190.9. Kafka 헤더 전파
Camel 2.22에서 사용 가능
Kafka의 메시지를 사용할 때 헤더는 camel exchange 헤더로 자동으로 전파됩니다. 동일한 동작으로 지원되는 흐름 생성 - 특정 교환의 camel 헤더는 kafka 메시지 헤더로 전파됩니다.
kafka 헤더는 byte[] 값만 허용하므로 camel exchnage 헤더가 해당 값을 bytes[] 로 전파해야 합니다. 그러지 않으면 헤더를 건너뜁니다. 다음 헤더 값 유형이 지원됩니다. 문자열,Integer,Long,double,부울,byte[]. 참고: kafka 에서 camel exchange 로 전파되는 모든 헤더에는 기본적으로 byte[] 값이 포함됩니다. 기본 기능 uri 매개변수를 재정의하려면 경로에서 kafkaHeaderDeserializer 및 route에 대한 kafkaHeaderSerializer 를 설정할 수 있습니다. 예제:
from("kafka:my_topic?kafkaHeaderDeserializer=#myDeserializer")
...
.to("kafka:my_topic?kafkaHeaderSerializer=#mySerializer")
from("kafka:my_topic?kafkaHeaderDeserializer=#myDeserializer")
...
.to("kafka:my_topic?kafkaHeaderSerializer=#mySerializer")
기본적으로 모든 헤더는 KafkaHeaderFilterStrategy 에 의해 필터링됩니다. 전략에서는 Camel 또는 org.apache.camel 접두사로 시작하는 헤더를 필터링합니다. 기본 전략은 경로에서 headerFilterStrategy uri 매개변수를 사용하여 덮어 쓸 수 있습니다.
from("kafka:my_topic?headerFilterStrategy=#myStrategy")
...
.to("kafka:my_topic?headerFilterStrategy=#myStrategy")
from("kafka:my_topic?headerFilterStrategy=#myStrategy")
...
.to("kafka:my_topic?headerFilterStrategy=#myStrategy")
myStrategy 오브젝트는 HeaderFilterStrategy 의 하위 클래스여야 하며 Camel 레지스트리에 배치해야 하며 Camel 레지스트리에 수동으로 배치하거나 Spring/Blueprint의Bean으로 등록해야 합니다.