Python:给定2个进程A和B,从B调用A中的函数

时间:2013-03-15 18:23:44

标签: python python-2.7 multiprocessing shared-memory python-multiprocessing

基于: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中调用这些函数乙

1 个答案:

答案 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()