python3多进程 queue 取值_python 多进程队列数据处理

# -*- coding:utf8 -*-

import paho.mqtt.client as mqtt

from multiprocessing import Process, Queue

import time, random, os

import camera_person_num

MQTTHOST = "172.19.4.4"

MQTTPORT = 1883

mqttClient = mqtt.Client()

q = Queue()

# 连接MQTT服务器

def on_mqtt_connect():

mqttClient.connect(MQTTHOST, MQTTPORT, 60)

mqttClient.loop_start()

# 消息处理函数

def on_message_come(lient, userdata, msg):

# print(msg.topic + ":" + str(msg.payload.decode("utf-8")))

q.put(msg.payload.decode("utf-8")) # 放入队列

print("产生消息", msg.payload.decode("utf-8"))

# 消息处理开启多进程

# p = Process(target=talk, args=("/camera/person/num/result", msg.payload.decode("utf-8")))

# p.start()

def consumer(q, pid):

print("开启消费序列进程", pid)

while True:

msg = q.get()

# p = Process(target=talk, args=("/camera/person/num/result", msg, pid))

# p.start()

talk("/camera/person/num/result", msg, pid)

# subscribe 消息订阅

def on_subscribe():

mqttClient.subscribe("test123", 1) # 主题为"test"

mqttClient.on_message = on_message_come # 消息到来处理函数

# publish 消息发布

def on_publish(topic, msg, qos):

mqttClient.publish(topic, msg, qos);

# 多进程中发布消息需要重新初始化mqttClient

def talk(topic, msg, pid):

cameraPsersonNum = camera_person_num.CameraPsersonNum(msg)

t_max, t_mean, t_min = cameraPsersonNum.personNum()

# time.sleep(20)

print("消费消息", pid, msg)

mqttClient2 = mqtt.Client()

mqttClient2.connect(MQTTHOST, MQTTPORT, 60)

mqttClient2.loop_start()

mqttClient2.publish(topic, '{"max":' + str(t_max) + ',"mean":' + str(t_mean) + ',"min:"' + t_min + '}', 1)

mqttClient2.disconnect()

def main():

on_mqtt_connect()

on_subscribe()

for i in range(1, 3):

c1 = Process(target=consumer, args=(q, i))

c1.start()

while True:

pass

if __name__ == '__main__':

main()

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Python 3.6中的多进程queue是一个在多个进程之间共享数据的队列。它基于进程间通信(IPC)机制来实现数据的安全传递和同步。 使用多进程queue的关键是先创建一个Queue对象,然后将其传递给不同的进程,使得多个进程可以读取和写入相同的队列。以下是使用python多进程queue的基本步骤: 1. 首先导入必要的库: ```python from multiprocessing import Process, Queue ``` 2. 创建Queue对象: ```python queue = Queue() ``` 3. 定义需要在多进程中执行的函数,该函数可以将数据写入队列: ```python def write_to_queue(queue, data): queue.put(data) ``` 4. 创建进程并启动: ```python p = Process(target=write_to_queue, args=(queue, "Hello world!")) p.start() ``` 5. 在主进程中从队列中读取数据: ```python data = queue.get() print(data) # 输出: Hello world! ``` 以上示例中,我们创建了一个进程p,该进程执行write_to_queue函数并将数据"Hello world!"写入队列。然后从主进程中使用queue.get()方法获取队列中的数据,并将其打印出来。 需要注意的是,多进程queue中的数据是由操作系统来管理和同步的,因此确保数据传递的顺序和可靠性。此外,为了终止子进程,我们还可以使用p.join()方法。 总结:Python 3.6中的多进程queue提供了一种在多个进程之间共享数据的有效和方便的方式,通过使用Queue对象,我们可以实现数据的安全传递和同步。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值