等待来自服务器的响应时超时 (32000) at org.eclipse.paho.client.mqttv3.internal
try {
// host为主机名,test为clientid即连接MQTT的客户端ID,一般以客户端唯一标识符表示,MemoryPersistence设置clientid的保存形式,默认为以内存保存
this.client = new MqttClient(HOST, clientid, new MemoryPersistence());
// MQTT的连接设置
MqttConnectOptions options = new MqttConnectOptions();
// 设置是否清空session,这里如果设置为false表示服务器会保留客户端的连接记录,这里设置为true表示每次连接到服务器都以新的身份连接
options.setCleanSession(true);
// 设置连接的用户名
options.setUserName(userName);
// 设置连接的密码
options.setPassword(passWord.toCharArray());
// 设置超时时间 单位为秒
options.setConnectionTimeout(10);
// 设置会话心跳时间 单位为秒 服务器会每隔1.5*20秒的时间向客户端发送个消息判断客户端是否在线,但这个方法并没有重连的机制
options.setKeepAliveInterval(20);
// 设置回调函数
client.setCallback(new MqttCallback() {
public void connectionLost(Throwable cause) {
System.out.println("connectionLost");
}
public void messageArrived(String topic, MqttMessage message) throws Exception {
System.out.println(message);
handleMessage(topic,message);
}
public void deliveryComplete(IMqttDeliveryToken token) {
System.out.println("deliveryComplete---------"+ token.isComplete());
}
});
client.connect(options);
//订阅消息
System.out.println(topic);
client.subscribe(topic);
return null;
} catch (Exception e) {
e.printStackTrace();
return null;
}
定位问题:可能是因为网络或者并发导致连接不上,通过paho客户端也发现连接服务器比较慢
解决方法:
先增加超时时间,后查mqtt服务器并发,网络状况
// 设置超时时间 单位为秒
options.setConnectionTimeout(1000);
// 设置会话心跳时间 单位为秒 服务器会每隔1.5*20秒的时间向客户端发送个消息判断客户端是否在线,但这个方法并没有重连的机制
options.setKeepAliveInterval(2000);
打开EMQX服务器的dashboard
默认账户名---密码:admin---public
最后重装EMQX服务器解决 可能是缓存问题