ZeroMQ:订阅-发布模式的java程序示例

ZeroMQ:订阅-发布模式的java程序示例 

休息完了我们可以接着我们的旅程了,现在我们来验证下自己编译生成的东西是否能用,

具体怎么编译就请回顾我们的上期旅行http://blog.csdn.net/sinat_19351993/article/details/45477743 

首先把我们的要用到的东西拿过来 libzmq.dll ,jzmq.dll和zmq.jar


libzmq.dll 和jzmq.dll的文件目录要加到path环境变量中,或者再简单点也可以这么办,把它俩直接放在jdk当中Java\jdk7\bin也就相当于加到path环境变量中去了。zmq.jar就直接放到项目的lib目录下面就可以了。

下面就开始验证是否能用了

发布-订阅者模式之发布服务

import org.zeromq.ZMQ;
import org.zeromq.ZMQ.Context;
import org.zeromq.ZMQ.Socket;

public class ZMQ_PUB {
 
   public static void main(String[] args) throws InterruptedException {
	   //准备上下文和套接字
       Context context = ZMQ.context(1); 
       Socket publisher = context.socket(ZMQ.PUB);
       publisher.bind("tcp://*:5555");
       //发布100条消息
       Thread.sleep(1000);
       for (int i = 0; i < 100; i++) {
           publisher.send(("admin " + i).getBytes(), ZMQ.NOBLOCK);
           System.out.println("pub msg " + i);
           Thread.sleep(1000);
       }
       
       //关闭套接字和上下文
       publisher.close();
       context.term();
    }
}

发布-订阅者模式之订阅客户端。持续接收消息

import org.zeromq.ZMQ;
import org.zeromq.ZMQ.Context;
import org.zeromq.ZMQ.Socket;

public class ZMQ_SUB {
	 
	   public static  void main(String[] args) {
		   //准备上下文
		   //套接字连接至服务器
	        Context context = ZMQ.context(1);
	        Socket subscriber = context.socket(ZMQ.SUB);
	        subscriber.connect("tcp://localhost:5555");
	 
	        //订阅任何主题(An empty 'option_value' of length zero shall subscribe to all incoming messages)
	        subscriber.subscribe("".getBytes());
	        for (int i=0;i<100;i++) {
	        	//Receive a message.	 
	            String string = new String(subscriber.recv(0));         
	            System.out.println("recv 1" + string);
	        }
	        
	        //关闭套接字和上下文
	        subscriber.close();
	        context.term();
	   }
}

下面启动项目吧。然后先运行ZMQ_SUB.java 订阅,再运行ZMQ_PUB.java 发布

得到如下结果

ZMQ_PUB.java 发布:

ZeroMQ:订阅-发布模式的java程序示例_第1张图片

ZMQ_SUB.java 订阅

ZeroMQ:订阅-发布模式的java程序示例_第2张图片

若是先运行ZMQ_PUB.java 发布,再运行ZMQ_SUB.java 订阅,结果又是另一种

ZMQ_PUB.java 发布:

ZeroMQ:订阅-发布模式的java程序示例_第3张图片

ZMQ_SUB.java 订阅:

ZeroMQ:订阅-发布模式的java程序示例_第4张图片

好了,现在也验证完了,我自己编译生成的是可以用的,旅行结束,回家吃饭去。拜拜

你可能感兴趣的:(java,ZeroMQ)