我正在使用python多处理模块来并行运行一些长时间运行的任务.我正在使用start()方法运行作业,但是一旦作业返回,我想再次运行它们.是否可以重用我创建的流程?还是我每次要运行作业时都必须创建一个新的Process对象?...

我正在使用python多处理模块来并行运行一些长时间运行的任务.我正在使用start()方法运行作业,但是一旦作业返回,我想再次运行它们.
是否可以重用我创建的流程?还是我每次要运行作业时都必须创建一个新的Process对象?
pyhton文档中有这部分建议我不能仅使用onece来使用start()方法,但是也许有人知道重用该实例的另一种方法:
start()
开始流程的活动.
每个过程对象最多只能调用一次.
它将对象的run()方法安排在一个单独的进程中.
这是我的Process类的版本:
class Process(multiprocessing.Process):
def __init__(self, result_queue, MCMCinstance):
assert isinstance(MCMCinstance, MCMC)
multiprocessing.Process.__init__(self)
self.result_queue = result_queue
self.mcmc = MCMCinstance
self.interface = C_interface(self.mcmc)
self.burn_in = False
def run(self):
if self.burn_in: interface.burn_in()
self.interface.sample(self.mcmc.options.runs)
self.interface.update(self.mcmc)
self.result_queue.put(self.mcmc)
然后,我实例化流程并使用start()方法运行它们:
# setup the jobs and run
result_queue = multiprocessing.Queue()
mcmc1 = MCMC(options, donors, clusters)
mcmc2 = MCMC(options, donors, clusters)
mcmc3 = MCMC(options, donors, clusters)
mcmc4 = MCMC(options, donors, clusters)
p1 = Process(result_queue, mcmc1)
p2 = Process(result_queue, mcmc2)
p3 = Process(result_queue, mcmc3)
p4 = Process(result_queue, mcmc4)
jobs = [p1, p2, p3, p4]
for job in jobs:
job.start()
results = [result_queue.get() for job in jobs]
解决方法:
要重用过程,您应该使用池.尽管我尚未进行测试,但类似的事情可能应该起作用.
SENTINEL = "SENTINEL"
class Worker(object):
def __init__(self, result_queue, MCMCinstance):
assert isinstance(MCMCinstance, MCMC)
self.result_queue = result_queue
self.mcmc = MCMCinstance
self.interface = C_interface(self.mcmc)
self.burn_in = False
def run(self):
if self.burn_in: interface.burn_in()
self.interface.sample(self.mcmc.options.runs)
self.interface.update(self.mcmc)
#Signal exit by putting SENTINEL in the queue
if True:
self.result_queue.put(SENTINEL)
else:
self.result_queue.put(self.mcmc)
def run(result_queue):
while True:
instance = result_queue.get(True)
if instance == SENTINEL:
break
worker = Worker(result_queue, instance)
worker.run()
if __name__ == "__main__":
result_queue = multiprocessing.Queue()
pool = multiprocessing.pool.Pool(3, run, (result_queue,)) # Use a pool with 5 process
mcmc1 = MCMC(options, donors, clusters)
mcmc2 = MCMC(options, donors, clusters)
mcmc3 = MCMC(options, donors, clusters)
mcmc4 = MCMC(options, donors, clusters)
result_queue.put(mcmc1)
result_queue.put(mcmc2)
result_queue.put(mcmc3)
result_queue.put(mcmc4)
pool.close()
pool.join()
沃梦达教程
本文标题为:Python Multiprocessing.Process如何重用一个进程?


基础教程推荐
猜你喜欢
- Python pywin32实现word与Excel的处理 2022-09-03
- 创建python虚拟环境(在ubuntu16.04中) 2023-09-04
- Python入门教程之运算符重载详解 2022-10-20
- Pyspark 线性回归梯度下降交叉验证知识点详解 2023-08-05
- centos6,python3,通过pip安装pycurl出现报错提示 2023-09-04
- python数据结构输入输出及控制和异常 2023-08-08
- 在centos6.4下安装python3.5 2023-09-04
- python-增加熊猫数据帧创建时的内存使用率 2023-11-11
- Python多处理比内核启动更多的进程 2023-11-11
- Python3.7 + Yolo3实现识别语音播报功能 2023-08-04