码迷,mamicode.com
首页 > 系统相关 > 详细

org.eclipse.paho.client mqtt客户端连接超时

时间:2019-09-02 19:06:21      阅读:3105      评论:0      收藏:0      [点我收藏+]

标签:nec   cli   nbsp   java   exception   state   原因   inter   oop   

客户端订阅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());

org.eclipse.paho.client mqtt客户端连接超时

标签:nec   cli   nbsp   java   exception   state   原因   inter   oop   

原文地址:https://www.cnblogs.com/zhangyy3/p/11448130.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!