[英]Run multiple python scripts concurrently with different CMD name
我尝试通过multiprocessing.Process()在test.py中同时调用a.py和b.py,它起作用了。 但是a.py,b.py和test.py的进程CMD名称为'/ usr / bin / python /tmp/test.py'是相同的。
# ps -ef | grep b.py
UID PID PPID C STIME TTY TIME CMD
501 61486 39878 0 2:33PM ?? 0:00.05 /usr/bin/python /tmp/test.py
501 61487 61486 0 2:33PM ?? 0:00.01 /usr/bin/python /tmp/test.py
501 61488 61486 0 2:33PM ?? 0:00.01 /usr/bin/python /tmp/test.py
我希望这三个进程通过“ ps -ef”显示不同的CMD名称,如下所示:(这可以帮助我识别是否正在运行其他进程。)
# ps -ef | grep b.py
UID PID PPID C STIME TTY TIME CMD
501 61486 39878 0 2:33PM ?? 0:00.05 /usr/bin/python /tmp/test.py
501 61487 61486 0 2:33PM ?? 0:00.01 /usr/bin/python /tmp/a.py
501 61488 61486 0 2:33PM ?? 0:00.01 /usr/bin/python /tmp/b.py
请帮忙咨询:)
源代码如下:
test.py:
import multiprocessing
import a
import b
p1 = multiprocessing.Process(target=a.printa)
p2 = multiprocessing.Process(target=b.printb)
p1.start()
p2.start()
a.py:
import time
def printa():
while True:
print 'a'
time.sleep(1)
if __name__ == '__main__':
printa()
b.py:
import time
def printb():
while True:
print 'b'
time.sleep(1)
if __name__ == '__main__':
printb()
您正在使用a.py
和b.py
作为python中的库,因此以与执行文件test.py
相同的名称进行调用。 使用multiprocessing
或joblib
发生相同的情况。
Process
方法中有一个名称选项( multiprocessing.Process(self, group=None, target=None, name=None, args=(), kwargs={})
),但是正如@fedterzi所说,它仅用于识别目的。
如果要调用进程或文件,则可以使用库子进程。
根据您正在执行的任务,例如将一堆进程并行化,您还可以通过bash
使用gnu parallel或其他方法来完成所需的行为。
阅读Python»2.7.13文档, 使用-subprocess模块
从subprocess
选择一种NOWAIT方法,相应地编辑您的问题代码。
import subprocess
def openCmd(name):
return subprocess.?
if __name__ == '__main__':
while True:
key = raw_input('input 1=open, 0=terminate, q=quit:')
print(key)
if key == '1':
A_p = openCmd(('a'))
B_p = openCmd(('b'))
if key == '0':
A_p.terminate()
B_p.terminate()
if key == 'q':
break
使用Python测试:2.7.9
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.