您的位置:首页 > 编程语言 > Java开发

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

2015-05-04 14:51 411 查看
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 发布:



ZMQ_SUB.java 订阅



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

ZMQ_PUB.java 发布:



ZMQ_SUB.java 订阅:



好了,现在也验证完了,我自己编译生成的是可以用的,旅行结束,回家吃饭去。拜拜
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  发布-订阅 ZeroMQ