基于:http://docs.python.org/2/library/multiprocessing.html#managers我正在重写其中一个示例,分为2个进程,一个客户端和一个服务器。它是以下代码:
from multiprocessing.managers import BaseManager
import multiprocessing
class ManagerServer(multiprocessing.Process):
def __init__(self):
multiprocessing.Process.__init__(self)
class MathsClass(object):
def add(self, x, y):
return x + y
def mul(self, x, y):
return x * y
class MyManager(BaseManager):
pass
MyManager.register('Maths', MathsClass)
m = MyManager(address=('', 50000), authkey='abracadabra')
self.s = m.get_server()
def run(self):
self.s.serve_forever()
class ManagerClient(multiprocessing.Process):
def __init__(self):
multiprocessing.Process.__init__(self)
class MyManager(BaseManager):
pass
MyManager.register('Maths')
self.m = MyManager(address=('', 50000), authkey='abracadabra')
def run(self):
self.m.connect()
maths = self.m.Maths()
print maths.add(4, 3)
print maths.mul(7, 8)
if __name__ == "__main__":
ms = ManagerServer()
mc = ManagerClient()
ms.start()
mc.start()
此代码有效,从客户端我可以从服务器调用MathsClass类中的函数。
我遇到的问题是我仅限于在MathsClass中直接定义的函数,这些函数不处理来自其他任何地方的数据。
例如,如果在ManagerServer中我定义了一个名为“addOuter(self,x,y)”的函数,然后在类MathsClass中,在其函数add中调用addOuter(),它就看不到它,它就说出来了不存在。
所以,我的问题是,给定两个进程A和B,其中A具有与 init 相同级别定义的函数,而不是在另一个类中,我如何在A中调用这些函数乙
答案 0 :(得分:2)
首先,您应该将self
中的MathsClass
变量重命名为其他内容以避免冲突。要在示例中访问ManagerServer
中的函数,您必须静态调用它,并将ManagerServer
的实例作为第一个参数传递给它。我们已经定义为self
的好东西。这应该可以解决问题:
from multiprocessing.managers import BaseManager
import multiprocessing
class ManagerServer(multiprocessing.Process):
def __init__(self):
multiprocessing.Process.__init__(self)
class MathsClass(object):
def add(innerSelf, x, y):
return ManagerServer.addOuter(self, x, y)
def mul(innerSelf, x, y):
return x * y
class MyManager(BaseManager):
pass
def addOuter(self, x, y):
return x + y
MyManager.register('Maths', MathsClass)
m = MyManager(address=('', 50000), authkey='abracadabra')
self.s = m.get_server()
def run(self):
self.s.serve_forever()
class ManagerClient(multiprocessing.Process):
def __init__(self):
multiprocessing.Process.__init__(self)
class MyManager(BaseManager):
pass
MyManager.register('Maths')
self.m = MyManager(address=('', 50000), authkey='abracadabra')
def run(self):
self.m.connect()
maths = self.m.Maths()
print maths.add(4, 3)
print maths.mul(7, 8)
if __name__ == "__main__":
ms = ManagerServer()
mc = ManagerClient()
ms.start()
mc.start()