浅谈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()
相关推荐
workflower2 分钟前
活动图描述场景
开发语言·软件工程·需求分析·软件需求·敏捷流程
梦想的初衷~4 分钟前
基于现代R语言【Tidyverse、Tidymodel】的机器学习方法
开发语言·机器学习·r语言
liliangcsdn4 分钟前
mac mlx大模型框架的安装和使用
java·前端·人工智能·python·macos
香蕉可乐荷包蛋7 分钟前
Python学习之路(十三)-常用函数的使用,及优化
开发语言·python·学习
惜.己15 分钟前
使用python的读取xml文件,简单的处理成元组数组
xml·开发语言·python·测试工具
Everbrilliant8919 分钟前
Ubuntu系统下交叉编译Android的X265库
linux·运维·ubuntu·x265交叉编译·android x265·ffmpeg x265
倔强青铜三24 分钟前
苦练Python第25天:玩转字典
人工智能·python·面试
我不要放纵27 分钟前
LVS集群搭建
linux·服务器·lvs
阿巴~阿巴~32 分钟前
自主Shell命令行解释器
linux·运维·服务器
许白掰32 分钟前
Linux入门篇学习——借助 U 盘或 TF 卡拷贝程序到开发板上
linux·学习·借助 u 盘拷贝程序到开发板上·借助 tf卡拷贝程序到开发板上