日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > python >内容正文

python

python多进程队列中的队列_python 多进程队列数据处理详解

發布時間:2024/9/27 python 28 豆豆
生活随笔 收集整理的這篇文章主要介紹了 python多进程队列中的队列_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()

以上這篇python 多進程隊列數據處理詳解就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持python博客。

總結

以上是生活随笔為你收集整理的python多进程队列中的队列_python 多进程队列数据处理详解的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。