浅谈Python之Mqtt

一、基本介绍

在Python中使用MQTT,通常会使用paho-mqtt这个库,它是一个广泛使用的MQTT客户端库,支持MQTT v3.1和v3.1.1协议。

二、基本步骤

安装paho-mqtt库

使用pip安装paho-mqtt库:

bash 复制代码
pip3 install paho-mqtt

创建MQTT连接

设置MQTT代理(Broker)的地址、端口和主题(topic),并生成一个随机的客户端ID。

python 复制代码
from paho.mqtt import client as mqtt_client
import random

broker = 'broker.emqx.io'  # MQTT代理地址
port = 1883                # MQTT代理端口
topic = "/python/mqtt"     # 订阅的主题
client_id = f'python-mqtt-{random.randint(0, 1000)}'  # 客户端ID

编写连接回调函数

当客户端成功连接到MQTT代理时,会调用on_connect回调函数。

python 复制代码
def on_connect(client, userdata, flags, rc):
    if rc == 0:
        print("Connected to MQTT Broker!")
    else:
        print("Failed to connect, return code %d\n", rc)

创建客户端并连接

创建一个MQTT客户端对象,并设置连接回调函数,然后连接到MQTT代理。

python 复制代码
client = mqtt_client.Client(client_id)
client.on_connect = on_connect
client.connect(broker, port)

发布消息

使用publish方法向指定的主题发布消息。

python 复制代码
def publish(client):
    msg_count = 0
    while True:
        msg = f"messages: {msg_count}"
        result = client.publish(topic, msg)
        if result[0] == 0:
            print(f"Send `{msg}` to topic `{topic}`")
        else:
            print(f"Failed to send message to topic {topic}")
        msg_count += 1
        time.sleep(1)

订阅消息

设置on_message回调函数来处理接收到的消息,并使用subscribe方法订阅主题。

python 复制代码
def on_message(client, userdata, msg):
    print(f"Received `{msg.payload.decode()}` from `{msg.topic}` topic")

def subscribe(client):
    client.subscribe(topic)
    client.on_message = on_message

启动网络循环

使用loop_foreverloop_start方法启动网络循环,以处理网络事件。

python 复制代码
client.loop_forever()  # 或者使用 client.loop_start() 在不同的线程中运行

三、完整代码示例

以下是一个完整的代码示例,展示了如何连接MQTT代理、发布消息和订阅消息。

python 复制代码
# python 3.6
import random
import time
from paho.mqtt import client as mqtt_client

broker = 'broker.emqx.io'
port = 1883
topic = "/python/mqtt"
client_id = f'python-mqtt-{random.randint(0, 1000)}'

def on_connect(client, userdata, flags, rc):
    if rc == 0:
        print("Connected to MQTT Broker!")
    else:
        print("Failed to connect, return code %d\n", rc)

def on_message(client, userdata, msg):
    print(f"Received `{msg.payload.decode()}` from `{msg.topic}` topic")

def publish(client):
    msg_count = 0
    while True:
        msg = f"messages: {msg_count}"
        result = client.publish(topic, msg)
        if result[0] == 0:
            print(f"Send `{msg}` to topic `{topic}`")
        else:
            print(f"Failed to send message to topic {topic}")
        msg_count += 1
        time.sleep(1)

def subscribe(client):
    client.subscribe(topic)
    client.on_message = on_message

def run():
    client = mqtt_client.Client(client_id)
    client.on_connect = on_connect
    client.on_message = on_message
    client.connect(broker, port)
    client.loop_start()
    publish(client)

if __name__ == '__main__':
    run()
相关推荐
AI攻城狮31 分钟前
用 Playwright 实现博客一键发布到稀土掘金
python·自动化运维
曲幽1 小时前
FastAPI分布式系统实战:拆解分布式系统中常见问题及解决方案
redis·python·fastapi·web·httpx·lock·asyncio
孟健16 小时前
Karpathy 用 200 行纯 Python 从零实现 GPT:代码逐行解析
python
码路飞18 小时前
写了个 AI 聊天页面,被 5 种流式格式折腾了一整天 😭
javascript·python
曲幽20 小时前
FastAPI压力测试实战:Locust模拟真实用户并发及优化建议
python·fastapi·web·locust·asyncio·test·uvicorn·workers
chlk1231 天前
Linux文件权限完全图解:读懂 ls -l 和 chmod 755 背后的秘密
linux·操作系统
舒一笑1 天前
Ubuntu系统安装CodeX出现问题
linux·后端
改一下配置文件1 天前
Ubuntu24.04安装NVIDIA驱动完整指南(含Secure Boot解决方案)
linux
敏编程1 天前
一天一个Python库:jsonschema - JSON 数据验证利器
python