Kafka - 신뢰성 있는 카프카 애플리케이션을 만드는 3가지 방법(멱등성 프로듀서, 트랜잭션 컨슈머, 컨슈머 중복 적재)
2024. 6. 18. 16:53ㆍMiddleware/Kafka&RabbitMQ
1. 멱등성 프로듀서
1.1. 중복 데이터 produce 문제 상황
만약 네트워크에 이슈가 생겨서, Acknowledge 전송이 실패되면 중복으로 데이터를 produce할 수 있다.
1.2. 멱등성 프로듀서 사용
PID(Producer unique ID)를 같이 보내서 브로커에 메시지가 저장되어있음을 같이 저장해서 중복 메시지가 발행되면 토픽에 개시하지 않음.
아래는 실제 3.0 이상의 카프카 프로듀서 팩토리 코드인데, 디폴트로 true로 설정된 코드.
2. 트랜잭션 컨슈머 + 프로듀서
컨슈머와 프로듀서를 하나의 트랜잭션으로 묶어서 처리하는 방식임. 특이하게 커밋을 Producer가 한다.
트랜잭션 컨슈머 + 프로듀서 구성으로 되어있고 그 프로듀서가 발행한 이벤트를 consume하는 컨슈머는 반드시isolation.level을 read_committed로 설정해주어야한다.(트랜잭션 commit이 성공한 레코드만 컨슘하는 메커니즘)
3. 컨슈머의 중복 적재 방지
유니크 키 값을 record key나 혹은 메시지가 발행된 타임스탬프 등으로 설정하면 실제로 중복 오퍼레이션 수행은 하지만, 저장은 못한다.
4. 3가지 방법을 정리한 구성 그림
참고: https://tech.kakao.com/posts/602
'Middleware > Kafka&RabbitMQ' 카테고리의 다른 글
Kafka - Spring kafka Producer, Consumer 예제 코드 및 오프셋 커밋, 에러 핸들링 설명 (1) | 2023.11.18 |
---|---|
spring kafka commit 실패시 next poll때 일어나는일 (0) | 2023.11.07 |
[Kafka] Parallel Consumers, 메시지별 병렬 처리 (0) | 2023.10.30 |
Spring cloud stream kafka - concurrency (1) | 2022.07.27 |
RabbitMQ - 레빗엠큐 개념 및 동작방식, 실습 (0) | 2020.07.26 |