mqtt等待来自服务器响应超时,等待来自服务器的响应时超时 (32000) at org.eclipse.paho.client.mqttv3.interna...

等待来自服务器的响应时超时 (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

8e5bf5490cf7213dfee6345ab07efffa.png

最后重装EMQX服务器解决 可能是缓存问题

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值