springboot集成ZeroMQ

一 ZMQ简介

ZMQ(即ZeroMq)号称是"史上最快的消息队列",基于c语言开发的,实时流处理sorm的task之间的通信就是用的zeroMQ。它跟RabbitMQ,ActiveMQ之类有着相当本质的区别,ZeroMQ根本就不是一个消息队列服务器,更像是一组底层网络通讯库,对原有的Socket API加上一层封装,使我们操作更简便。如果说rabbitMQ已经近乎是一个小型操作系统,那么ZeroMQ就像是一个嵌入在操作系统内的一个组件,说白了ZeroMQ就是一组jar包,直接嵌入到项目中就可以运行,它不需要一台独立的服务器来承载整个消息系统。ZeroMQ的性能远远高于其它MQ。ZeroMQ对于消息的处理可以说除却请求-应答模式之外,基本就是不关系消息是否丢失,它只管发送。

ZeroMQ关注的不是消息的可靠送达,而是着眼于端到端的发送、接收。它希望的是尽快完成任务,而不介意部分消息的丢失。但这也并不是说他完全没有持久化的功能,ZeroMQ是具有一定的本地持久化的功能的,但是能保存的数据量比较有限,而且是暂存于内存中的。

虽然ZeroMQ在高并发环境下不会出问题,但是有可能会导致本地的缓存区被塞满而导致消息丢失的情况。所以不推荐在并发量较高的情境下使用ZeroMQ.

ZeroMQ与其他MQ类似,也实现了3中最基本的工作模式:发布-订阅,请求-应答,管道模式

二 springboot集成ZeroMq

  1. 添加ZeroMq依赖
xml 复制代码
<dependency>
   <groupId>org.zeromq</groupId>
    <artifactId>jeromq</artifactId>
    <version>0.5.2</version>
</dependency>
  1. 服务端接收消息
java 复制代码
import org.springframework.boot.CommandLineRunner;
import org.springframework.stereotype.Component;
import org.zeromq.ZMQ;

/**
 * @Author:sgw
 * @Date:2023/12/27
 * @Description: 监听zmq消息
 */
@Component
public class ZmqServer  implements CommandLineRunner {

    @Override
    public void run(String... args) throws Exception {
        try (
               //一般参数写1足够,如果希望创建多个IO线程,不要超出cpu核数
                ZMQ.Context context = ZMQ.context(1);
                ZMQ.Socket socket = context.socket(ZMQ.REP)) {
            // 绑定端口
            socket.bind("tcp://*:5555");
            while (true) {
                // 等待接收消息
                byte[] request = socket.recv(0);
                String text = new String(request);
                System.out.println("接收到消息: " + text);
                // 返回消息
                byte[] reply = "你好,我是服务端。".getBytes();
                socket.send(reply, 0);
            }
        }
    }
}
  1. 客户端发送消息
java 复制代码
public class ZmqClient {
    public static void main(String[] args) {
        try (ZMQ.Context context = ZMQ.context(1);
             ZMQ.Socket socket = context.socket(ZMQ.REQ)) {
            // 连接服务端
            socket.connect("tcp://localhost:5555");
            // 发送消息
            String text = "你好,我是客户端。";
            byte[] request = text.getBytes();
            socket.send(request, 0);
            System.out.println("发送消息:" + text);
            // 等待回复
            byte[] reply = socket.recv(0);
            String response = new String(reply);
            System.out.println("接收到回复:" + response);
        }
    }
}
相关推荐
ps酷教程6 小时前
Jackson 解决没有无参构造函数的反序列化问题
java
NiceCloud喜云6 小时前
Opus 4.8 的 Effort Control 怎么选:Low 到 Max 五档策略
android·java·大数据·前端·c++·python·spring
为思念酝酿的痛6 小时前
POSIX信号量
linux·运维·服务器·后端
小羊在睡觉6 小时前
力扣84. 柱状图中最大的矩形
后端·算法·leetcode·golang·go
_日拱一卒7 小时前
LeetCode:994腐烂的橘子
java·数据结构·算法·leetcode·深度优先
swipe7 小时前
Neo4j + Graph RAG 医疗知识图谱工程实践:患者教育问答真正需要的是“关系可追溯”
后端·langchain·llm
隔窗听雨眠7 小时前
Nginx网关响应慢排查手记
java·服务器·nginx
智慧物业老杨7 小时前
智慧物业合同周期管理系统:从风险预警到智能交接的全流程数智化落地方案
java·人工智能·python
源码宝8 小时前
MES系统源码:Java8 + SpringBoot2.7 + MySQL8 + Redis,后端源码清爽易扩展
java·后端·源码·springboot·mes系统·源码二开·mes源码
JAVA社区8 小时前
Java高级全套教程(十)—— SpringCloudAlibaba超详细实战详解
java·开发语言·spring cloud·面试·职场和发展