ZMQ订阅模式消息丢失

跨系统使用ZMQ订阅模式进行消息传输,压测发现会有千分之一的概率SUB端丢失消息,需要修改以下参数进行优化,SUB和PUB端都需要修改

  • ZMQ_RECBUF 用于设置和获取 ZeroMQ 套接字的接收缓冲区大小。

  • ZMQ_SNDBUF 用于设置和获取 ZeroMQ 套接字的发送缓冲区大小。

  • ZMQ_RCVHWM 用于设置和获取 ZeroMQ 套接字的接收高水位标记。当消息队列中未接收的消息数量达到 RCVHWM 值时,后续的消息将被丢弃或阻塞发送端(取决于套接字类型)。

  • ZMQ_SNDHWM 用于设置和获取 ZeroMQ 套接字的发送高水位标记。当消息队列中未发送的消息数量达到 SNDHWM 值时,后续的消息将被丢弃或阻塞发送端(取决于套接字类型)。

     // 创建 ZeroMQ 套接字
     void* socket = zmq_socket(context, ZMQ_PULL);
    
     // 设置接收缓冲区大小为 1000000 字节
     int recvBufSize = 1000000;
     zmq_setsockopt(socket, ZMQ_RECBUF, &recvBufSize, sizeof(recvBufSize));
    
     // 设置发送缓冲区大小为 2000000 字节
     int sendBufSize = 2000000;
     zmq_setsockopt(socket, ZMQ_SNDBUF, &sendBufSize, sizeof(sendBufSize));
    
     // 设置接收高水位标记为 1000
     int recvHWM = 1000;
     zmq_setsockopt(socket, ZMQ_RCVHWM, &recvHWM, sizeof(recvHWM));
    
     // 设置发送高水位标记为 2000
     int sendHWM = 2000;
     zmq_setsockopt(socket, ZMQ_SNDHWM, &sendHWM, sizeof(sendHWM));
    
     // 关闭 ZeroMQ 套接字
     zmq_close(socket);
    
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值