[英]Drop a message Kafka Streams Topology
我想知道是否有办法从 stream 拓扑中删除记录/消息?
我有如下设置:
builder.stream("my-source-topic")
.map(CustomMapper)
.mapValues(CustomValueMapper)
.filterNot(CustomFilter)
.transformValues(CustomValueTransformer)
.toStream()
每个 CustomMapper/CustomFilter 等都覆盖了它们各自的应用/转换方法,它们可能如下所示,如上所述,错误可能无法恢复,这是一个好的解决方案,这些消息将被手动处理并写入相应的日志。 假设在第一个 map 期间发生不可恢复的错误,我现在如何防止后续阶段甚至处理记录,我想停止处理此记录并移至下一个记录。
@Override
public V transform(K readOnlyKey, V value) {
try {
// do some logic
} catch(Exception e){
// process error - this might be unrecoverable.
dropRecord(); // this is what i would be looking for if possible
}
}
我可以杀死线程并让 customUncaughtExceptionHandler 重新安排不会提交偏移量的线程,因此尝试再次处理错误记录。
为传递的对象创建包装器需要在每个处理步骤中添加检查以查看记录是否仍然有效。
在每个处理步骤之前添加 a.branch() 也需要大量的返工。
您只需返回null
即可将消息放入Transformer
中。 请参阅Transformer#transform的 Javadoc。 所以你的例子是:
@Override
public V transform(K readOnlyKey, V value) {
try {
// do some logic
} catch(Exception e){
// process error - this might be unrecoverable.
return null;
}
}
请注意,您目前只能在Transformer
中执行此操作,但不能在ValueTransformer
中执行此操作。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.