HiveMQ 中的 Websocket 不工作 - 日志中没有任何内容
Posted
技术标签:
【中文标题】HiveMQ 中的 Websocket 不工作 - 日志中没有任何内容【英文标题】:Websockets in HiveMQ not working - nothing in the log 【发布时间】:2017-01-21 07:03:53 【问题描述】:问题已解决:查看帖子底部
我无法连接到 websocket。端口 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 站点可以正常工作。 应该可以对 http 使用 SSL,对 websocket 使用不安全,我可以在这里看到:
Nginx MQTT websocket proxy 1
Nginx MQTT websocket proxy 2
我尝试了那里的配置,但没有运气。
解决方案: HiveMQ 不需要 Nginx 代理。 问题是 Firefox 不接受 websockets 的自签名证书。将“network.websocket.allowInsecureFromHTTPS”设置为 true 将使其工作。在 Chrome 中,您会收到有关 JavaScript 安全性的消息,您可以接受它。因为我只使用 Firefox 并且没有消息,所以花了几个小时才发现出了什么问题。 paho onFailure 函数也没有出现。
【问题讨论】:
【参考方案1】:很遗憾,websocket support 尚未在 MQTT.fx 中实现。
如果您坚持通过 websocket 连接,则必须使用不同的 MQTT 客户端。
干杯,
HiveMQ 团队的 Florian。
【讨论】:
对于 mqtt-spy 也不起作用。 # netstat -na | grep 8000: tcp 0 0 192.168.0.12:8000 0.0.0.0:* LISTEN 你可以试试The HiveMQ Websocket Client 吗? 这就是我要解决的问题。我的本地网站 (paho.js) 无法正常工作,所以我正在与客户一起尝试。还用 mqtt-spy 中的域进行了尝试。 ~# lsof -iTCP:8000 的输出:java 27019 root 687u IPv4 1190757 0t0 TCP hellgate.skulltronics.net:8000 (LISTEN) 好的,打开防火墙做了一个端口转发,它可以从您的站点到我的 ISP IP。那么为什么 mqtt-spy 和与 HiveMQ 在同一台服务器上的站点不起作用。 我发现了问题。我在 Nginx 中将 80(http)转发到 443(ssl)。所以带有非安全 websockets 的 https 不起作用?不知道为什么 mqtt-spy 不工作,但使用 http 工作。以上是关于HiveMQ 中的 Websocket 不工作 - 日志中没有任何内容的主要内容,如果未能解决你的问题,请参考以下文章