使用BaseManager在进程之间共享类对象

时间:2019-09-19 18:13:19

标签: python object process shared multiprocess

我正在尝试使用BaseManager在两个进程之间共享一个对象。

我的类对象是从配置json文件读取的,我需要使用它来创建对象并在2个进程之间使用它。

例如,从config json文件读取的类名称为'Event'

from multiprocessing import Process, Manager
from multiprocessing.managers import BaseManager
class Event:
    def __init__(self):
        print('init')
        self.i = None
    def inject(self):
        print(self.i)
        self.i = 100
        print(self.i)
    def restore(self):
        print(self.i)


So, if my class name 'Event' is in evt_class, I am able to register it with BaseManager.
>>> evt_class = Event
>>> BaseManager.register(str(evt_class).split('.')[1], evt_class)
>>> manager = BaseManager()
>>> manager.start()

dir(manager) shows the 'Event' class registered.

>>> dir(manager)
['Event', '_Client', '_Listener', '_Server', '__class__', '__delattr__', '__dict__', '__doc__', '__enter__', '__exit__', '__format__', '__getattribute__', '__hash__', '__init__', '__module__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__setattr__', '__sizeof__', '__str__', '__subclasshook__', '__weakref__', '_address', '_authkey', '_create', '_debug_info', '_finalize_manager', '_number_of_objects', '_process', '_registry', '_run_server', '_serializer', '_state', 'address', 'connect', 'get_server', 'join', 'register', 'shutdown', 'start']
>>> 

But, I am not able to create the 'Event' object using the BaseManager.

>>> c = manager.evt_class()
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
AttributeError: 'BaseManager' object has no attribute 'evt_class'
>>> evt_class
<class __main__.Event at 0x7f0b9f2186d0>
>>> c = manager.str(evt_class).split('.')[1]()
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
AttributeError: 'BaseManager' object has no attribute 'str'

不胜感激。

0 个答案:

没有答案