等待来自服务器的响应时超时 (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服务器解决 可能是缓存问题