kafka-jira mailing list archives

Site index · List index
Message view « Date » · « Thread »
Top « Date » · « Thread »
From "Matthias J. Sax (JIRA)" <j...@apache.org>
Subject [jira] [Updated] (KAFKA-5818) Kafka Stream state transitions not correct
Date Thu, 31 Aug 2017 22:25:00 GMT

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

Matthias J. Sax updated KAFKA-5818:
    Affects Version/s:

> Kafka Stream state transitions not correct
> ------------------------------------------
>                 Key: KAFKA-5818
>                 URL: https://issues.apache.org/jira/browse/KAFKA-5818
>             Project: Kafka
>          Issue Type: Bug
>          Components: streams
>    Affects Versions:
>            Reporter: Matthias J. Sax
>            Assignee: Matthias J. Sax
> There is a race condition revealed by failing test {{KafkaStreamsTest#testCannotStartTwise}}.
It fails with:
> {noformat}
> java.lang.Exception: Unexpected exception, expected<java.lang.IllegalStateException>
but was<java.lang.IllegalThreadStateException>
> Caused by: java.lang.IllegalThreadStateException
> 	at java.lang.Thread.start(Thread.java:705)
> 	at org.apache.kafka.streams.KafkaStreams.start(KafkaStreams.java:590)
> 	at org.apache.kafka.streams.KafkaStreamsTest.testCannotStartTwice(KafkaStreamsTest.java:251)
> {noformat}
> The race condition is a follows:
> 1) test calls {{KafkaStreams#start()}} for the first time and state transits from CREATED
> 2) First poll triggers a rebalance and {{StreamThread}} put {{KafkaStreams}} into state
> 3) before REBALANCING completes, the main test thread calls {{KafkaStream#start()}} again.
As current state is REBALANCING, the transition to RUNNING is valid and {{start()}} does not
fail with {{IllegalStateException}} but resumes. When it tries to start internal streams,
we get {{IllegalThreadStateException}} as thread are already running.

This message was sent by Atlassian JIRA

View raw message