V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
推荐学习书目
Learn Python the Hard Way
Python Sites
PyPI - Python Package Index
http://diveintopython.org/toc/index.html
Pocoo
值得关注的项目
PyPy
Celery
Jinja2
Read the Docs
gevent
pyenv
virtualenv
Stackless Python
Beautiful Soup
结巴中文分词
Green Unicorn
Sentry
Shovel
Pyflakes
pytest
Python 编程
pep8 Checker
Styles
PEP 8
Google Python Style Guide
Code Style from The Hitchhiker's Guide
tqknight
V2EX  ›  Python

apply_async 多进程异步调用,子任务不执行,居然没找到原因

  •  
  •   tqknight · 2019-01-06 12:59:35 +08:00 · 7980 次点击
    这是一个创建于 2149 天前的主题,其中的信息可能已经有所发展或是发生改变。
    问题:为啥多传一个 queue 参数,子任务函数 perform_task(), 没有执行?

    代码如下:

    from multiprocessing import Pool, Queue
    from time import time, sleep
    import random


    def perform_task(id, queue):
    print(" [{}号] 子进程 [开始] 执行任务".format(id))
    begin = time()
    sleep(random.random() * 5)
    print(" [{}号] 子进程 [结束] 执行任务".format(id))
    end = time()
    cost = end - begin
    res = " [{}号] 子进程执行任务耗时:{}".format(id, cost)
    queue.put(res)
    print(res)



    if __name__ == "__main__":
    # 进程结果集
    queue = Queue()

    # 进程池中进程最大数量
    pool_count = 5

    # 创建进程池
    pool = Pool(pool_count)
    print("进程池准备就绪, 多进程开始执行任务,等待结束...")

    #
    for i in range(pool_count):
    pool.apply_async(perform_task, args=(i, queue) )
    # 关闭进程池,使其不再接受新的任务
    pool.close()
    # 主进程阻塞机制
    pool.join()
    print("所有进程池中的任务完成")


    正常结果应该是:

    进程池准备就绪, 多进程开始执行任务,等待结束...
    [ 0 号] 子进程 [开始] 执行任务
    [ 1 号] 子进程 [开始] 执行任务
    [ 2 号] 子进程 [开始] 执行任务
    [ 3 号] 子进程 [开始] 执行任务
    [ 4 号] 子进程 [开始] 执行任务
    [ 3 号] 子进程 [结束] 执行任务
    [ 3 号] 子进程执行任务耗时:0.24634218215942383
    [ 4 号] 子进程 [结束] 执行任务
    [ 4 号] 子进程执行任务耗时:0.41087770462036133
    [ 2 号] 子进程 [结束] 执行任务
    [ 2 号] 子进程执行任务耗时:0.8377587795257568
    [ 1 号] 子进程 [结束] 执行任务
    [ 1 号] 子进程执行任务耗时:2.044529914855957
    [ 0 号] 子进程 [结束] 执行任务
    [ 0 号] 子进程执行任务耗时:2.7406675815582275
    所有进程池中的任务完成
    5 条回复    2019-01-06 16:31:08 +08:00
    tqknight
        1
    tqknight  
    OP
       2019-01-06 13:00:15 +08:00
    求大佬指点
    fanhaipeng0403
        2
    fanhaipeng0403  
       2019-01-06 15:40:10 +08:00
    Note that with asynchronous programming you don't need to manually deal with result queues - apply_async returns a AsyncResult instance which can be used to get the result: result.get(). This uses an underlying result (out-) queue and so you simply need to return in your target function. Also if you use result.get() and you passed a Queue instance as an argument to the target function it will raise a RuntimeError
    bihuchao
        4
    bihuchao  
       2019-01-06 16:23:54 +08:00
    multiprocessing 中的 Queue 不能被序列化。
    目的应该是这样吧
    ``` Python
    #! /usr/bin/python3

    import time
    import random
    import multiprocessing

    queue = multiprocessing.Queue()

    def perform_task(id):
    print("{0}# process start".format(id))
    begin = time.time()
    time.sleep(random.random()*5)
    print("{0}# process end".format(id))

    res = "{0}# process time : {1}".format(id, time.time()-begin)
    print(res)

    queue.put(res)

    return

    if __name__ == "__main__":
    poolCount = 5
    pool = multiprocessing.Pool(poolCount)

    for i in range(poolCount):
    pool.apply_async(perform_task, args=(i, ))

    pool.close()
    pool.join()

    print("End tasking, print results:")

    while True:
    res = queue.get()
    print(res)
    if queue.empty():
    break

    ```
    执行结果:
    ```
    0# process start
    1# process start
    2# process start
    3# process start
    4# process start
    0# process end
    0# process time : 0.5990872383117676
    1# process end
    1# process time : 2.662280559539795
    3# process end
    3# process time : 3.903242826461792
    2# process end
    2# process time : 4.440236330032349
    4# process end
    4# process time : 4.543649435043335
    End tasking, print results:
    0# process time : 0.5990872383117676
    1# process time : 2.662280559539795
    3# process time : 3.903242826461792
    2# process time : 4.440236330032349
    4# process time : 4.543649435043335
    ```
    zn
        5
    zn  
       2019-01-06 16:31:08 +08:00 via iPhone
    为啥我看到函数名就直觉是蟒蛇呢?我基本没怎么学过蟒蛇,同时百分百确定没用过这个函数。
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   1032 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 21ms · UTC 18:51 · PVG 02:51 · LAX 10:51 · JFK 13:51
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.