控制运行Python进程(多处理)

时间:2015-08-05 11:03:18

标签: python python-multiprocessing

我还有一个关于Python多处理的问题。 我有一个创建进程的模块,只需运行一段时间的True循环。 该模块旨在从另一个Python模块启用/禁用。 该另一个模块将导入第一个模块,并且也作为一个过程运行。

我怎样才能更好地实现这个目标?

所以参考:

#foo.py

def foo():
  while True:
    if enabled:
      #do something

p = Process(target=foo)
p.start()

并想象第二个模块是这样的:

#bar.py
import foo, time

def bar():
  while True:
    foo.enable()
    time.sleep(10)
    foo.disable()

Process(target=bar).start()

持续运行进程检查循环内的条件似乎是浪费,但我很乐意接受只允许我从外部设置enabled值的解决方案。 理想情况下,我希望能够再次从此模块的外部终止并重新启动该过程。 根据我的理解,我将使用Queue将命令传递给Process。如果确实如此,有人可以告诉我如何设置它,以便我可以从不同的模块向队列中添加内容。

这是否可以通过Python轻松完成,或者是时候放弃希望并切换到像C或Java这样的东西

1 个答案:

答案 0 :(得分:1)

我的目的是评论两种不同的方法:

  • 使用multiprocessing.Value
  • 中的共享变量
  • 使用信号暂停/恢复过程

通过共享变量

进行控制
def target_process_1(run_statement):
    while True:
        if run_statement.value:
            print "I'm running !"
            time.sleep(1)

def target_process_2(run_statement):
    time.sleep(3)
    print "Stoping"
    run_statement.value = False
    time.sleep(3)
    print "Resuming"
    run_statement.value = True

if __name__ == "__main__":
    run_statement = Value("i", 1)

    process_1 = Process(target=target_process_1, args=(run_statement,))
    process_2 = Process(target=target_process_2, args=(run_statement,))

    process_1.start()
    process_2.start()

    time.sleep(8)
    process_1.terminate()
    process_2.terminate()

通过发送信号进行控制

from multiprocessing import Process
import time
import os, signal

def target_process_1():
    while True:
        print "Running !"
        time.sleep(1)

def target_process_2(target_pid):
    time.sleep(3)
    os.kill(target_pid, signal.SIGSTOP)
    time.sleep(3)
    os.kill(target_pid, signal.SIGCONT)

if __name__ == "__main__":
    process_1 = Process(target=target_process_1)
    process_1.start()

    process_2 = Process(target=target_process_2, args=(process_1.pid,))
    process_2.start()

    time.sleep(8)

    process_1.terminate()
    process_2.terminate()

旁注:如果可能,请不要运行while True

编辑:如果您想在两个不同的文件中管理您的流程,假设您想通过共享变量来使用控件,这是一种方法。

# file foo.py

from multiprocessing import Value, Process
import time

__all__ = ['start', 'stop', 'pause', 'resume']

_statement = None
_process = None

def _target(run_statement):
    """ Target of the foo's process """
    while True:
        if run_statement.value:
            print "I'm running !"
            time.sleep(1)

def start():
    global _process, _statement
    _statement = Value("i", 1)
    _process = Process(target=_target,  args=(_statement,))
    _process.start()

def stop():
    global _process, _statement
    _process.terminate()
    _statement, _process = None, _process

def enable():
    _statement.value = True

def disable():
    _statement.value = False