我在笔记本电脑上运行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在一个网络内完成。没有移动数据。有人可以解释一下为什么会发生这种情况吗?
答案 0 :(得分:0)
您可以运行的第一个检查之一是通过您的代理配置(如果它是您自己的代理,否则请询问您的供应商的凭据),并查看您是否已设置任何用户名/密码以进行连接。很可能这是客户端连接超时的问题。
如果是这种情况,您只需在客户端配置中设置用户名/密码,如:
client.username_pw_set("username_on_broker", "password_on_broker")
另外,我建议使用urlparse.urlparse("broker url")
来清理/标准化您的代理网址
如果这对您没有帮助,请联系。