一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

服務器資訊|IT/互聯網|云計算|區塊鏈|軟件資訊|操作系統|手機數碼|百科知識|免費資源|頭條新聞|

服務器之家 - 新聞資訊 - 操作系統 - Linux下利用Docker快速部署配置Kafka服務

Linux下利用Docker快速部署配置Kafka服務

2024-01-10 17:01未知服務器之家 操作系統

Kafka是由Apache軟件基金會開發一個開源流處理平臺,使用Scala和Java編寫, 該項目的目標是為處理實時數據提供一個統一、高吞吐、低延遲的平臺。其持久化層本質上是一個按照分布式事務日志架構的大規模發布/訂閱消息隊列。這種工

Kafka是由Apache軟件基金會開發一個開源流處理平臺,使用Scala和Java編寫, 該項目的目標是為處理實時數據提供一個統一、高吞吐、低延遲的平臺。其持久化層本質上是一個按照分布式事務日志架構的大規模發布/訂閱消息隊列。這種工作方式使它為企業級基礎設施來處理流失數據非常有價值。

本文的目的是使用Docker容器來部署Kafka, 這樣可以省略Kafka安裝配置的中間過程, 節省大量時間。文章中分別從幾個維度來闡述Kafka的部署過程, 包括:基礎環境要求、安裝zookeeper、容器內的設置等, 最后給出了一個從生產者角度向消費者發送消息, 消費者成功接收到消息作為結尾, 最后給出了一個在全過程當中遇到問題排查的正確方法。

Linux下利用Docker快速部署配置Kafka服務

認識Kafka

Kafka存儲的消息來自任務多被稱為"生產者"(Producer)的進程。數據從而可以被分配到不同的"分區"(Partition)、不同的“Topic”下。在一個分區內, 消息被索引并連同時間戳存儲在一起。而其它被稱為"消費者"(Consumer)的進程可以從分區查詢消息。Kafka運行在一個由一臺或多臺服務器組成的集群上, 并且分區可以跨集群節點分布。Kafka的架構如下圖所示:

Linux下利用Docker快速部署配置Kafka服務

以下列出了Kafka技術相關的術語:

  • Topic - 用來對消息進行分類, 每個進入到Kafka的信息都會被放到一個Topic下。
  • Broker - 用來實現數據存儲的主機服務器。
  • Partition - 每個Topic中的消息會被分為若干個Partition,以提高消息的處理效率
  • Producer - 消息的生產者
  • Consumer - 消息的消費者

了解了以上概念之后,對于Kafka的部署已經沒有什么障礙, 下面開始正式的部署過程。

基礎環境準備

大多數Linux發行版都支持安裝Kafka,這里我準備了一臺ubuntu 22.04.3 LTS版本的虛擬機作為試驗環境。

登錄到系統輸入:docker -v 命令, 如果出現:

Docker version 24.0.5, build 24.0.5-0ubuntu1~22.04.1

類似于這樣的提示信息,說明Docker已安裝,如果沒有,請輸入以下命令安裝Docker:

$ sudo apt update
$ sudo apt install docker.io

安裝zookeeper

由于Kafka依賴Zookeeper實現高可用性和一致性,其為Kafka提供了關鍵的分布式協調服務,因此部署Kafka必須先部署Zookeeper集群作為基礎, 以下進入部署Zookeeper的過程:

在命令行直接輸入以下命令,docker會自動拉取對應鏡像:

# docker run -d --name zookeeper -p 2181:2181 -v /etc/localtime:/etc/localtime wurstmeister/zookeeper

拉取過程如圖:

Linux下利用Docker快速部署配置Kafka服務

安裝Kafka

Zookeeper安裝成功后, 接著安裝Kafka組件, 在命令行直接輸入以下命令,docker會自動拉取對應鏡像:

# docker run -d --name kafka -p 9092:9092 -e KAFKA_BROKER_ID=0 -e KAFKA_ZOOKEEPER_CONNECT=[你的IP地址]:2181 -e KAFKA_ADVERTISED_LISTENERS=PLAINTEXT://[你的IP地址]:9092 -e KAFKA_LISTENERS=PLAINTEXT://0.0.0.0:9092 -t wurstmeister/kafka

注意, 我的服務器IP是192.168.201.206,所以上面的IP要根據自己的實際情況進行變更,我變更后的命令如下:

# docker run -d --name kafka -p 9092:9092 -e KAFKA_BROKER_ID=0 -e KAFKA_ZOOKEEPER_CONNECT=192.168.201.206:2181 -e KAFKA_ADVERTISED_LISTENERS=PLAINTEXT://192.168.201.206:9092 -e KAFKA_LISTENERS=PLAINTEXT://0.0.0.0:9092 -t wurstmeister/kafka

拉取過程如圖:

Linux下利用Docker快速部署配置Kafka服務

進入容器

Kafka安裝完畢后,還要進入到容器中啟動生產者和消費者,這樣可以驗證kafka功能是否正常,順序執行命令如下:

# docker ps -a #查看kafka鏡像的容器ID
# docker exec -it 容器ID /bin/sh #進入到容器內部
# cd /opt/kafka/bin # 切到容器內部kafka執行目錄下

執行最后的結果如圖:

Linux下利用Docker快速部署配置Kafka服務

啟動生產者

在容器里執行以下命令啟動生產者:

./kafka-console-producer.sh --broker-list localhost:9092 --topic [你的topic名稱]

我這里自己起了一個topic名稱,名字為test123, 如圖:

Linux下利用Docker快速部署配置Kafka服務

產生者腳本啟動成功后,會有一個">"提示符。

啟動消費者

為了看到生產者和消費者之間的消息傳遞效果,這里需要另開一個終端,按照上面的方法進入容器對應目錄,并執行以下命令:

./kafka-console-consumer.sh --bootstrap-server [你的IP地址]:9092 --topic [你的topic名稱]

注意,這里有兩個變量需要自己調整,一個是IP地址,另一個是上面建立的Topic名稱, 我這里填入信息后的完整命令如下:

./kafka-console-consumer.sh --bootstrap-server 192.168.201.206:9092 --topic test123

執行過程如圖:

Linux下利用Docker快速部署配置Kafka服務

生產者與消費者測試

切換到生產者窗口,連續輸入一些信息,如圖:

Linux下利用Docker快速部署配置Kafka服務

再切換回消費者窗口, 正常的話已經可以收到生產者發送的信息了,如圖:

Linux下利用Docker快速部署配置Kafka服務

1故障排查

如果在使用Docker過程中遇到任何錯誤, 可以命令:

docker logs 容器ID

通過查看容器日志進行故障排查,過程如圖:

Linux下利用Docker快速部署配置Kafka服務

總結

在部署Kafka的整個過程中, 遵循以下部署順序流程:

  • 首先檢查Docker安裝是否正常, 確保Docker安裝無任何異常。
  • 其次安裝Kafka的依賴服務Zookeeper, 只需要一句命令可實現自動鏡像拉取。
  • 接著安裝Kafka組件,也是一句命令即可搞定, 自動拉取對應的鏡像。
  • 進入到容器內部, 分別啟動生產者和消費者腳本, 便可以開始進行發送消息測試了。
  • 在整個部署過程中,遇到任何錯誤或問題都可以通過Docker日志進行問題排查。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 波多野结衣中文字幕 | 国产成人成人一区二区 | 96免费精品视频在线 | 9自拍视频在线观看 | 美女的隐私脱裤子无遮挡 | 国产3p在线 | 国产成人精品视频一区二区不卡 | 99热这里只精品99re66 | 精品无码久久久久久久久 | 日韩视频免费观看 | yellow最新视频2019 | 天美传媒果冻传媒星空传媒 | 喷奶水榨乳ova动漫无修 | 小黄文污到你湿 | 天堂网www在线中文天堂 | 午夜无码国产理论在线 | 国产a一级毛片午夜剧院 | 国产麻豆剧果冻传媒影视4934 | 亚洲欧美日韩国产一区图片 | 久久er99热精品一区二区 | 日韩一级精品视频在线观看 | 国产亚洲一欧美一区二区三区 | 和日本免费不卡在线v | sss亚洲国产欧美一区二区 | 垫底辣妹免费观看完整版 | yin娃sao货调教情趣用品店 | 美女的让男人桶爽免费看 | 国产成人久久久精品一区二区三区 | 18捆绑调教在线高清 | 成年男人永久免费看片 | 精品国产原创在线观看视频 | 美女脱了内裤让男生尿囗 | 铁牛tv 在线观看 | 久久精品中文字幕 | 99re7在线精品免费视频 | 公翁的舌尖研磨她的花蒂小说 | 国产成人精品曰本亚洲78 | 99ri国产在线 | 无人区在线观看免费国语完整版 | 亚洲精品无码久久不卡 | 波多野结衣不卡 |