不管producer还是consumer,都要调用该方法。
核心代码其实就如下部分.一个while循环(没错,核心就是一个while循环)
while (likely(!rd_kafka_terminating(rk) ||
rd_kafka_q_len(rk->rk_ops))) {
rd_ts_t sleeptime = rd_kafka_timers_next(
&rk->rk_timers, 1000*1000/*1s*/, 1/*lock*/);
rd_kafka_q_serve(rk->rk_ops, (int)(sleeptime / 1000), 0,
RD_KAFKA_Q_CB_CALLBACK, NULL, NULL);
if (rk->rk_cgrp) /* FIXME: move to timer-triggered */
rd_kafka_cgrp_serve(rk->rk_cgrp);
rd_kafka_timers_run(&rk->rk_timers, RD_POLL_NOWAIT);
}
包含两部分工作
1 运行rd_kafka_q_serve. 主要完成op队列的消费和callback触发。
2 如果是消费者,运行 rd_kafka_cgrp_serve.主要完成消费者的相关工作。
包括状态维护和消息拉取:比如JoinGroup, SyncGroup, Fetch, CommitOffset等。