进程池


  • 方便创建,管理进程,单独进程的Process创建,需要手动开启,维护任务函数,以及释放回收
  • 进程池不需要这么麻烦,进程提前创建好,未来在使用的时候,可以直接给与任务函数
  • 某个进程池中的任务结束了,占用的进程会自己释放刚才工作的事情,以便接收下一个
  • P = Pool(num) #创建一个包含有num个空闲进程的池子
  • p.apply() 填充任务,任务如果结束,会自动释放掉当前占用的进程
  • 创建大规模任务,Pool(100)
  • 1,创建进程池:进程池中的进程是可以复用的
    • from mutliprocessing import Pool
    • p = Pool(num)
      • num:指明当前多少空闲进程创建出来
    • p.apply(func,args,)
      • 阻塞行为
      • func:指明填充功能函数名
      • args:对应的参数
      • 阻塞行为相当于(lock)加锁的进程池工作方式,有序的,第一个执行完才会执行第二个
    • p.apply_async(func,args,)
      • 非阻塞行为,并发的,无序的
    • p.close()
      • 在整个业务结束之后,进程池要首先关闭
      • 关闭之后进程池里的旧任务会继续执行但是没有办法填充新的任务
      • 进程池关闭了就无法打开
    • p.join()
      • 进程回收,把关闭了的进程池中的每个进程join() 释放回收掉
    • p.terminate()
      • 直接关闭进程池,并且终止所欲偶进程
  • 2,进程池的工作的返回值:
    • res = p.apply(func,)

      • res就是进程池的工作结果
      • 立竿见影就可以看到结果,就因为apply填充任务是阻塞行为
    • res = p.apply_aysnc(func,)
      • 非阻塞的结果,可以立即拿到,但是不是结果,只是一个抽象虚拟的值
        • 这个值代表进程结束后的返回值
      • res.get() #使用要谨慎
        • 当前非阻塞执行的进程,有优先级先结束
        • 强制要求立即这个结果,但是会影响进程之间的并发效果
  • 3,进程池中的通信队列是特殊的
    • from multiprocessing import Manager
    • q = Manager().Queue()   #进程共享队列
    • 无法使用管道(Pipe)
  • #进程池创建
    from multiprocessing import Pool
    import sys
    def work_a():
    for var in range(1,5):
    print(var)
    sys.stdout.flush()
    def work_b():
    for var in range(5,10):
    print(var)
    sys.stdout.flush()
    def work_c():
    for var in range(10,15):
    print(var)
    sys.stdout.flush()
    def main():
    p = Pool(2) #参数:可以最多同时执行任务个数,并不是填充的最大任务个数
    #p.apply_async(func=work,args=(a,b),) 非阻塞行为
    p.apply(func=work_a)#阻塞行为
    p.apply(func=work_b)
    p.apply(func=work_c)
    #?: 是否是阻塞行为执行完这三个任务
    #阻塞的话:1个等一个,同步
    #非阻塞:异步
    p.close()
    p.join()
    if __name__ == '__main__':
    main()

    运行结果:

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
  • #获取阻塞进程池返回结果
    from multiprocessing import Pool
    import sys
    def work_a():
    for var in range(1,5):
    print(var)
    sys.stdout.flush()
    return 'a'
    def work_b():
    for var in range(5,10):
    print(var)
    sys.stdout.flush()
    return 'b'
    def work_c():
    for var in range(10,15):
    print(var)
    sys.stdout.flush()
    return 'c'
    def main():
    p = Pool(2) #参数:可以最多同时执行任务个数,并不是填充的最大任务个数
    res1 = p.apply(func=work_a) #阻塞的一个等一个,res1执行完才会执行res2
    res2 = p.apply(func=work_b)
    res3 = p.apply(func=work_c)
    print('res1进程返回结果:%s' % res1),print('res2进程返回结果:%s' % res2),print('res3进程返回结果:%s' % res3)
    p.close(),p.join()
    if __name__ == '__main__':
    main()

    运行结果:

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    res1进程返回结果:a
    res2进程返回结果:b
    res3进程返回结果:c
  • #获取非阻塞进程池返回结果
    from multiprocessing import Pool
    import sys
    def work_a():
    for var in range(1,5):
    # print(var)
    sys.stdout.flush()
    return 'a'
    def work_b():
    for var in range(5,10):
    # print(var)
    sys.stdout.flush()
    return 'b'
    def work_c():
    for var in range(10,15):
    # print(var)
    sys.stdout.flush()
    return 'c'
    def main():
    p = Pool(2) #参数:可以最多同时执行任务个数,并不是填充的最大任务个数
    res1 = p.apply_async(func=work_a) #非阻塞的会返回一个抽象的数据
    res2 = p.apply_async(func=work_b)
    res3 = p.apply_async(func=work_c)
    print('res1进程返回结果:%s' % res1.get()),print('res2进程返回结果:%s' % res2.get()),print('res3进程返回结果:%s' % res3.get())
    p.close(),p.join()
    if __name__ == '__main__':
    main()

    运行结果:

    res1进程返回结果:a
    res2进程返回结果:b
    res3进程返回结果:c
  • #进程池通讯--Queue
    from multiprocessing import Pool,Manager,Queue
    from time import sleep
    import sys
    def work_a(q):
    #生产者 放十次
    for var in range(10):
    print('生产者:',var)
    sys.stdout.flush()
    q.put(var)
    sleep(1)
    def work_b(q):
    #消费者,拿十次
    for var in range(10):
    res = q.get() #阻塞行为
    print('消费者:',var)
    sys.stdout.flush()
    def main():
    q = Manager().Queue() #进程共享队列
    p = Pool(5) #进程可以复用
    p.apply_async(func=work_a,args={q,q})
    p.apply_async(func=work_b,args={q,q})
    p.close()
    p.join()
    if __name__ == '__main__':
    main()

    运行结果:

    生产者: 0
    消费者: 0
    生产者: 1
    消费者: 1
    生产者: 2
    消费者: 2
    生产者: 3
    消费者: 3
    生产者: 4
    消费者: 4
    生产者: 5
    消费者: 5
    生产者: 6
    消费者: 6
    生产者: 7
    消费者: 7
    生产者: 8
    消费者: 8
    生产者: 9
    消费者: 9  
  •   

      

      

41.进程池--Pool的更多相关文章

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

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

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

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

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

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

  4. python 进程池pool简单使用

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

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

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

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

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

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

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

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

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

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

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

随机推荐

  1. 51nod 1843 排列合并机(DP+组合)

    题解链接 不过求ggg不用O(n2)DPO(n^2)DPO(n2)DP,g[n]g[n]g[n]直接就是卡特兰数的第n−1n-1n−1项.即: g[n]=(2(n−1)n−1)−(2(n−1)n−2) ...

  2. 51nod 1594 Gcd and Phi 反演

    OTZ 又被吊打了...我当初学的都去哪了??? 思路:反演套路? 提交:\(1\)次 题解: 求\(\sum_{i=1}^{n}\sum_{j=1}^{n}\varphi(gcd(\varphi(i ...

  3. 009_STM32程序移植之_内部falsh

    flash  模拟  EEPROM  实验 1. 测试环境:STM32C8T6 2. 测试接口: 3. 串口使用串口一,波特率9600 单片机引脚------------CH340引脚 VCC---- ...

  4. 013_使用 user.txt 文件中的人员名单,在计算机中自动创建对应的账户并配置初始密码

    for i in `cat user.txt`do    useradd $i    echo "123456" | passwd --stdin $idone

  5. bzoj 5072

    对于某一大小的连通子图包含的黑点的数目的最大值和最小值都能取到考虑树形dp$f[i][j]$ 表示从 $i$ 的子树中选出大小为 $j$ 的联通子图黑点数目的最小值$g[i][j]$ 表示从 $i$ ...

  6. 《剑指offer》数组中只出现一次的数字

    本题来自<剑指offer> 数组中只出现一次的数字 题目: 一个整型数组里除了两个数字之外,其他的数字都出现了两次.请写程序找出这两个只出现一次的数字. 思路: 思路一:在<剑指of ...

  7. 关于lda算法的一个博客

    http://www.cnblogs.com/LeftNotEasy/archive/2011/01/08/lda-and-pca-machine-learning.html

  8. go - GOPATH配置

    查看配置信息 go env 然后找到对应的 GOPATH=>修改为你自己的目录 ..liunx 系统下,注意要给权限 go bulid 编译文件 go run  先编译后执行. -------- ...

  9. 数据结构实验之数组二:稀疏矩阵(SDUT 3348)

    Problem Description 对于一个n*n的稀疏矩阵M(1 <= n <= 1000),采用三元组顺序表存储表示,查找从键盘输入的某个非零数据是否在稀疏矩阵中,如果存在则输出O ...

  10. 你的windows许可证即将过期

    0xC004F025拒绝访问:所请求的操作需要提升特权:解决方法:1.打开我的电脑找到windows System32目录下的cmd                 2.对windows System ...