一、安装
搭建一个mqtt服务器,这里我们采用mosquitto
1、 下载地址:https://mosquitto.org/download/
2、 选择windows:https://mosquitto.org/files/binary/win64/mosquitto-2.0.18-install-windows-x64.exe
3、 右键安装即可
默认的安装路径在这里:C:\Program Files\mosquitto
二、修改配置文件
1、 进入mosquitto的安装目录,找到配置文件
C:\Program Files\mosquitto\ mosquitto.conf
2、 修改mosquitto指定的监听端口
listener 8899

3、 关闭mosquitto的匿名登录功能
allow_anonymous false

4、 修改配置用户的配置文件路径(这里要用绝对路径)
password_file D:\other\mosquitto\pwd.emample

三、启动
1、 进入windows的service。启动mqtt broker服务

2、命令行启动:mosquitto.exe -c mosquitto.conf -v
四、使用
1、用python写一个订阅者的代码
import paho.mqtt.client as mqtt
import ssl
context = ssl.create_default_context()
# 加载证书
context.load_default_certs()
# 将证书转换为常量
cert_data = ssl.DER_cert_to_PEM_cert(context.get_ca_certs()[0])
broker = '127.0.0.1'
port = 7788
topic = "AIOT"
# 当客户端和服务端连接成功后执行的回调函数
def on_connect(client, userdata, flags, rc):
print(f"Connected with result code {rc}")
# 当连接成功后,客户端订阅一个主题,并消费该主题的消息
client.subscribe(topic=topic)
# 当客户端订阅的主题收到消息的时候执行的回调函数
def on_message(client, userdata, msg):
# client 那个客户端
# userdata 用户数据
# msg 实际的消息对象
print(msg.topic+" "+str(msg.payload))
# 实例化一个客户端,实现mqtt协议版本3.1、3.1.1、5.0的客户端类,是一个主要的与MQTT服务端通信的类
client = mqtt.Client()
# 实例化的时候可以传递参数进去
# client_id="",
# 唯一的客户端ip字符串,当前连接mqtt服务器时候使用,如果cliendid长度为0,则会自动随机生产一个clientid,这种情况下,clean_session参数必须是true
# clean_session=None,
# 决定clint类型的参数,如果为true,当client失去连接时候中间人将删除所有关于这个client的信息,如果为false,则说明这是一个永久的client,当失去连接的时候,发布的消息和队列里的消息
# 都会被保持。
# 注意,当失去连接的时候clinet永远不会抛弃自己需要发布的消息,当调用connetc()/reconnect()会重新发送这些消息
# userdata=None,
# 用户定义的任何类型的数据将被传输为userdata,后面可以使用user_data_set()来更新这个参数
# protocol=MQTTv311,
# client使用的mqtt版本
# transport="tcp",
# 设置通信机制,websocket或者tcp、一个是websocket传输,一个tcp传输
# reconnect_on_failure=True
# 连接失败是否重新连接
# 客户端绑定回调方法,其实这里定义的很多回调函数
client.on_connect = on_connect
client.on_message = on_message
# client.on_disconnect
#
# client.on_publish
# 客户端连接mqtt broker服务器
client.connect(bind_address=broker, bind_port=port, keepalive=60)
# client.connect_async()
# 客户端和mqtt broker服务器断开连接
client.disconnect()
# 永久执行,保持和mqtt broker服务端的长期通信
client.loop_forever()
我们当然也可以用命令行的方式启动订阅者,可以通过help来查询使用方法
mosquitto_sub.exe –help

2、发布者代码
import paho.mqtt.client as mqtt
import time
broker = '127.0.0.1'
port = 8899
topic = "AIOT"
def on_connect(client, userdata, flags, rc):
print(f"Connected with result code {rc}")
client = mqtt.Client()
client.on_connect = on_connect
client.connect(broker, port, 60)
for i in range(60):
client.publish(topic, payload=i, qos=0, retain=False)
print(f"send {i} to a/b{topic}")
time.sleep(1)
client.loop_forever()
当然我们可以使用命令行的方式启用生产者,可以通过help来查询使用方法
mosquitto_pub.exe –help

3、通过证书连接mqtt broker
import paho
import ssl
mqttc = paho.mqtt.client.Client('my_client')
...
# 构建一个SSL上下文
SSL_CTX = {
'ssl_port': 8884,
'ca': "/ ca.crt",
'client_cert': '/client/client.crt',
'client_key':" /client/client.key",
'cert_reqs': None,
'tls_version': None,
'ciphers': None,
'insecure': False # 关闭insecure选项
}
# 设置TLS参数
mqttc.tls_set(SSL_CTX['ca'],
certfile=SSL_CTX['client_cert'],
keyfile=SSL_CTX['client_key'],
cert_reqs=SSL_CTX['cert_reqs'],
tls_version=SSL_CTX['tls_version'],
ciphers=SSL_CTX['ciphers'])
# ca_certs=None, certfile=None, keyfile=None, cert_reqs=None, tls_version=None, ciphers=None, keyfile_password=Non
# 要求验证服务端证书中域名与mqtt连接创建时输入的broker域名一致
mqttc.tls_insecure_set(SSL_CTX['insecure'])
浙公网安备 33010602011771号