[ 
https://issues.apache.org/jira/browse/BOOKKEEPER-59?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=13097949#comment-13097949
 ] 

Flavio Junqueira commented on BOOKKEEPER-59:
--------------------------------------------

One question: why can't we simply remove the else block in 
BookieClient.lookup()? If we do it, then we should have 
PerChannelBookieClient.connect() always called under a lock, through 
PerChannelBookieClient.connectIfNeededAndDoOp(), which is invoked by addEntry() 
and readEntry().

> Race condition in netty code allocates and orphans resources (BK-5 revisited)
> -----------------------------------------------------------------------------
>
>                 Key: BOOKKEEPER-59
>                 URL: https://issues.apache.org/jira/browse/BOOKKEEPER-59
>             Project: Bookkeeper
>          Issue Type: Bug
>            Reporter: Ivan Kelly
>            Assignee: Ivan Kelly
>             Fix For: 3.4.0
>
>         Attachments: BOOKKEEPER-59.diff
>
>
> We thought BK-5 fixed this, but it still hits if you run for long enough.
> To repro,
> true; while [ $? = 0 ]; do mvn test -Dtest=BookieReadWriteTest; done
> Leave this running for 5-6 hours, and the bug should hit. From looking at the 
> code it could be that connect is unsynchronized, so resources could be 
> allocated and lost by concurrent executions of connect(). 

--
This message is automatically generated by JIRA.
For more information on JIRA, see: http://www.atlassian.com/software/jira

        

Reply via email to