MQTT paho客户端连接超时错误

时间:2017-04-14 12:33:11

标签: python raspberry-pi mqtt

我在笔记本电脑上运行MQTT Mosquitto代理。然后我试图将2个Paho MQTT客户端连接到它:1)使用Java Paho的Android手机和2)使用Python Paho的Raspberry Pi。

从Android连接完美。没问题。

然而,Raspberry由于某种原因无法连接。而不是client.connect方法阻止,并在一段时间后收到以下内容:

Traceback (most recent call last):
  File "sensorsClient.py", line 28, in <module>
    client.connect(mqttServer, 1883)
  File "/usr/local/lib/python2.7/dist-packages/paho/mqtt/client.py", line 700, in connect
    return self.reconnect()
  File "/usr/local/lib/python2.7/dist-packages/paho/mqtt/client.py", line 822, in reconnect
    sock = socket.create_connection((self._host, self._port), source_address=(self._bind_address, 0))
  File "/usr/lib/python2.7/socket.py", line 571, in create_connection
    raise err
socket.error: [Errno 110] Connection timed out

连接的代码如下:

import paho.mqtt.client as mqtt

def on_connect(client, userdata, flags, rc):
    print("Connected with result code "+str(rc))
    client.subscribe("$SYS/#")

def on_message(client, userdata, msg):
    print(msg.topic+" "+str(msg.payload))

mqttServer = 'zzz.xxx.ccc.qqq' # Public IP of the laptop


client = mqtt.Client("", True, None, mqtt.MQTTv31)
client.on_connect = on_connect
client.on_message = on_message

client.connect(mqttServer, 1883)
client.loop_start()

Everythin通过WIFI在一个网络内完成。没有移动数据。有人可以解释一下为什么会发生这种情况吗?

1 个答案:

答案 0 :(得分:0)

您可以运行的第一个检查之一是通过您的代理配置(如果它是您自己的代理,否则请询问您的供应商的凭据),并查看您是否已设置任何用户名/密码以进行连接。很可能这是客户端连接超时的问题。

如果是这种情况,您只需在客户端配置中设置用户名/密码,如:

client.username_pw_set("username_on_broker", "password_on_broker")

另外,我建议使用urlparse.urlparse("broker url")来清理/标准化您的代理网址

如果这对您没有帮助,请联系。