[ 
https://issues.apache.org/jira/browse/DIRSHARED-135?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel
 ]

Emmanuel Lecharny resolved DIRSHARED-135.
-----------------------------------------

    Resolution: Won't Fix

This is  a complex issue. 

sharing a connection between many threads is certainly not a good idea : the 
incoming messages may arrive fragmented, and this may be impossible to build 
the correct responses in this case, leading to a situation where we will have 
long timeout (60s).

OTOH, making the connection threadsafe would forbid someone to stop a long 
operation with the AbandonRequest request. 

ATM, I would rather tell you to create as many connection as you have threads.
                
> LdapNetworkConnection should be thread-safe
> -------------------------------------------
>
>                 Key: DIRSHARED-135
>                 URL: https://issues.apache.org/jira/browse/DIRSHARED-135
>             Project: Directory Shared
>          Issue Type: Bug
>          Components: 0.9.18
>    Affects Versions: 1.0.0-M12
>         Environment: java version "1.6.0_31"
> Java(TM) SE Runtime Environment (build 1.6.0_31-b04)
> Java HotSpot(TM) 64-Bit Server VM (build 20.6-b01, mixed mode)
> Linux annafi.dev 3.0.0-21-generic #35-Ubuntu SMP Fri May 25 17:57:41 UTC 2012 
> x86_64 x86_64 x86_64 GNU/Linux
>            Reporter: Hendy Irawan
>             Fix For: 1.0.0-M13
>
>
> I'm working on an open source project ( https://github.com/soluvas/ldap-tools 
> ) which uses LdapNetworkConnection using shared v1.0.0-M12. Several threads 
> are running in parallel (using Akka), all using the same 
> LdapNetworkConnection to delete entries.
> However in some cases it locks up (deadlock? race condition?) and the last 
> logs I get is :
> ...
> 22:17:17 [NioProcessor-2] DEBUG o.a.m.f.codec.ProtocolCodecFilter - 
> Processing a MESSAGE_RECEIVED for session 1
> 22:17:17 [ldap_cli-akka.actor.default-dispatcher-14] INFO  
> o.soluvas.ldaptools.cli.PersonClear - Deleting 
> uid=setsuna_hinagiku,ou=users,dc=berbatik,dc=com
> 22:17:17 [ldap_cli-akka.actor.default-dispatcher-24] INFO  
> o.soluvas.ldaptools.cli.PersonClear - Deleting 
> uid=rumah_amal_salman_itb,ou=users,dc=berbatik,dc=com
> 22:17:17 [NioProcessor-2] DEBUG o.a.m.f.codec.ProtocolCodecFilter - 
> Processing a MESSAGE_RECEIVED for session 1
> 22:17:17 [ldap_cli-akka.actor.default-dispatcher-18] INFO  
> o.soluvas.ldaptools.cli.PersonClear - Deleting 
> uid=setyo_rini,ou=users,dc=berbatik,dc=com
> 22:17:17 [NioProcessor-2] DEBUG o.a.m.f.codec.ProtocolCodecFilter - 
> Processing a MESSAGE_RECEIVED for session 1
> 22:17:17 [ldap_cli-akka.actor.default-dispatcher-1] INFO  
> o.soluvas.ldaptools.cli.PersonClear - Deleting 
> uid=pipit_nugroho,ou=users,dc=berbatik,dc=com
> 22:17:17 [ldap_cli-akka.actor.default-dispatcher-15] INFO  
> o.soluvas.ldaptools.cli.PersonClear - Deleting 
> uid=yuliana_riris_basaria,ou=users,dc=berbatik,dc=com
> 22:17:17 [NioProcessor-2] DEBUG o.a.m.f.codec.ProtocolCodecFilter - 
> Processing a MESSAGE_RECEIVED for session 1
> 22:17:17 [ldap_cli-akka.actor.default-dispatcher-16] INFO  
> o.soluvas.ldaptools.cli.PersonClear - Deleting 
> uid=setia_budi,ou=users,dc=berbatik,dc=com
> 22:17:17 [NioProcessor-2] DEBUG o.a.m.f.codec.ProtocolCodecFilter - 
> Processing a MESSAGE_RECEIVED for session 1
> 22:17:17 [NioProcessor-2] DEBUG o.a.m.f.codec.ProtocolCodecFilter - 
> Processing a MESSAGE_RECEIVED for session 1
> 22:17:17 [NioProcessor-2] DEBUG o.a.m.f.codec.ProtocolCodecFilter - 
> Processing a MESSAGE_RECEIVED for session 1
> 22:17:17 [NioProcessor-2] DEBUG o.a.m.f.codec.ProtocolCodecFilter - 
> Processing a MESSAGE_RECEIVED for session 1
> 22:17:17 [NioProcessor-2] DEBUG o.a.m.f.codec.ProtocolCodecFilter - 
> Processing a MESSAGE_RECEIVED for session 1
> 22:17:17 [NioProcessor-2] DEBUG o.a.m.f.codec.ProtocolCodecFilter - 
> Processing a MESSAGE_RECEIVED for session 1
> 22:17:17 [NioProcessor-2] DEBUG o.a.m.f.codec.ProtocolCodecFilter - 
> Processing a MESSAGE_RECEIVED for session 1
> 22:17:17 [NioProcessor-2] DEBUG o.a.m.f.codec.ProtocolCodecFilter - 
> Processing a MESSAGE_RECEIVED for session 1
> 22:17:17 [NioProcessor-2] DEBUG o.a.m.f.codec.ProtocolCodecFilter - 
> Processing a MESSAGE_RECEIVED for session 1
> 22:17:17 [NioProcessor-2] DEBUG o.a.m.f.codec.ProtocolCodecFilter - 
> Processing a MESSAGE_RECEIVED for session 1
> I also experience similar issues doing concurrent add()s.
> LdapNetworkConnection should be thread-safe.
> Workaround: use separate LdapConnection for each thread, or probably 
> sufficient to use synchronized blocks.

--
This message is automatically generated by JIRA.
If you think it was sent incorrectly, please contact your JIRA administrators
For more information on JIRA, see: http://www.atlassian.com/software/jira

Reply via email to