emqx 发布二十万以上字节消息失败

最近在做通过emqx通信的项目,其间出现一个很奇怪的问题,车载终端发送字节超过二十万的消息后,emqx会直接中断与客户端的连接,导致车载终端消息发送失败。这里我说一下我的解决问题的思路。

1.刚开始以为是消息大小超过mqtt协议的限制,查看emqx.conf文件发现,默认的mqtt.max_packet_size=1M,我的消息二十几万个字节,也没有到1M.排除这个因素。

2.查看emqx日志,发现每次发送大消息的时候,客户端会被强制kill掉,且报错日志:Process: <0.3295.0> on node 'emqx@172.16.0.13', Context: maximum heap size reached, Max Heap Size: 10485760, Total Heap Size: 11644009, Kill: true, Error Logger: true, Message Queue Len: 0, GC Info: [{old_heap_block_size,4298223},{heap_block_size,8596446},{mbuf_size,0},{recent_size,1977200},{stack_size,72},{old_heap_size,0},{heap_size,3047563},{bin_vheap_size,119061},{bin_vheap_block_size,75110},{bin_old_vheap_size,0},{bin_old_vheap_block_size,46422}]。从报错日志来看,应该是消息超过最大heap内存大小。于是增大了消息队列长度,,缓冲区大小,垃圾回收次数,等很多参数,都还是不行。最后想法是emqx的erlang虚拟机参数设置的heap大小不够,想着设置一下,但是查看官方文档并没有相应的参数设置说明。最终加了官方技术交流群,在群里提出相关问题,群里大部分认为是消费延迟,导致的消息堆积,但是我觉得我的场景不符合消息堆积的场景。因为我测试环境就一个终端连接emqx,消息也是30秒发一次,一个消费者,每次发送小的消息,消费者会立马消费,一旦突然加大消息体数据达到二十几万字节,生产者客户端会立马与emqx断掉。这种场景不存在消息堆积,最后官方技术人员了解到我们情况,问了一下我的emqx版本,我当前用的是4.4.1版本,官方技术人员回答这个情况应该是这个版本的bug,让升级到4.4.10版本,我升级到4.4.10版本后,再次尝试真的就搞定了。记录一下这次排错之旅,记住避坑emqx4.4.1版本。最后感谢emqx官方技术人员支持!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
要在Java中使用emqx进行订阅和发布16进制数据,需要使用MQTT客户端库。以下是一个简单的示例代码,它将以16进制格式发布一个字节数组,并订阅一个主题以接收16进制格式的消息。 ```java import org.eclipse.paho.client.mqttv3.*; import org.eclipse.paho.client.mqttv3.persist.MemoryPersistence; public class MqttExample { public static void main(String[] args) throws MqttException { String broker = "tcp://localhost:1883"; String clientId = "JavaExample"; MemoryPersistence persistence = new MemoryPersistence(); // 创建MQTT客户端实例 MqttClient client = new MqttClient(broker, clientId, persistence); // 设置回调函数 client.setCallback(new MqttCallback() { public void connectionLost(Throwable cause) {} public void messageArrived(String topic, MqttMessage message) throws Exception { // 接收到消息时执行的代码 byte[] payload = message.getPayload(); String hexString = bytesToHexString(payload); System.out.println("Received message: " + hexString); } public void deliveryComplete(IMqttDeliveryToken token) {} }); // 连接到MQTT代理服务器 client.connect(); // 订阅主题 String topic = "test"; client.subscribe(topic); // 发布消息 byte[] payload = {0x01, 0x02, 0x03}; MqttMessage message = new MqttMessage(payload); message.setQos(0); client.publish(topic, message); // 断开连接 client.disconnect(); } // 将字节数组转换为16进制字符串 public static String bytesToHexString(byte[] bytes) { StringBuilder sb = new StringBuilder(); for (byte b : bytes) { sb.append(String.format("%02X", b)); } return sb.toString(); } } ``` 在上面的示例中,`bytesToHexString`方法将字节数组转换为16进制字符串。在订阅的回调函数中,接收到的消息将转换为16进制字符串并打印到控制台上。在发布消息时,字节数组将作为`MqttMessage`对象的负载,并使用`client.publish`方法发布到指定的主题上。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值