티스토리 뷰
1. 이전 포스트에서 Consumer 사용방법을 언급할 때 이미 Consumer Group를 이야기 했다.
1-1 그 포스트에서 3개의 파티션을 가진 first_topic에 first_group이라는 그룹이름으로 3개의 컨슈머를 생성했다.
1-2 그런 후 하나를 죽여 2개의 컨슈머만 남겨 두었다.
2. 컨슈머 그룹의 관리하기 위해서는 kafka-consumer-groups라는 명령어를 사용한다.
2-1 아래는 한 줄의 내용을 중간에서 나누어 붙인 내용이다.
2-2 현재 컨슈머 그룹은 first_group 하나만 존재함을 --list 옵션으로 알 수 있고
2-3 --group옵션으로 해당 그룹을 선택하고 --describe 옵션을 통해 해당 그룹의 상태를 알 수 있다.
2-3-1 아래를 보통 그룹 first_group는 first_topic에 연결되어 있고 파티션은 3개가 존재한다.
2-3-2 각 파티션에는 10개, 8개, 7개의 메시지가 있고 현재 offset은 log-end와 동일하므로 모두 읽은 것이다.
2-3-3 만일 읽기 않은 파티션이 있다면 LAG에서 몇 개가 아직 읽혀지지 않은지를 확인할 수 있다.
2-4 consumer-id를 보면 위의 두개는 같은 id이고 아래 하나는 다른 id를 쓰고 있다. 2개의 컨슈머를 확인할 수 있다.
2-5 두개의 컨슈머는 1,2번 파티션은 하나의 컨슈머가 붙어서 사용하고, 3번 파티션은 다른 컨슈머가 사용한다.
3. Offset 변경하기
3-1 메시지를 어디까지 읽은지를 설정하는 부분이 consumer offset이다. 이것을 변경하는 명령어는 아래와 같다.
3-1-1 그룹이름, 토픽이름을 지정하는 것은 필수이다. --reset-offsets이 있고 어떤 정책을 사용할지를 붙인다.
3-1-2 --to-earliest는 아래를 보면 알겠지만 new-offset이 0으로 설정되어 모든 메시지를 다시 읽을 수 있다.
3-1-3 아래의 consumer를 붙여보면 처음부터 다시 읽고 있음을 알 수 있다.
kafka-consumer-groups.bat --bootstrap-server localhost:9092 --group first_group --topic first_topic --reset-offsets --to-earliest --execute
3-2 offset를 개수단위로 이동하려면 --shift-by 설정이 필요하다. 양수는 뒤로, 음수는 거슬로 올라가는 값이다.
3-2-1 파티션 내의 2개의 메시지를 다시 읽고 싶은 경우
kafka-consumer-groups.bat --bootstrap-server localhost:9092 --group first_group --topic first_topic --reset-offsets --shift-by -2 --execute
3-2-2 실행결과는 다음의 캡처로 알 수 있다.
'Side Technologies' 카테고리의 다른 글
Node : JavaScript 키보드로부터 입력 받기 stdin (1) | 2021.05.03 |
---|---|
Mongo: mongoose-encryption (1) | 2021.04.11 |
Kafka : CLI로 메시지 전송 및 수신 (0) | 2020.09.15 |
Kafka : 윈도우에서 TOPIC 생성 및 관리, 서버 기동과 다운 (0) | 2020.09.14 |
Kafka : 윈도우에서 설치하기 (0) | 2020.09.14 |
- Total
- Today
- Yesterday
- 도커 개발환경 참고
- AWS ARN 구조
- Immuability에 관한 설명
- 자바스크립트 멀티 비동기 함수 호출 참고
- WSDL 참고
- SOAP 컨슈머 참고
- MySql dump 사용법
- AWS Lambda with Addon
- NFC 드라이버 linux 설치
- electron IPC
- mifare classic 강의
- go module 관련 상세한 정보
- C 메모리 찍어보기
- C++ Addon 마이그레이션
- JAX WS Header 관련 stackoverflow
- SOAP Custom Header 설정 참고
- SOAP Custom Header
- SOAP BindingProvider
- dispatcher 사용하여 설정
- vagrant kvm으로 사용하기
- git fork, pull request to the …
- vagrant libvirt bridge network
- python, js의 async, await의 차이
- go JSON struct 생성
- Netflix Kinesis 활용 분석
- docker credential problem
- private subnet에서 outbound IP 확…
- 안드로이드 coroutine
- kotlin with, apply, also 등
- 안드로이드 초기로딩이 안되는 경우
- navigation 데이터 보내기
- 레이스 컨디션 navController
- raylib
- form
- WebMvc
- 상속
- Rest
- mapping
- XML
- 스프링부트
- 설정
- hibernate
- 매핑
- 스프링
- MYSQL
- RestTemplate
- 로그인
- jsp
- one-to-many
- 설정하기
- 외부파일
- Spring
- spring boot
- Security
- 자바
- Many-To-Many
- Validation
- login
- one-to-one
- Angular
- 하이버네이트
- crud
- Spring Security