Welcome to OGeek Q&A Community for programmer and developer-Open, Learning and Share
Welcome To Ask or Share your Answers For Others

Categories

0 votes
847 views
in Technique[技术] by (71.8m points)

process - How to kill Python Multiprocessing.Pool by pid?

import multiprocessing
import os
import time


def work():
    pid, ppid = os.getpid(), os.getppid()
    print('pid={}, ppid={}'.format(pid, ppid))
    time.sleep(10)


def run_process(n):
    pool = multiprocessing.Pool(10)

    res_l = []
    for _ in range(n):
        res = pool.apply_async(work)
        res_l.append(res)

    pool.close()
    pool.join()

run_process(2)

pid_0=63780, ppid=63779 pid_1=63781, ppid=63779

I have to kill pid and ppid to kill the current process.Is there a better way?Or I just want to one of the subprocesses. What should I do?

def kill_proc(pid, ppid):
    os.kill(pid, signal.SIGTERM)
    os.kill(ppid, signal.SIGTERM)

与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
Welcome To Ask or Share your Answers For Others

1 Reply

0 votes
by (71.8m points)
等待大神答复

与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
OGeek|极客中国-欢迎来到极客的世界,一个免费开放的程序员编程交流平台!开放,进步,分享!让技术改变生活,让极客改变未来! Welcome to OGeek Q&A Community for programmer and developer-Open, Learning and Share
Click Here to Ask a Question

1.4m articles

1.4m replys

5 comments

57.0k users

...