永发信息网

python 进程池当一个进程报错时,别的进程有影响吗

答案:2  悬赏:40  手机版
解决时间 2021-03-12 08:38
python 进程池当一个进程报错时,别的进程有影响吗
最佳答案
Python提供了非常好用的多进程包multiprocessing,你只需要定义一个函数,Python会替你完成其他所有事情。
借助这个包,可以轻松完成从单进程到并发执行的转换。

1、新建单一进程
如果我们新建少量进程,可以如下:
import multiprocessing
import time

def func(msg):
for i in xrange(3):
print msg
time.sleep(1)

if __name__ == "__main__":
p = multiprocessing.Process(target=func, args=("hello", ))
p.start()
p.join()
print "Sub-process done."12345678910111213

2、使用进程池
是的,你没有看错,不是线程池。它可以让你跑满多核CPU,而且使用方法非常简单。
注意要用apply_async,如果落下async,就变成阻塞版本了。
processes=4是最多并发进程数量。
import multiprocessing
import time

def func(msg):
for i in xrange(3):
print msg
time.sleep(1)

if __name__ == "__main__":
pool = multiprocessing.Pool(processes=4)
for i in xrange(10):
msg = "hello %d" %(i)
pool.apply_async(func, (msg, ))
pool.close()
pool.join()
print "Sub-process(es) done."12345678910111213141516

3、使用Pool,并需要关注结果
更多的时候,我们不仅需要多进程执行,还需要关注每个进程的执行结果,如下:
import multiprocessing
import time

def func(msg):
for i in xrange(3):
print msg
time.sleep(1)
return "done " + msg

if __name__ == "__main__":
pool = multiprocessing.Pool(processes=4)
result = []
for i in xrange(10):
msg = "hello %d" %(i)
result.append(pool.apply_async(func, (msg, )))
pool.close()
pool.join()
for res in result:
print res.get()
print "Sub-process(es) done."1234567891011121314151617181920

2014.12.25更新
根据网友评论中的反馈,在Windows下运行有可能崩溃(开启了一大堆新窗口、进程),可以通过如下调用来解决:
multiprocessing.freeze_support()1

附录(自己的脚本):
#!/usr/bin/python
import threading
import subprocess
import datetime
import multiprocessing

def dd_test(round, th):
test_file_arg = 'of=/zbkc/test_mds_crash/1m_%s_%s_{}' %(round, th)
command = "seq 100 | xargs -i dd if=/dev/zero %s bs=1M count=1" %test_file_arg
print command
subprocess.call(command,shell=True,stdout=open('/dev/null','w'),stderr=subprocess.STDOUT)

def mds_stat(round):
p = subprocess.Popen("zbkc mds stat", shell = True, stdout = subprocess.PIPE)
out = p.stdout.readlines()
if out[0].find('active') != -1:
command = "echo '0205pm %s round mds status OK, %s' >> /round_record" %(round, datetime.datetime.now())
command_2 = "time (ls /zbkc/test_mds_crash/) 2>>/round_record"
command_3 = "ls /zbkc/test_mds_crash | wc -l >> /round_record"
subprocess.call(command,shell=True)
subprocess.call(command_2,shell=True)
subprocess.call(command_3,shell=True)
return 1
else:
command = "echo '0205 %s round mds status abnormal, %s, %s' >> /round_record" %(round, out[0], datetime.datetime.now())
subprocess.call(command,shell=True)
return 0

#threads = []
for round in range(1, 1600):
pool = multiprocessing.Pool(processes = 10) #使用进程池
for th in range(10):
# th_name = "thread-" + str(th)
# threads.append(th_name) #添加线程到线程列表
# threading.Thread(target = dd_test, args = (round, th), name = th_name).start() #创建多线程任务
pool.apply_async(dd_test, (round, th))
pool.close()
pool.join()
#等待线程完成
# for t in threads:
# t.join()

if mds_stat(round) == 0:
subprocess.call("zbkc -s",shell=True)
break
全部回答
当进程池中任务队列非空时,才会触发worker进程去工作,那么如何向进程池中的任务队列中添加任务呢,进程池类有两组关键方法来创建任务,分别是apply/apply_async和map/map_async 实际上进程池类的apply和map方法与python内建的两个同名方法类似,apply_async和map_async分别为它们的非阻塞版本。
我要举报
如以上问答信息为低俗、色情、不良、暴力、侵权、涉及违法等信息,可以点下面链接进行举报!
大家都在看
拉骨夹和小龙虾的区别?
合兴地产茶山分店地址在什么地方,想过去办事
【森林医生】被称为森林医生的是()。
如何快速消除紧张感
注音全都正确的一组为A.纤(xiān)维 间(ji
中国政法大学研究生的复试分数线是自主划?
榆次东鑫驾校怎么样、报名多一个月了、一点反
演员杨洋的同人小说最好是完结的!谢谢☺
迎吉惠民快餐地址在什么地方,想过去办事
1950土地革命农民的生活
一看时间总看到四十七或十四这些数字啥意思
怎么用很经典的话劝一个女生别犹豫,喜欢一个
原始生命起源的大致历程是AA. 原始大气的主要
瓮安旺旺春梅饭店地址有知道的么?有点事想过
什么是船舶稳性计算书?
推荐资讯
洛阳吉祥驾校科目二考试分车不公平,考试车比
雅康模拟射击地址有知道的么?有点事想过去
我的魅族mx4为什么电量显示不准确,且充电速
今夫下午木渎影视城放什么电影
第一心音的起源
哪些情况下公司辞退员工可以不做经济补偿的?
新疆自治区绩效办主任是什么级别?主要负责什
饭店对外投资的目的包括()A.取得投资报酬B.分
奇骏可以加涡轮增压么
怎么样才能避免在学校突然来初潮的尴尬
— Look at that photo! What a happy family
如果你还爱我 请联系我 无论什么时候 我一直
正方形一边上任一点到这个正方形两条对角线的
阴历怎么看 ?