1、multiprocessing模块——跨平台版本的多进程模块

multiprocessing模块提供了一个Process类来代表一个进程对象,下面的例子演示了启动一个子进程并等待其结束:

from multiprocessing import Process
import os #子进程要执行的代码
def run_proc(name):
print('Run child process %s (%s)…'%(name , os.getpid())) if __name__=='__main__':
print('parent process %s.'%os.getpid())
p=Process(target=run_proc,args=('test',))
print('Child process will start')
p.start()
p.join()
print('Child process end') parent process 14960.
Child process will start
Run child process test (12496)…
Child process end

上述代码的说明:

1、父进程的进程ID的获取,通过os.getpid()

2、创建子进程时,用到了语句

p=Process(target=run_proc,args=('test',))

只需传入一个执行函数的函数名(如上文的run_proc)和函数的参数(args,注意一个参数时括号中的逗号),如此构造一个Process实例,并用start()启动。

join()方法可以等待子进程结束后继续往下执行,通常用于进程间的同步。

2、Pool

如果要创建大量进程,可以通过进程池的方式批量创建子进程:

from multiprocessing import Pool
import os,time,random def long_time_task(name):
print('run task %s (%s)'%(name,os.getpid()))
start=time.time()
time.sleep(random.random()*3)
end=time.time()
print('task %s runs %.2fs'%(name,end-start)) if __name__=='__main__':
print('parent process %s '%os.getpid())
p=Pool(4)
for i in range(5):
p.apply_async(long_time_task,args=(i,))
print('Waiting for all subprocesses done…')
p.close()
p.join()
print('All subprocesses done')
parent process 5280
Waiting for all subprocesses done…
run task 0 (2768)
run task 1 (12844)
run task 2 (15340)
run task 3 (7612)
task 1 runs 0.33s
run task 4 (12844)
task 0 runs 1.45s
task 2 runs 2.01s
task 3 runs 2.91s
task 4 runs 2.89s
All subprocesses done

上述代码的说明:

1、对Pool对象调用join()方法会等待所有子进程执行完毕,调用join()前必须先调用close(),调用close()后就不能再添加新的process了

2、输出结果中,task0,1,2,3是立即执行的,而task4要等前面的某个task执行完后才能执行,这是因为我们之前人为设置了Pool的大小为4,因此最多同时执行4个进程。这是人为根据需要制定的,并不是操作系统的限制,如果我们改为

p=Pool(5)

就可以同时跑5个进程。

Pool的默认大小是CPU的核数。

3、子进程subprocess

很多时候,子进程不是自身,而是一个外部进程。——暂未理解这句话啥意思

我们创建子进程后,还要控制子进程的输入和输出。

subprocess模块可以让我们非常方便地启动一个子进程,然后控制其输入输出。

举例:在Python代码中运行命令

nslookup www.python.org

来达到和命令行同时运行相同的效果。

import subprocess
print('$ nslookup www.python.org')
r=subprocess.call(['nslookup','www.python.org'])
print('Exit Code:',r)
$ nslookup www.python.org
��Ȩ��Ӧ��:
������: public1.114dns.com
Address: 114.114.114.114
����: dualstack.python.map.fastly.net
Addresses: 2a04:4e42:36::223
151.101.108.223
Aliases: www.python.org
Exit Code: 0

如果子进程还需要输入,则可以通过communicate()方法输入:

import subprocess
print('$nslookup www.python.org')
p=subprocess.Popen(['nslookup'],stdin=subprocess.PIPE,stdout=subprocess.PIPE,stderr=subprocess.PIPE)
output,err=p.communicate(b'set q=mx\npython.org\nexit\n')
print(output.decode('utf-8'))
print('Exit Code:',p.returncode)

其中

p.communicate(b'set q=mx\npython.org\nexit\n')

相当于在命令行执行命令nslookup,然后手动输入:

set q=mx
python.org
exit

4、进程间通信

Python的multiprocessing模块提供了Queue、Pipes等多种方式来交换数据。

以Queue为例,在父进程中创建两个子进程,一个往Queue中写数据,另一个从Queue中读数据:

from multiprocessing import Queue,Process
import os,time,random #写数据进程要执行的代码
def write(q):
print('Process to write:%s'%os.getpid())
for value in ['A','B','C']:
print('put %s to queue'%value)
q.put(value)
time.sleep(random.random()) #读数据进程执行的代码
def read(q):
print('Process to read:%s'%os.getpid())
while True:
value=q.get(True)
print('Get %s from queue.'%value) if __name__=='__main__':
#父进程创建Queue并传给各个子进程
q=Queue()
pw=Process(target=write,args=(q,))
pr=Process(target=read,args=(q,))
#启动子进程pw,写入
pw.start()
#启动子进程pr,读取
pr.start() #等待pw结束
pw.join()
#pr进程里是死循环,无法自行终止,只能强行结束
pr.terminate()

结果:

Process to write:2696
put A to queue
Process to read:7944
Get A from queue.
put B to queue
Get B from queue.
put C to queue
Get C from queue.

在Unix/Linux下,multiprocessing模块封装了fork()调用,使我们不需要关注fork()的细节。由于Windows没有fork调用,因此multiprocessing需要模拟出fork的效果,父进程中所有Python对象都必须通过pickle序列化再传到子进程中去,所以如果multiprocessing在Windows下失效了,要先考虑是不是pickle失败了

2020.9.28 多进程multiprocess 进程池pool 子进程subprocess 进程间通信的更多相关文章

  1. python学习笔记——multiprocessing 多进程组件 进程池Pool

    1 进程池Pool基本概述 在使用Python进行系统管理时,特别是同时操作多个文件目录或者远程控制多台主机,并行操作可以节约大量时间,如果操作的对象数目不大时,还可以直接适用Process类动态生成 ...

  2. Python多进程库multiprocessing中进程池Pool类的使用[转]

    from:http://blog.csdn.net/jinping_shi/article/details/52433867 Python多进程库multiprocessing中进程池Pool类的使用 ...

  3. Python多进程库multiprocessing创建进程以及进程池Pool类的使用

    问题起因最近要将一个文本分割成好几个topic,每个topic设计一个regressor,各regressor是相互独立的,最后汇总所有topic的regressor得到总得预测结果.没错!类似bag ...

  4. [转]Python多进程并发操作中进程池Pool的应用

    Pool类 在使用Python进行系统管理时,特别是同时操作多个文件目录或者远程控制多台主机,并行操作可以节约大量的时间.如果操作的对象数目不大时,还可以直接使用Process类动态的生成多个进程,十 ...

  5. Python多进程并发操作中进程池Pool的应用

    Pool类 在使用Python进行系统管理时,特别是同时操作多个文件目录或者远程控制多台主机,并行操作可以节约大量的时间.如果操作的对象数目不大时,还可以直接使用Process类动态的生成多个进程,十 ...

  6. python 进程池pool简单使用

    平常会经常用到多进程,可以用进程池pool来进行自动控制进程,下面介绍一下pool的简单使用. 需要主动是,在Windows上要想使用进程模块,就必须把有关进程的代码写if __name__ == ‘ ...

  7. python 使用进程池Pool进行并发编程

    进程池Pool 当需要创建的子进程数量不多时,可以直接利用multiprocessing中的Process动态成生多个进程,但如果是上百甚至上千个目标,手动的去创建进程的工作量巨大,此时就可以用到mu ...

  8. 多任务-进程之进程池Pool

    1.什么是池? 首先从字面上看,池代表着一个容器,用来承载着某些内容的容器,了解到这里,就对进程池有了一个初步的轮廓. 2.什么是进程池Pool? (1)利用现实中的事物来理解: 对于小白初学者,接触 ...

  9. Python 之并发编程之manager与进程池pool

    一.manager 常用的数据类型:dict list 能够实现进程之间的数据共享 进程之间如果同时修改一个数据,会导致数据冲突,因为并发的特征,导致数据更新不同步. def work(dic, lo ...

随机推荐

  1. oracle 快速创建用户

    create user  testdb identified by 123456; grant  dba to testdb;

  2. Java基础之Scanner类中next()与nextLine()方法的区别

    java中使用Scanner类实现数据输入十分简单方便,Scanner类中next()与nextLine()都可以实现字符串String的获取,所以我们会纠结二者之间的区别. 其实next()与nex ...

  3. Java线程--Atomic原子类使用

    原创:转载需注明原创地址 https://www.cnblogs.com/fanerwei222/p/11871241.html Java线程--Atomic原子类使用 package concurr ...

  4. 使用Reachability监测网络变化-陈鹏

    在appdelegate里面添加观察者,并启动监测 // 使用通知中心监听kReachabilityChangedNotification通知 [[NSNotificationCenter defau ...

  5. 微信小程序开发常用功能

    获取用户信息 调用 wx.getUserProfile 方法获取用户基本信息.页面产生点击事件(例如 button 上 bindtap 的回调中)后才可调用,每次请求都会弹出授权窗口,用户同意后返回 ...

  6. git本地仓库关联多个远程仓库及取消关联

    关联 本地和远程仓库关联步骤: 在网站上(如gitee.github等,这里以gitee为例)首先添加好自己的ssh公钥 本地创建一个空的项目,即文件夹. 在文件夹下git init初始化仓库 在gi ...

  7. desktopForWin安装

    window环境下搭建appium(win7和win10都试过,能行),这里只说了Android自动化环境.iOS自动化需要MacOS支持. 一.python环境搭建 下载Python 官网下载地址h ...

  8. 帆软报表(finereport)鼠标悬停背景变色

    在报表中,为了突出鼠标所在单元格,当鼠标悬浮时突出背景色(字体),鼠标离开后恢复原有的背景色(字体). 在设计器 模板>模板 Web 属性>填报页面设置,去除填报当前编辑行背景设置的勾选, ...

  9. 神奇小证明之——世界上只有5个正多面体+构造x3=2a3

    今天我彻底放飞自我了...作业还没写完...但就是要总结一些好玩的小性质...谁给我的勇气呢?

  10. 框架5--nginx安装部署 上(web服务)

    目录 框架5--nginx安装部署(web服务) 1.练习 2.昨日问题 3.今日内容 4.什么是web服务 5.web服务器软件 6.部署Nginx 7.平滑增加Nginx模块 8.Nginx的命令 ...