SocketAcceptor.unbind can hang when unbinding only one of several service 
adresses
----------------------------------------------------------------------------------

                 Key: DIRMINA-722
                 URL: https://issues.apache.org/jira/browse/DIRMINA-722
             Project: MINA
          Issue Type: Bug
    Affects Versions: 1.0.10
         Environment: Centos 5.3, JDK 1.6.0u11
            Reporter: Rhys Yarranton


If a SocketAcceptor
 - has multiple service addresses bound and
 - you unbind one of them and
 - disconnectOnUnbind is true and
 - the one being unbound has at least one session connected and
 - some other session on the acceptor also has at least one session connected
the unbind call can hang.  Excerpt from stack trace below.

I suspect the hang is coming from IoServiceListenerSupport.disconnectSessions.  
The sessions to be closed are in the sessions variable, which is a subset of 
managedSessions (line 280).  However, at lines 306-309, it is waiting (forever) 
for managedSessions to be empty.  This will never happen.

This is 1..0.10.  The 1.1.7 code is different (it uses a countdown latch), and 
looks OK.


"JBoss Shutdown Hook" daemon prio=10 tid=0x00002aab00d5b800 nid=0x114a in 
Object.wait() [0x00002aab23215000..0x00002aab23217c10]
   java.lang.Thread.State: WAITING (on object monitor)
        at java.lang.Object.wait(Native Method)
        at java.lang.Object.wait(Object.java:485)
        at 
org.apache.mina.transport.socket.nio.SocketAcceptor.unbind(SocketAcceptor.java:213)
        - locked <0x00002aaab0370000> (a 
org.apache.mina.transport.socket.nio.SocketAcceptor$CancellationRequest)
...
"SocketAcceptor-0" daemon prio=10 tid=0x00002aaafcd93000 nid=0x2ca in 
Object.wait() [0x000000004cbc8000..0x000000004cbc8a10]
   java.lang.Thread.State: TIMED_WAITING (on object monitor)
        at java.lang.Object.wait(Native Method)
        at 
org.apache.mina.common.support.IoServiceListenerSupport.disconnectSessions(IoServiceListenerSupport.java:308)
        - locked <0x00002aaab0376670> (a java.lang.Object)
        at 
org.apache.mina.common.support.IoServiceListenerSupport.fireServiceDeactivated(IoServiceListenerSupport.java:165)
        - locked <0x00002aaab5e783c8> (a 
org.apache.mina.common.support.IoServiceListenerSupport)
        at 
org.apache.mina.transport.socket.nio.SocketAcceptor.cancelKeys(SocketAcceptor.java:470)
        at 
org.apache.mina.transport.socket.nio.SocketAcceptor.access$900(SocketAcceptor.java:53)
        at 
org.apache.mina.transport.socket.nio.SocketAcceptor$Worker.run(SocketAcceptor.java:251)
        at 
org.apache.mina.util.NamePreservingRunnable.run(NamePreservingRunnable.java:51)
        at java.lang.Thread.run(Thread.java:619)


-- 
This message is automatically generated by JIRA.
-
You can reply to this email to add a comment to the issue online.

Reply via email to