java sub_java调用zeromq PUB-SUB模式

直接上代码

package com.guo.server;

import org.zeromq.ZMQ;

import org.zeromq.ZMQ.Context;

import org.zeromq.ZMQ.Socket;

public class Publisher {

public void start(){

System.out.println("===========publisher start=============");

Context context = ZMQ.context(1);

Socket socket = context.socket(ZMQ.PUB);

socket.setLinger(5000);

socket.setSndHWM(0);

socket.bind("tcp://192.168.124.130:6666");

try {

Thread.sleep(10000);

} catch (InterruptedException e) {

}

for(int i=0;i<10;i++){

String pubstr ="WORK task"+i;

socket.send(pubstr,0);

try {

Thread.sleep(1000);

} catch (InterruptedException e) {

}

}

socket.send("END", 0);

System.out.println("===========publisher end=============");

socket.close();

context.term();

}

}

package com.guo.client;

import org.zeromq.ZMQ;

import org.zeromq.ZMQ.Context;

import org.zeromq.ZMQ.Socket;

public class Subscriber {

public void start(){

System.out.println("===========subscriber start=============");

Context context = ZMQ.context(1);

Socket socket = context.socket(ZMQ.SUB);

socket.connect("tcp://192.168.124.130:6666");

socket.subscribe("".getBytes());

while(true){

byte[] res =socket.recv(0);

String resStr = new String(res);

System.out.println("substring is ="+resStr);

if("END".equalsIgnoreCase(resStr)){

break;

}

}

System.out.println("===========subscriber end=============");

socket.close();

context.term();

}

}

说明:

在启动Subscriber程序后,启动publisher程序。重要的是这个模式下publisher的消息可以被同时多个subscriber程序接收并处理。实现广播的方式。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值