多处理目标将依次在父流程中运行

时间:2018-07-16 22:32:40

标签: python websocket python-multiprocessing

我有一个功能orderbook(pair),该功能打开一个websocket,订阅一个频道并收听消息。我希望能够订阅多个频道并并行收听消息。有什么办法吗?

截至目前,我正在尝试以下操作:

from dev.orderbook import *
from multiprocessing import Process

def main():
    process01 = Process(target=orderbook('BTC-USD'))
    process02 = Process(target=orderbook('ETH-USD'))
    process01.start()
    process02.start()

if __name__ == '__main__':
    main()

但是,所有这些操作都是在process01上运行的,只有当我停止脚本时,它才运行process02。这不是我要寻找的行为。有什么办法可以同时订阅这两个频道,并同时收听和打印消息/响应?如果没有,那么有什么办法可以启动一个进程-让它运行指定的时间,然后启动下一个进程?

我的websocket反映了以下内容:

import websocket

class orderbook(object):

def __init__(self, pair):
    self.pair = pair
    websocket.enableTrace(True)
    ws = websocket.WebSocketApp("ws://echo.websocket.org/",
                          on_message = self.on_message,
                          on_error = self.on_error,
                          on_close = self.on_close)
    ws.on_open = self.on_open
    ws.run_forever()

def on_message(self, ws, message):
    print(message)

def on_error(self, ws, error):
    print(error)

def on_close(self, ws):
    print("### closed ###")

def on_open(self, ws):
   ws.send(self.pair)

1 个答案:

答案 0 :(得分:1)

您的Process构造函数包括对目标函数的实际调用。因此,在评估构造函数行的过程中,将在父过程中调用该函数,并将结果作为Process()传递给target

您应该传递函数本身,并分别传递其参数:

process01 = Process(target=orderbook, args=('BTC-USD',))