如何作为MQTT客户端累计消息1秒,然后保存到文件中

2022-03-28 00:00:00 python mqtt mosquitto libmosquitto

问题描述

我的问题如下: 我写了一个订阅一个主题的程序,其中两个带有一个键的字典分别每秒到达更多的次数。在每条消息上,它们都会更改其值。 我将这些字典保存在一个名为&status&q;的大缓冲字典中。我需要的是将每秒状态的快照(&Q;)保存到文件中。

我尝试了计时。睡眠(1),但它漂移。而且我不知道如何用日程安排来处理这个问题,因为已经存在客户端循环.

我是Python和MQTT的新手,非常感谢您的帮助

我的代码:

import paho.mqtt.client as mqtt
import time
import json

Status = {}

#create client instance
client = mqtt.Client(client_id=None, clean_session=True, transport="tcp")

#connect to broker
client.connect("my_broker", 1883)

#use subscribe() to subscribe to a topic and receive messages
client.subscribe("topic/#", qos=0)

def test1_callback(client, userdata, msg):
    msg_dict = json.loads((msg.payload))
    Status.update(msg_dict)

client.message_callback_add("topic/test1", test1_callback)

while True:
    client.loop_start()
    time.sleep(1)
    client.loop_stop()

    with open('Data.txt', 'a+') as file:
        t = time.localtime()
        Status["time"]= time.strftime("%H:%M:%S", t)
            file.write(str(Status["time"]) + " ")
            file.write(str(Status["key1"]) + " ")
            file.write(str(Status["key2"]) + " ")

    client.loop_start()

解决方案

与其手动停止网络线程,我更喜欢使用每秒触发的计时器。此外,将数据存储到文件时锁定数据可能是个好主意,否则两者之间可能会发生更新:

# ...
import threading

def test1_callback(client, userdata, msg):
   msg_dict = json.loads((msg.payload))
   lock.acquire()
   Status.update(msg_dict)
   lock.release()

def timer_event():
   lock.acquire()
   # save to file here
   lock.release()
   # restart timer
   threading.Timer(1, timer_event).start()

Status = {}
lock = threading.Lock()

# client initialization
# ...

client.loop_start()
threading.Timer(1, timer_event).start()

while True:
   pass

但这并不能防止您的存储值漂移,因为该主题显然发布得太频繁,因此您的订阅者(甚至是代理)无法足够快地处理消息。

因此,您可能希望缩短发布此主题的时间间隔。还要注意,您订阅了一个多级主题-即使"topic/test1"之外的主题没有在代码中处理,它们仍然会给代理和订阅客户端带来负载

相关文章