[
https://issues.apache.org/jira/browse/KAFKA-2350?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=14637187#comment-14637187
]
Jason Gustafson commented on KAFKA-2350:
----------------------------------------
[~becket_qin] [~jkreps] Currently automatic assignment is inferred based on
which subscribe methods are invoked (e.g. if you subscribe to a topic, then we
assume you want automatic assignment). I wonder if it might help to make that
instead an explicit configuration parameter? Then that might free us a little
bit to use subscribe/unsubscribe in the way [~becket_qin] is proposing since we
don't have to guess whether the user is intending to actually subscribe to a
partition or just to pause it.
> Add KafkaConsumer pause capability
> ----------------------------------
>
> Key: KAFKA-2350
> URL: https://issues.apache.org/jira/browse/KAFKA-2350
> Project: Kafka
> Issue Type: Improvement
> Reporter: Jason Gustafson
> Assignee: Jason Gustafson
>
> There are some use cases in stream processing where it is helpful to be able
> to pause consumption of a topic. For example, when joining two topics, you
> may need to delay processing of one topic while you wait for the consumer of
> the other topic to catch up. The new consumer currently doesn't provide a
> nice way to do this. If you skip poll() or if you unsubscribe, then a
> rebalance will be triggered and your partitions will be reassigned.
> One way to achieve this would be to add two new methods to KafkaConsumer:
> {code}
> void pause(String... topics);
> void unpause(String... topics);
> {code}
> When a topic is paused, a call to KafkaConsumer.poll will not initiate any
> new fetches for that topic. After it is unpaused, fetches will begin again.
--
This message was sent by Atlassian JIRA
(v6.3.4#6332)