응답을 검색하기 위해 LDAP 쿼리와 다른 하위 프로세스를 보낼 하나의 하위 프로세스가 있습니다. 두 프로세스간에 LDAP 개체를 공유하는 데 문제가 있습니다. 누군가 해결책을 가르쳐 줄 수 있습니까?파이썬 다중 처리로 서브 프로세스에 LDAP 객체를 공유 할 수 없습니다.
import ldap
from multiprocessing import Process
def send_ldap(ldap_conn):
print ldap_conn
def receive_ldap(ldap_conn):
print ldap_conn
def main():
ldap_conn = ldap.initialize('ldap://abc:12345')
ldap_sender = Process(target=send_ldap, args=(ldap_conn,))
ldap_receiver = Process(target=receive_ldap, args=(ldap_conn,))
ldap_sender.start()
if __name__ == '__main__':
main()
오류는 피클 모듈입니다 :
Traceback (most recent call last):
File "t.py", line 22, in <module>
main()
File "t.py", line 16, in main
ldap_sender.start()
File "c:\python27\lib\multiprocessing\process.py", line 130, in start
self._popen = Popen(self)
File "c:\python27\lib\multiprocessing\forking.py", line 277, in __init__
dump(process_obj, to_child, HIGHEST_PROTOCOL)
File "c:\python27\lib\multiprocessing\forking.py", line 199, in dump
ForkingPickler(file, protocol).dump(obj)
File "c:\python27\lib\pickle.py", line 224, in dump
self.save(obj)
File "c:\python27\lib\pickle.py", line 331, in save
self.save_reduce(obj=obj, *rv)
File "c:\python27\lib\pickle.py", line 419, in save_reduce
save(state)
File "c:\python27\lib\pickle.py", line 286, in save
f(self, obj) # Call unbound method with explicit self
File "c:\python27\lib\pickle.py", line 649, in save_dict
self._batch_setitems(obj.iteritems())
File "c:\python27\lib\pickle.py", line 681, in _batch_setitems
save(v)
File "c:\python27\lib\pickle.py", line 286, in save
f(self, obj) # Call unbound method with explicit self
File "c:\python27\lib\pickle.py", line 548, in save_tuple
save(element)
File "c:\python27\lib\pickle.py", line 286, in save
f(self, obj) # Call unbound method with explicit self
File "c:\python27\lib\pickle.py", line 725, in save_inst
save(stuff)
File "c:\python27\lib\pickle.py", line 286, in save
f(self, obj) # Call unbound method with explicit self
File "c:\python27\lib\pickle.py", line 649, in save_dict
self._batch_setitems(obj.iteritems())
File "c:\python27\lib\pickle.py", line 681, in _batch_setitems
save(v)
File "c:\python27\lib\pickle.py", line 286, in save
f(self, obj) # Call unbound method with explicit self
File "c:\python27\lib\pickle.py", line 725, in save_inst
save(stuff)
File "c:\python27\lib\pickle.py", line 286, in save
f(self, obj) # Call unbound method with explicit self
File "c:\python27\lib\pickle.py", line 649, in save_dict
self._batch_setitems(obj.iteritems())
File "c:\python27\lib\pickle.py", line 681, in _batch_setitems
save(v)
File "c:\python27\lib\pickle.py", line 331, in save
self.save_reduce(obj=obj, *rv)
Traceback (most recent call last):
File "c:\python27\lib\pickle.py", line 396, in save_reduce
File "<string>", line 1, in <module>
File "c:\python27\lib\multiprocessing\forking.py", line 381, in main
save(cls)
File "c:\python27\lib\pickle.py", line 286, in save
self = load(from_parent)
File "c:\python27\lib\pickle.py", line 1378, in load
f(self, obj) # Call unbound method with explicit self
File "c:\python27\lib\pickle.py", line 748, in save_global
return Unpickler(file).load()
File "c:\python27\lib\pickle.py", line 858, in load
(obj, module, name))
pickle.PicklingError: Can't pickle <type 'thread.lock'>: it's not found as thread.lock
dispatch[key](self)
File "c:\python27\lib\pickle.py", line 880, in load_eof
raise EOFError
EOFError
나는 또한'ReconnectLDAPObject'가 picklable이 아닌 문제에 대해 [버그를 고쳤습니다] (https://sourceforge.net/p/python-ldap/bugs/64/)했습니다. – dano
LDAP 객체가 아닌 사용자 정의 클래스를 제외하고이 문제가 발생합니다. 내 클래스에는 두 스레드의 작동에 필수적인 다중 처리 .lock을 비롯하여 하위 프로세스에서 액세스해야하는 다양한 데이터 객체가 포함되어 있습니다. 저에게 어떤 해결책이 있습니까? 액세스해야하는 개별 객체에 핸들을 전달할 수 있습니까? (나는 왜/pickle이 여기에 사용되는지, LDAP에 익숙하지 않다는 것을 정말로 이해하지 못한다) – kjgregory