mqtt等待来自服务器响应超时,org.eclipse.paho.client mqtt客户端连接超时
客户端订阅mqtt 的时候 显示超时。第二次重起服务可能就好了,但是可能会丢消息。报错如下org.eclipse.paho.client.mqttv3.MqttException: 等待来自服务器的响应时超时at org.eclipse.paho.client.mqttv3.internal.ExceptionHelper.createMqttException(ExceptionHelper.j
客户端订阅mqtt 的时候 显示超时。第二次重起服务可能就好了,但是可能会丢消息。
报错如下
org.eclipse.paho.client.mqttv3.MqttException: 等待来自服务器的响应时超时
at org.eclipse.paho.client.mqttv3.internal.ExceptionHelper.createMqttException(ExceptionHelper.java:31) ~[org.eclipse.paho.client.mqttv3-1.2.1.jar!/:na]
at org.eclipse.paho.client.mqttv3.internal.ClientState.checkForActivity(ClientState.java:741) ~[org.eclipse.paho.client.mqttv3-1.2.1.jar!/:na]
at org.eclipse.paho.client.mqttv3.internal.ClientComms.checkForActivity(ClientComms.java:816) ~[org.eclipse.paho.client.mqttv3-1.2.1.jar!/:na]
at org.eclipse.paho.client.mqttv3.internal.ClientComms.checkForActivity(ClientComms.java:802) ~[org.eclipse.paho.client.mqttv3-1.2.1.jar!/:na]
at org.eclipse.paho.client.mqttv3.TimerPingSender$PingTask.run(TimerPingSender.java:79) ~[org.eclipse.paho.client.mqttv3-1.2.1.jar!/:na]
at java.util.TimerThread.mainLoop(Timer.java:555) ~[na:1.8.0_221]
at java.util.TimerThread.run(Timer.java:505) ~[na:1.8.0_221]
解决办法:
log.info("try connect to mqtt");
//调用connect 后,一定要再调用 一下token.waitForCompletion();这样应该就可以了。原因不明。
IMqttToken token = client.connect(connOpts);
token.waitForCompletion();
log.info("connect mqtt success");
client.subscribe(topic, 1, new MqttMsgListener());
魔乐社区(Modelers.cn) 是一个中立、公益的人工智能社区,提供人工智能工具、模型、数据的托管、展示与应用协同服务,为人工智能开发及爱好者搭建开放的学习交流平台。社区通过理事会方式运作,由全产业链共同建设、共同运营、共同享有,推动国产AI生态繁荣发展。
更多推荐

所有评论(0)