HiveMQ中的Websockets无法正常工作 - 日志中没有任何内容

时间:2017-01-21 07:03:54

标签: ssl websocket mqtt paho hivemq

问题已解决:检查发布底部

我无法连接到websockets。 1883端口工作正常。 这是MQTT.fx的输出:

2017-01-21 07:46:26,293  INFO --- BrokerConnectorController      : onConnect
2017-01-21 07:46:26,294  INFO --- ScriptsController              : Clear console.
2017-01-21 07:46:26,295  INFO --- MqttFX ClientModel             : MqttClient with ID MQTT_FX_Client_Websocket assigned.
2017-01-21 07:46:36,314 ERROR --- MqttFX ClientModel             : Error when connecting
org.eclipse.paho.client.mqttv3.MqttException: Connection lost
at org.eclipse.paho.client.mqttv3.internal.CommsReceiver.run(CommsReceiver.java:146) ~[org.eclipse.paho.client.mqttv3-1.1.0.jar:?]
at java.lang.Thread.run(Unknown Source) [?:1.8.0_112]
Caused by: java.io.EOFException
at java.io.DataInputStream.readByte(Unknown Source) ~[?:1.8.0_112]
at org.eclipse.paho.client.mqttv3.internal.wire.MqttInputStream.readMqttWireMessage(MqttInputStream.java:65) ~[org.eclipse.paho.client.mqttv3-1.1.0.jar:?]
at org.eclipse.paho.client.mqttv3.internal.CommsReceiver.run(CommsReceiver.java:107) ~[org.eclipse.paho.client.mqttv3-1.1.0.jar:?]
... 1 more
2017-01-21 07:46:36,315 ERROR --- MqttFX ClientModel:Please verify your Settings (e.g. Broker Address, Broker Port & Client ID) and the user credentials!
org.eclipse.paho.client.mqttv3.MqttException: Connection lost
at org.eclipse.paho.client.mqttv3.internal.CommsReceiver.run(CommsReceiver.java:146) ~[org.eclipse.paho.client.mqttv3-1.1.0.jar:?]
at java.lang.Thread.run(Unknown Source) [?:1.8.0_112]
Caused by: java.io.EOFException
at java.io.DataInputStream.readByte(Unknown Source) ~[?:1.8.0_112]
at org.eclipse.paho.client.mqttv3.internal.wire.MqttInputStream.readMqttWireMessage(MqttInputStream.java:65) ~[org.eclipse.paho.client.mqttv3-1.1.0.jar:?]
at org.eclipse.paho.client.mqttv3.internal.CommsReceiver.run(CommsReceiver.java:107) ~[org.eclipse.paho.client.mqttv3-1.1.0.jar:?]
... 1 more
2017-01-21 07:46:36,321  INFO --- ScriptsController              : Clear console.
2017-01-21 07:46:36,322 ERROR --- BrokerConnectService           : Connection lost

我对服务器和端口进行了Telnet测试,得到一个空白终端。 我想这意味着有一个连接,否则我会有一个"连接失败"。消息日志插件没有显示任何内容,日志文件中没有任何内容。

其Debian和HiveMQ 3.2.2。

JAVA_OPTS:  -Djava.net.preferIPv4Stack=true -XX:-UseSplitVerifier -noverify -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=/opt/hivemq/heap-dump.hprof

-------------------------------------------------------------------------

2017-01-21 07:37:02,159 INFO  - Starting HiveMQ Server
2017-01-21 07:37:02,176 INFO  - HiveMQ version: 3.2.2
2017-01-21 07:37:02,178 INFO  - HiveMQ home directory: /opt/hivemq
2017-01-21 07:37:02,226 INFO  - Log Configuration was overridden by /opt/hivemq/conf/logback.xml
2017-01-21 07:37:12,013 INFO  - Loaded Plugin HiveMQ JMX Metrics Reporting Plugin - v3.0.0
2017-01-21 07:37:12,014 INFO  - Loaded Plugin HiveMQ MQTT Message Log Plugin - v3.0.0
2017-01-21 07:37:12,014 INFO  - Loaded Plugin HiveMQ Sys Topic Plugin - v3.0.0
2017-01-21 07:37:12,014 INFO  - Loaded Plugin HiveMQ JVM Metrics Plugin - v3.1.0
2017-01-21 07:37:12,038 INFO  - JMX Metrics Reporting started.
2017-01-21 07:37:12,099 INFO  - JMX Metrics Reporting started.
2017-01-21 07:37:12,109 INFO  - Starting TCP listener on address 192.168.0.12 and port 1883
2017-01-21 07:37:12,131 INFO  - Starting Websocket listener on address 192.168.0.12 and port 8000
2017-01-21 07:37:12,139 INFO  - Started TCP Listener on address 192.168.0.12 and on port 1883
2017-01-21 07:37:12,139 INFO  - Started Websocket Listener on address 192.168.0.12 and on port 8000
2017-01-21 07:37:12,140 INFO  - Started HiveMQ in 9967ms
2017-01-21 07:37:12,142 INFO  - No valid license file found. Using evaluation license, restricted to 25 connections.

修改

好吧,这是一个Nginx问题,因为没有SSL,我的JavaScript网站就可以运行。 对于websockets,应该可以使用SSL作为http而无需使用SSL,我可以在这里看到:

Nginx MQTT websocket proxy 1

Nginx MQTT websocket proxy 2

我尝试了配置,但没有运气。

解决方案: 使用HiveMQ不需要Nginx代理。 问题是Firefox不接受websockets的自签名证书。设置" network.websocket.allowInsecureFromHTTPS"真实将使它工作。在Chrome中,您会收到有关JavaScript安全性的消息,您可以接受它。由于我只使用Firefox而且没有消息,因此需要花费数小时才能找出问题所在。 paho onFailure功能也没有显示出来。

1 个答案:

答案 0 :(得分:0)

遗憾的是,websocket support尚未在MQTT.fx中实现。

如果您坚持通过websocket连接,则必须使用不同的MQTT客户端。

干杯,

Florian,来自HiveMQ团队。