Тема не прогрессирует мимо ZMQ.context(1)

Я пытаюсь реализовать простой пример паба, где у меня есть сервер, и я публикую периодические уведомления о доступности для клиентов.

Это выполняется как часть службы Windows - в комплекте с InnoSetup и launch4j и Apache procrun/prunsrv.

Поток не выходит за рамки создания контекста. Что может быть не так?

import java.io.IOException;
import java.util.Date;
import org.msgpack.MessagePack;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.zeromq.ZMQ;
import org.ocpsoft.prettytime.*;

/**
 * Notification service for updates to configuration in the logger
 * @author Aalhad
 */
public class NotificationServer extends Thread {

    private final Logger log = LoggerFactory.getLogger(this.getClass());
    private volatile boolean shouldRun;

    private PrettyTime upTime;
    private PreferenceManager prefMgr = PreferenceManager.getInstance();
    public ZMQ.Context context;
    public ZMQ.Socket pubSocket;

    public NotificationServer() {
        log.debug("Entered notification server constructor ......................");
        context = ZMQ.context(1);
        log.debug("THIS DOES NOT GET PRINTED ... it is as if we are blocking in ZMQ.context!!!");
        pubSocket = context.socket(ZMQ.PUB);
        pubSocket.bind("tcp://*:"+prefMgr.getNotificationPort());
        pubSocket.bind("ipc://powerlogger");

        log.debug("NotificationServer created");
    }

    @Override
    public void run() {
        log.debug("Entering run loop of Notification Server");
        setStarting();
        log.debug("Writing to tcp port: {}", prefMgr.getNotificationPort());
        upTime = new PrettyTime();        
        ConfigMessage msg = prefMgr.getConfigMessage();
        MessagePack msgPack = new MessagePack();
        byte[] sendBytes;

        try {
            log.debug("Going ahead and sending: {}", msg);
            sendBytes = msgPack.write(msg);
            pubSocket.send(sendBytes);
            log.debug("Finished sending msg");
        } catch (IOException ex) {
            log.error("Could not send first config notification",ex);
        }

        //On starts and restarts, we send the current configuration to our
        //subscribers
        String upSince;
        while (shouldRun()) {
            log.trace("In the notification loop");
            upSince = upTime.format(new Date(0));
            log.trace("============================================================== Started: {}", upSince );
            ConfigMessage cfgMsg = new ConfigMessage();
            cfgMsg.msgType = MessageType.UPSINCE;
            cfgMsg.message = upSince;

            try {
                // ..... code here to write the time into a
                // messagepack structure and publishing it 
                sleep(5000);
                log.trace("After sleeping in notification loop");
            } catch (InterruptedException ex) {
                log.error("Notification thread disturbed when sleeping.");
            }
        }
    }

    public synchronized void shutDown() {
        shouldRun = false;
        log.trace("Set shouldRun to false in discovery server");
        try {
            if (pubSocket != null) {
                pubSocket.close();
                context.term();
            }
        }
        catch(Exception e) {
            log.error("Interesting situation when trying to close the discovery socket when shutting down",e);
        }
    }

    public synchronized void setStarting() {
        shouldRun = true;        
    }

    private synchronized boolean shouldRun() {
        return shouldRun;
    }       
}

1 ответ

Решение

Нашел ошибку. Это была простая проблема - забыть предоставить банку для службы при создании установщика. Журналы не показывают, что класс не может быть найден.

Исправлена.

Другие вопросы по тегам