连接丢失(32109) - java.io.EOFException(MqttAndroidClient)

时间:2016-09-20 12:36:07

标签: java android mqtt paho

P.S。请在结束之前阅读整个问题。

每当调用connect方法时,我都会收到以下异常:

  

连接丢失(32109) - java.io.EOFException   在org.eclipse.paho.client.mqttv3.internal.CommsReceiver.run(CommsReceiver.java:146)   在java.lang.Thread.run(Thread.java:818)   引起:java.io.EOFException   at java.io.DataInputStream.readByte(DataInputStream.java:77)   在org.eclipse.paho.client.mqttv3.internal.wire.MqttInputStream.readMqttWireMessage(MqttInputStream.java:65)   在org.eclipse.paho.client.mqttv3.internal.CommsReceiver.run(CommsReceiver.java:107)

我尝试了几段代码片段,但两者都引发了相同的异常。

方法1

private final String serverUri = "tcp://95.177.135.232:9001";

private void mqqtConnectAndroidClient() {
    String clientId = "clientID-" + MqttClient.generateClientId();
    mqttAndroidClient = new MqttAndroidClient(getMainActivity(), serverUri, clientId);
    MqttConnectOptions mqttConnectOptions = new MqttConnectOptions();
    mqttConnectOptions.setKeepAliveInterval(60);
    mqttConnectOptions.setCleanSession(true);
    mqttConnectOptions.setMqttVersion(MqttConnectOptions.MQTT_VERSION_3_1_1);
    try {
        mqttAndroidClient.connect(mqttConnectOptions, null, new IMqttActionListener() {
            @Override
            public void onSuccess(IMqttToken asyncActionToken) {
                subscribeToTopic();
            }

            @Override
            public void onFailure(IMqttToken asyncActionToken, Throwable exception) {
                AppLog.Error("Failed to connect to: " + serverUri);
                exception.printStackTrace();
            }
        });
    } catch (MqttException e) {
        e.printStackTrace();
    }
}

方法2

private final String serverUri = "tcp://95.177.135.232:9001";

private void methodTwo() {
    try {
        MqttDefaultFilePersistence mdfp = new MqttDefaultFilePersistence(MQTT_DIR);
        mqttClient = new MqttClient(serverUri, "1", mdfp);
        MqttConnectOptions options = new MqttConnectOptions();
        options.setMqttVersion(MqttConnectOptions.MQTT_VERSION_3_1_1);
        options.setKeepAliveInterval(60);
        options.setAutomaticReconnect(true);
        options.setCleanSession(true);
        mqttClient.connect(options);
        mqttClient.subscribe("#");
        mqttClient.setCallback(new MqttCallback() {

            @Override
            public void connectionLost(Throwable arg0) {
                AppLog.Error("Connection lost");
                try {
                    mqttClient.connect();
                } catch (MqttException e) {
                    e.printStackTrace();
                }
            }

            @Override
            public void deliveryComplete(IMqttDeliveryToken arg0) {
                AppLog.Error("deliveryComplete");
            }

            @Override
            public void messageArrived(String arg0, MqttMessage arg1) throws Exception {
                AppLog.Error("messageArrived");
                AppLog.Error(arg1.toString());
            }
        });
    } catch (MqttException e) {
        AppLog.Error("Main Exception");
        e.printStackTrace();
    }
}

订阅方法

public void subscribeToTopic() {
    try {
        String subscriptionTopic = "#";
        mqttAndroidClient.subscribe(subscriptionTopic, 0, null, new IMqttActionListener() {
            @Override
            public void onSuccess(IMqttToken asyncActionToken) {
                AppLog.Error("Subscribed!");
            }
            @Override
            public void onFailure(IMqttToken asyncActionToken, Throwable exception) {
                AppLog.Error("Failed to subscribe");
            }
        });
    } catch (MqttException ex) {
        System.err.println("Exception whilst subscribing");
        ex.printStackTrace();
    }
}

如果我在HiveMQ尝试相同的服务器URI,它在正确的连接下工作得很好,订阅也给了我结果。我使用以下两个库:

  

compile' org.eclipse.paho:org.eclipse.paho.client.mqttv3:1.1.0'   编译' org.eclipse.paho:org.eclipse.paho.android.service:1.0.2'

我尝试了一些SO答案,例如OneTwoThreeFourFive,但这些答案都不适用于我。< / p>

任何帮助将不胜感激。提前谢谢!

2 个答案:

答案 0 :(得分:3)

您正在使用端口9001,而HiveMQ链接指向通过Websockets客户端的MQTT。

您正在指定一个以tcp://开头的连接URI,它将向服务发出信号,表明它应该与本机MQTT连接而不是通过Websockets连接MQTT。

正如bug报告中提到的实现Websocket支持一样,您需要使用ws://启动连接URI,以使客户端代码知道使用Websockets。

答案 1 :(得分:0)

我已解决问题,请在此处查看更多详细信息 https://github.com/eclipse/paho.mqtt.java/issues/207

有趣,但是即使生成唯一的客户端ID,我们也能看到。多台计算机上有多个客户端,因此我想可能有多台计算机生成clientID,但是重复的clientId几乎不可能达到纳秒级。

相关问题