FLUME KAFKA SOURCE 和 SINK 使用同一个 TOPIC
FLUME KAFKA SOURCE 和 SINK 使用同一个 TOPIC
最近做了一个事情,过滤下kakfa中的数据后,做这个就用到了flume,直接使用flume source 和 flume sink,中间再加一个过滤的intercetpor就可以了。
要做的事情很简单,但是遇到了一个问题,就是sink中指定的topic不起作用。
过程是这样的:
KafkaSource.doProcess方法会给event的header中添加一个topic信息,里面保存了消费的topic。
if (!headers.containsKey(KafkaSourceConstants.TOPIC_HEADER)) {
headers.put(KafkaSourceConstants.TOPIC_HEADER, message.topic());
}
KafkaSink.process方法中会首先将event的header中的topic信息作为sinkTopic,如果header中没有topic信息,才会用sink定义的topic。
eventTopic = headers.get(TOPIC_HEADER);
if (eventTopic == null) {
eventTopic = topic;
}
这就尴尬了,自定义的sinkTopic没用,解决办法:
- 在
KafkaSink.process中去掉这几行代码,重新打包。 - 使用
intercetpor
具体参考这个。
posted on 2017-02-26 20:51 walkwalkwalk 阅读(1426) 评论(0) 收藏 举报
浙公网安备 33010602011771号