All Downloads are FREE. Search and download functionalities are using the official Maven repository.

reactor.net.zmq.ZeroMQWorker Maven / Gradle / Ivy

There is a newer version: 1.1.6.RELEASE
Show newest version
package reactor.net.zmq;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.zeromq.*;
import reactor.io.Buffer;

import java.util.UUID;

/**
 * @author Jon Brisbin
 */
public abstract class ZeroMQWorker implements Runnable {

	private final Logger log   = LoggerFactory.getLogger(getClass());
	private final ZLoop  zloop = new ZLoop();

	private final UUID                id;
	private final int                 socketType;
	private final int                 ioThreadCount;
	private final ZLoop.IZLoopHandler inputHandler;

	private volatile boolean      closed;
	private volatile boolean      shutdownCtx;
	private volatile ZContext     zmq;
	private volatile ZMQ.Socket   socket;
	private volatile ZMQ.PollItem pollin;

	public ZeroMQWorker(UUID id, int socketType, int ioThreadCount, ZContext zmq) {
		this.id = id;
		this.socketType = socketType;
		this.ioThreadCount = ioThreadCount;
		this.zmq = zmq;
		this.inputHandler = new ZLoop.IZLoopHandler() {
			@Override
			public int handle(ZLoop loop, ZMQ.PollItem item, Object arg) {
				ZMsg msg = ZMsg.recvMsg(socket);
				if (null == msg || msg.size() == 0) {
					return 0;
				}
				if (closed) {
					return -1;
				}

				String connId;
				switch (ZeroMQWorker.this.socketType) {
					case ZMQ.ROUTER:
						connId = msg.popString();
						break;
					default:
						connId = ZeroMQWorker.this.id.toString();
				}
				ZeroMQNetChannel netChannel = select(connId)
						.setConnectionId(connId)
						.setSocket(socket);

				ZFrame content;
				while (null != (content = msg.pop())) {
					netChannel.read(Buffer.wrap(content.getData()));
				}
				msg.destroy();

				return 0;
			}
		};
	}

	@Override
	public void run() {
		if (closed) {
			return;
		}
		if (null == zmq) {
			zmq = new ZContext(ioThreadCount);
			shutdownCtx = true;
		}
		socket = zmq.createSocket(socketType);
		socket.setIdentity(id.toString().getBytes());
		configure(socket);

		pollin = new ZMQ.PollItem(socket, ZMQ.Poller.POLLIN);
		if (log.isTraceEnabled()) {
			zloop.verbose(true);
		}
		zloop.addPoller(pollin, inputHandler, null);

		start(socket);

		zloop.start();

		zmq.destroySocket(socket);
	}

	public void shutdown() {
		if (closed) {
			return;
		}
		zloop.removePoller(pollin);
		zloop.destroy();

		closed = true;

		if (shutdownCtx) {
			zmq.destroy();
		}
	}

	protected abstract void configure(ZMQ.Socket socket);

	protected abstract void start(ZMQ.Socket socket);

	protected abstract ZeroMQNetChannel select(Object id);

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy