如何在Pool中使用Queue,Stack Overflow的回答,戳这里

其实吧官方文档看一遍应该就大部分都懂了。

需要注意的是:在使用多进程的时候,我们的进程函数的传入参数必须是pickle-able的,也就是参数必须可以被pickle保存下来,multiprocessing.Queue对象不能传递给pool.apply_*()等函数,需要使用multiprocessing.Manager().Queue()产生的对象

贴一下代码

# -*- coding: UTF-8 -*-
from multiprocessing import Process, Pool, Queue, Manager, JoinableQueue
import time
import os res = [] def put_task():
msg = []
for i in xrange(50):
time.sleep(0.1)
msg.append(str(os.getpid()))
return ','.join(msg) def collect_results(result):
res.append(result) def take_task(queue):
while 1:
print(queue.get(True)) def task_put(name, que):
for i in range(10):
time.sleep(1)
que.put("%d is done" % name) def task_take_queue(que, n):
i = 0
while i < n:
print(que.get(True))
i += 1 def consumer(input_q): while True:
item = input_q.get(True)
# 处理项目
print item # 此处替换为有用的工作
# 发出信号通知任务完成
input_q.task_done() def producer(output_q):
sequence = [1, 2, 3, 4] # range(5)[1:5]
for item in sequence:
# 将项目放入队列
time.sleep(1)
output_q.put(item)
# 建立进程 def method_1():
pool = Pool()
res = pool.map_async(put_task, range(5))
pool.close()
pool.join()
from pprint import pprint
pprint(res.get()) def method_2():
pool = Pool()
pool.apply_async(put_task, callback=collect_results)
pool.apply_async(put_task, callback=collect_results)
pool.apply_async(put_task, callback=collect_results)
pool.close()
pool.join()
from pprint import pprint
pprint(res) def method_3():
pool = Pool(processes=10)
m = Manager()
q = m.Queue()
for i in range(5):
pool.apply_async(task_put, (i, q))
pool.apply_async(task_take_queue, (q, 50))
pool.close()
pool.join() def method_4():
q = JoinableQueue() # 运行使用者进程
cons_p = Process(target=consumer, args=(q,))
cons_p.daemon = True # 定义该进程为后台运行 True - When a process exits, it attempts to terminate all of its daemonic child processes.
cons_p.start()
# 生产项目,sequence代表要发送给使用者的项目序列
# 在时间中,这可能是生成器的输出或通过一些其他方式生产出来 producer(q)
# 等待所有项目被处理
q.join() if __name__ == '__main__':
method_4()
 import multiprocessing
import os
import time def pool_init(q):
global queue # make queue global in workers
queue = q def task():
# can use `queue` here if you like
for i in range(5):
time.sleep(1)
queue.put(os.getpid()) def take_task():
while 1:
print(queue.get(True)) def run(pool):
tasks = []
tasks.append(pool.apply_async(take_task))
for i in range(os.cpu_count()):
tasks.append(pool.apply_async(task))
for t in tasks:
print(t.get(), ) if __name__ == '__main__':
queue = multiprocessing.Queue()
pool = multiprocessing.Pool(initializer=pool_init, initargs=(queue,))
run(pool)
pool.close()
pool.join()

 

python multiprocessing 使用的更多相关文章

  1. python multiprocessing example

    python multiprocessing example Server Code: #!/usr/bin/python #-*- coding: UTF-8 -*- # mpserver.py # ...

  2. python MultiProcessing模块进程间通信的解惑与回顾

    这段时间沉迷MultiProcessing模块不能自拔,没办法,python的基础不太熟,因此就是在不断地遇到问题解决问题.之前学习asyncio模块学的一知半解,后来想起MultiProcessin ...

  3. python multiprocessing模块

    python multiprocessing模块 原文地址 multiprocessing multiprocessing支持子进程.通信和共享数据.执行不同形式的同步,提供了Process.Queu ...

  4. python multiprocessing.Process

    在使用Kafka-python时自己写的一个bug 我在一个进程的__init__中初始化了一个producer,但是一直不好用 但是在函数里直接new一个就好用了 why? 需要说明的是produc ...

  5. python MultiProcessing标准库使用Queue通信的注意要点

    今天原本想研究下MultiProcessing标准库下的进程间通信,根据 MultiProcessing官网 给的提示,有两种方法能够来实现进程间的通信,分别是pipe和queue.因为看queue顺 ...

  6. Python multiprocessing

     推荐教程 官方文档 multiprocess各个模块较详细介绍 廖雪峰教程--推荐 Pool中apply, apply_async的区别联系 (推荐)python多进程的理解 multiproce ...

  7. python multiprocessing深度解析

    在写python多线程代码的时候,会用到multiprocessing这个包,这篇文章总结了一些这个包在多进程管理方面的一些原理和代码分析. 1. 问题一:是否需要显式调用pool的close和joi ...

  8. Python multiprocessing模块的Pool类来代表进程池对象

    #-*-coding:utf-8-*- '''multiprocessing模块提供了一个Pool类来代表进程池对象 1.Pool可以提供指定数量的进程供用户调用,默认大小是CPU的核心数: 2.当有 ...

  9. python Multiprocessing 多进程应用

    在运维工作中,经常要处理大量数据,或者要跑一些时间比较长的任务,可能都需要用到多进程,不管是管理端下发任务,还是客户端执行任务,如果服务器配置还可以,跑多进程还是挺能解决问题的 Multiproces ...

  10. python multiprocessing.Pool 中map、map_async、apply、apply_async的区别

    multiprocessing是python的多进程库,multiprocessing.dummy则是多线程的版本,使用都一样. 其中都有pool池的概念,进程池/线程池有共同的方法,其中方法对比如下 ...

随机推荐

  1. COM线程模型的行为

    原文:https://msdn.microsoft.com/library/ms809971.aspx Behavior of the COM Threading Models COM线程模型的行为 ...

  2. htm-文字标签和注释标签

    文字标签:修改文字的样式 <font></font>  属性: size:文字的大小 取值范围 1-7,超出了7,默认还是7 color:文字颜色 两种表示方法 英文单词:re ...

  3. Django基础三之视图函数

    一 Django的视图函数view 一个视图函数(类),简称视图,是一个简单的Python 函数(类),它接受Web请求并且返回Web响应. 响应可以是一张网页的HTML内容,一个重定向,一个404错 ...

  4. C# 如何在Linux操作系统下读取文件

    发布在Window环境上的微服务需要部署在Linux环境上,本以为没有什么问题,结果因为一处读取文件路径的原因报错了,在此记录一下两个问题:1.C#如何判断当前运行环境是什么操作系统:2.C#读取文件 ...

  5. opencv3.2.0形态学滤波之形态学梯度、顶帽、黑帽

    /*一.形态学梯度 (1)含义:是膨胀图和腐蚀图之差 (2)数学表达式:dst=morph-grad(src,element) =dilate(src,element) - erode(src,ele ...

  6. Windows7设置锁屏密码

    1.设置开机密码 2.设置屏幕保护程序 注意,不要选择无,选择其他的都可以,比如:气泡.彩带.空白

  7. java 方法重写和属性重写

    重写,子类对父类方法不满意,重写,但这是重写,要与父类的方法一模一样.方法名相同:参数列表相同:返回值相同或子类的返回值是父类返回值的子类型,父类是long,子类是int也不可以,因为父类引用指向子类 ...

  8. C#代码实现在控制台输入密码显示星号

    在控制台输入的内容C#默认按照字符串进行处理,如果直接让用户一次输入完毕就很难实现 显示星号的功能.但是如果让用户一次只能输入一个字符就,在将用户输入的字符替换为星号就可以实现了! 首先,C#中能让用 ...

  9. 《SQL Server 2008从入门到精通》--20180710

    目录 1.使用Transact-SQL语言编程 1.1.数据定义语言DDL 1.2.数据操纵语言DML 1.3.数据控制语言DCL 1.4.Transact-SQL语言基础 2.运算符 2.1.算数运 ...

  10. Webapi通过报文获取post上来的数据

    public HttpResponseMessage Post(HttpRequestMessage req) { var content = req.Content.ReadAsStringAsyn ...