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

Nicholas Telford resolved KAFKA-17487.
--------------------------------------
    Resolution: Duplicate

I mistakenly created this issue before pulling trunk, which has already been 
fixed!

> Race in GlobalStreamThread initialization
> -----------------------------------------
>
>                 Key: KAFKA-17487
>                 URL: https://issues.apache.org/jira/browse/KAFKA-17487
>             Project: Kafka
>          Issue Type: Bug
>          Components: streams
>    Affects Versions: 4.0.0
>            Reporter: Nicholas Telford
>            Assignee: Nicholas Telford
>            Priority: Minor
>
> When initializing the {{{}GlobalStreamThread{}}}, we {{countDown}} the 
> {{initializationLatch}} _before_ setting the state to {{{}RUNNING{}}}.
> This can cause other threads waiting on that latch, most notably through 
> {{{}GlobalStreamThread#start{}}}, to unblock before the thread state 
> transitions to {{{}RUNNING{}}}.
> This mostly affects {{{}GlobalStreamThreadTest{}}}, in particular:
>  * {{{}shouldBeRunningAfterSuccessfulStart{}}}, which waits on 
> {{GlobalStreamThread#start}} and then immediately asserts that the state is 
> {{{}RUNNING{}}}, which due to this race, it sometimes isn't (yet).
>  * {{{}shouldStopRunningWhenClosedByUser{}}}, which waits on 
> {{GlobalStreamThread#start}} and then immediately calls 
> {{{}GlobalStreamThread#shutdown{}}}, which changes the state to 
> {{{}PENDING_SHUTDOWN{}}}. The {{GlobalStreamThread}} then attempts to 
> transition the state to {{{}RUNNING{}}}, which fails because it's not a valid 
> transition from {{{}PENDING_SHUTDOWN{}}}.
> The fix is simple: move the {{setState(RUNNING)}} into {{{}#initialize{}}}, 
> immediately before returning. This ensures that the state is set _before_ 
> counting down the initialization latch.



--
This message was sent by Atlassian Jira
(v8.20.10#820010)

Reply via email to