[Apache Kafka] 2 -Producer / Consumer CLI

leeng·2024년 6월 28일
0

kafka

목록 보기
2/4

메시지를 produce하고 consume 하는 간단한 명령어들을 알아보자.

1. Producer & Consumer 콘솔 실행

1) producer와 consumer 실행 명령어를 각각 다른 터미널 창에서 입력한다.

kafka-console-producer.sh --bootstrap-server localhost:9092 --topic first_topic -- producer 실행

kafka-console-consumer.sh --bootstrap-server localhost:9092 --topic first_topic -- consumer

2) producer 콘솔 창에서 메세지를 입력한다.

3) 아래와 같이 consumer 콘솔에 producer가 보낸 메세지가 출력된다.


2. 메시지를 처음부터 Consume하기

위에서 설명한 명령어로 consumer 콘솔을 실행하면 실행한 이후에 전달된 메시지만을 소비한다.
만약에 메세지를 맨 처음부터 읽고 싶다면 --from-beginning 옵션을 사용하면 된다. 아래와 같이 --from-beginning를 추가하여 명령어를 입력하면 컨슈머 콘솔을 실행하기 전에 잘못 보낸(...) 메세지까지 읽을 수 있다.



3. 메시지를 Key와 함께 Produce하기

--property parse.key=true --property key.separator 옵션을 이용해 메세지를 보낼 때 를 설정하여 전송할 수도 있다. --property key.separator= 다음에 오는 값은 키와 값(메시지)을 구분하는 구분자가 된다.

kafka-console-producer.sh --bootstrap-server localhost:9092 --topic first_topic --property parse.key=true --property key.separator=:

예시와 같이 구분자를 :로 설정하고 메시지를 보내보자.

그러면 consumer에서는 값만 전달받고 있는 것을 확인할 수 있다.

그렇다면 메시지를 전송할 때 Key는 어떤 역할을 하기에 필요한 것일까?

1) 파티셔닝 & 논리적 그룹
Kafka는 키를 해시하여 파티션을 결정한다. 이를 통해 같은 키를 가진 메시지는 항상 같은 파티션으로 전송되므로 메시지 키를 사용하면 특정 파티션에 메시지를 보낼 수 있다. 그리고 이를 이용하여 논리적인 그룹으로 메시지를 묶을 수도 있다. 예를 들어서 user의 ID를 키 값으로 사용하면 같은 user의 메시지는 항상 같은 파티션으로 전송되는 것이다.

2) 키값에 따른 순서 보장
동일한 키를 가진 메시지는 동일한 파티션에 저장되기 때문에, 이 파티션에서의 메시지 순서가 보장된다. 키별로 순서를 보장하고자 할 때 유용하다.


4. 메시지를 acks 설정과 함께 Produce하기

메시지를 전달할 때 --producer-property acks= 옵션을 줌으로써 acks 모드를 설정할 수 있다. 설정 값으로는 acks=0, acks=1, acks=all(acks=-1)이 있다.

 kafka-console-producer.sh --bootstrap-server localhost:9092 --topic first_topic --producer-property acks=all -- acks 설정

acks란?
메시지를 브로커에 전송할 때의 확인(acknowledgement) 모드

  • acks=0: 프로듀서는 브로커로부터 어떤 응답도 기다리지 않는다. 메시지가 성공적으로 전달되었는지 알 수 없기 때문에 데이터 손실 가능성이 있다.
    -> 속도는 가장 빠르지만 신뢰성이 낮음.
  • acks=1: 리더 브로커가 메시지를 처리한 후 Producer에게 응답한다. 어느 정도의 신뢰성은 보장되지만 리더 브로커에 장애가 있을 경우 데이터 손실 가능성이 존재한다.
  • acks=all (또는 acks=-1): 리더 브로커 및 리더와 동기화된 replica가 모두 메시지를 처리한 후 프로듀서에게 응답한다. 데이터 손실의 가능성이 거의 없고 가장 신뢰성이 높지만, 속도가 느려질 수 있다.

5. 기타 Producer & Consumer CLI 명령어

1) Producer CLI 명령어

  • kafka-console-producer.sh --bootstrap-server localhost:9092 --topic non_existing_topic:
    존재하지 않는 토픽에 메시지를 보낼 수 있다. (여기서 non_existing_topic의 자리에는 지금은 존재하지 않지만 produce와 동시에 생성하고자 하는 토픽 이름을 입력) 이렇게 토픽을 생성한 경우에는 해당 토픽의 파티션이 server.properties 파일의 num.partitions 값만큼 생성된다.

2) Consumer CLI 명령어

display key, values and timestamp in consumer

kafka-console-consumer.sh --bootstrap-server localhost:9092 --topic first_topic --formatter kafka.tools.DefaultMessageFormatter --property print.timestamp=true --property print.key=true --property print.value=true --property print.partition=true --from-beginning :
메시지 format 옵션을 줄 수 있다. 위와 같은 옵션을 주는 경우에는 메시지(value)와 key, partition, timestamp까지 함께 보여준다.

profile
기술블로그보다는 기록블로그

39개의 댓글

comment-user-thumbnail
2025년 2월 26일

Outstanding submit, travelled in advance and also book marked your internet site. My partner and i can’t hold out to learn a lot more coming from an individual. Winter Park Top rated personal trainer

답글 달기
comment-user-thumbnail
2025년 3월 11일

Discount put up, Regards for the purpose of showing This unique practical knowledge. Excellently crafted piece of writing, if perhaps virtually all web guru proposed an identical standard of articles and other content whenever you, the on-line world will be more effective destination. Why not keep writing! 도봉 소액 대출

답글 달기
comment-user-thumbnail
2025년 3월 12일

Really good write-up, Appreciate it intended for giving That expertise. Excellently published document, but only if many blog writers made available identical higher level of information since you, the online world is a significantly better area. You need to thanks! funny thongs for the bride

답글 달기
comment-user-thumbnail
2025년 3월 13일

Maximize your potential with 1xBet’s 1X200MAX promo code! Claim a 100% bonus up to €130 or €1950 + 150 free spins. Tailored for African players, this code ensures a thrilling experience. un code promo 1xbet

답글 달기
comment-user-thumbnail
2025년 3월 13일

I am just genuinely thrilled to come across this great site along with does get pleasure from looking at valuable content put up below. Your concepts in the publisher ended up being wonderful, cheers to the talk about. مانجو جازان

답글 달기
comment-user-thumbnail
2025년 3월 13일

Please continue this great work and I look forward to more of your awesome blog posts.비대면 대출

답글 달기
comment-user-thumbnail
2025년 3월 13일

Really good write-up, Appreciate it intended for giving That expertise. Excellently published document, but only if many blog writers made available identical higher level of information since you, the online world is a significantly better area. You need to thanks! łóżko dla dziewczynki

답글 달기
comment-user-thumbnail
2025년 4월 10일

Thank you for the update, very nice site..A-1 Service Group

답글 달기
comment-user-thumbnail
2025년 4월 20일

I went to this website, and I believe that you have a plenty of excellent information, I have saved your site to my bookmarks. manaplay

답글 달기
comment-user-thumbnail
2025년 5월 1일

Yes, I am entirely agreed with this article, and I just want say that this article is very helpful and enlightening. I also have some precious piece of concerned info !!!!!!Thanks. 가상계좌 솔루션

답글 달기
comment-user-thumbnail
2025년 5월 1일

I exactly got what you mean, thanks for posting. And, I am too much happy to find this website on the world of Google. 가상계좌 임대

답글 달기
comment-user-thumbnail
2025년 5월 14일

It is truly a well-researched content and excellent wording. I got so engaged in this material that I couldn’t wait reading. I am impressed with your work and skill. Thanks. 해외선물 솔루션

답글 달기
comment-user-thumbnail
2025년 5월 15일

I have read a few of the articles on your website now, and I really like your style of blogging. I added it to my favorites blog site list and will be checking back soon. Please check out my site as well and let me know what you think.cannabis topicals for sale

답글 달기
comment-user-thumbnail
2025년 5월 15일

Wonderful article. Fascinating to read. I love to read such an excellent article. Thanks! It has made my task more and extra easy. Keep rocking.코인선물 솔루션

답글 달기
comment-user-thumbnail
2025년 5월 17일

Wow, excellent post. I'd like to draft like this too - taking time and real hard work to make a great article. This post has encouraged me to write some posts that I am going to write soon.해외선물 대여업체

답글 달기
comment-user-thumbnail
2025년 5월 18일

Great write-up, I am a big believer in commenting on blogs to inform the blog writers know that they’ve added something worthwhile to the world wide web!..DINA189 LOGIN

답글 달기
comment-user-thumbnail
2025년 5월 19일

I definitely enjoying every little bit of it. It is a great website and nice share. I want to thank you. Good job! You guys do a great blog, and have some great contents. Keep up the good work.Hosting

답글 달기
comment-user-thumbnail
2025년 5월 24일

Thanks for picking out the time to discuss this, I feel great about it and love studying more on this topic. It is extremely helpful for me. Thanks for such a valuable help again.클라우드웨이즈 가격테무 쿠폰테무 쿠폰temu クーポンコード마사지청주출장마사지

답글 달기
comment-user-thumbnail
2025년 5월 27일

We have sell some products of different custom boxes.it is very useful and very low price please visits this site thanks and please share this post with your friends.situs togel resmi toto 4d

답글 달기
comment-user-thumbnail
2025년 6월 1일

Thanks for taking the time to discuss this, I feel strongly about it and love learning more on this topic. If possible, as you gain expertise, would you mind updating your blog with extra information? It is extremely helpful for me.bandar toto macau

답글 달기
comment-user-thumbnail
2025년 6월 2일

Wow, cool post. I'd like to write like this too - taking time and real hard work to make a great article... but I put things off too much and never seem to get started. Thanks though.pestoto

답글 달기
comment-user-thumbnail
2025년 6월 2일

I think this is an informative post and it is very useful and knowledgeable. therefore, I would like to thank you for the efforts you have made in writing this article.mawartoto

답글 달기
comment-user-thumbnail
2025년 6월 2일

I admire this article for the well-researched content and excellent wording. I got so involved in this material that I couldn’t stop reading. I am impressed with your work and skill. Thank you so much.mawartoto

답글 달기
comment-user-thumbnail
2025년 6월 2일

I have read all the comments and suggestions posted by the visitors for this article are very fine,We will wait for your next article so only.Thanks!mahjong ways

답글 달기
comment-user-thumbnail
2025년 6월 3일

Your blog is too much amazing. I have found with ease what I was looking. Moreover, the content quality is awesome. Thanks for the nudgehttps://live-boutique.com/code-promo/melbet

답글 달기
comment-user-thumbnail
2025년 6월 4일

I wanted to thank you for this great read!! I definitely enjoying every little bit of it I have you bookmarked to check out new stuff you post.sengtoto

답글 달기
comment-user-thumbnail
2025년 6월 4일

I wanted to thank you for this great read!! I definitely enjoying every little bit of it I have you bookmarked to check out new stuff you post.live draw hk

답글 달기
comment-user-thumbnail
2025년 6월 4일

This is my first time i visit here. I found so many interesting stuff in your blog especially its discussion. From the tons of comments on your articles, I guess I am not the only one having all the enjoyment here keep up the good work4d

답글 달기
comment-user-thumbnail
2025년 6월 4일

This is my first time i visit here. I found so many interesting stuff in your blog especially its discussion. From the tons of comments on your articles, I guess I am not the only one having all the enjoyment here keep up the good worktoto 4d

답글 달기
comment-user-thumbnail
2025년 6월 4일

Thank you because you have been willing to share information with us. we will always appreciate all you have done here because I know you are very concerned with our.boswd77.net

답글 달기
comment-user-thumbnail
2025년 6월 12일

I’m going to read this. I’ll be sure to come back. thanks for sharing. and also This article gives the light in which we can observe the reality. this is very nice one and gives indepth information. thanks for this nice article...pol link alternatif

답글 달기
comment-user-thumbnail
2025년 6월 12일

I’m going to read this. I’ll be sure to come back. thanks for sharing. and also This article gives the light in which we can observe the reality. this is very nice one and gives indepth information. thanks for this nice article...카지노검증

답글 달기
comment-user-thumbnail
2025년 6월 14일

We aim to revolutionize your cali weed buds experience by offering a superior customer journey fromcali weed

답글 달기
comment-user-thumbnail
2025년 6월 14일

Thanks for sharing this quality information with us. I really enjoyed reading. Will surely going to share this URL with my friends.iosbet login

답글 달기
comment-user-thumbnail
7일 전

i never know the use of adobe shadow until i saw this post. thank you for this! this is very helpful.해외선물 솔루션

답글 달기
comment-user-thumbnail
7일 전

This is a great inspiring article.I am pretty much pleased with your good work.You put really very helpful information. Keep it up. Keep blogging. Looking to reading your next post. 해외선물 개발

답글 달기
comment-user-thumbnail
5일 전

I really appreciate the kind of topics you post here. Thanks for sharing us a great information that is actually helpful. Good day!anavar side effect

답글 달기
comment-user-thumbnail
4일 전

I really appreciate the kind of topics you post here. Thanks for sharing us a great information that is actually helpful. Good day!telegram官网

답글 달기
comment-user-thumbnail
약 9시간 전

Any movies is normally outstanding. You've gotten a lot of particularly as good writers and singers. Document prefer you will the best quality about financial success. olxtoto link Any movies is normally outstanding. You've gotten a lot of particularly as good writers and singers. Document prefer you will the best quality about financial success. link alternatif evostoto Any movies is normally outstanding. You've gotten a lot of particularly as good writers and singers. Document prefer you will the best quality about financial success. koi toto Any movies is normally outstanding. You've gotten a lot of particularly as good writers and singers. Document prefer you will the best quality about financial success. olxtoto link Any movies is normally outstanding. You've gotten a lot of particularly as good writers and singers. Document prefer you will the best quality about financial success. situs toto

답글 달기