激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

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

服務器資訊|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日志進行問題排查。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 蜜桃av鲁一鲁一鲁一鲁 | 日韩黄色av网站 | 欧美不卡 | av电影在线观看免费 | 国产精品成人亚洲一区二区 | 新久草在线视频 | 一区二区三区日韩在线观看 | 天堂精品在线 | 成人一级在线 | 精品国产中文字幕 | 久久精品首页 | 超碰九色 | 久久草在线观看视频 | 成人国产精品一区二区毛片在线 | 欧美性受xxxxxx黑人xyx性爽 | 激情影院在线观看 | 欧美一区二区三区中文字幕 | 欧美成人一区免费视频 | 91美女啪啪 | 石原莉奈日韩一区二区三区 | 国产伊人色 | 草莓福利视频在线观看 | 久久久久99一区二区三区 | 日韩视频一区在线 | 欧美性生交zzzzzxxxxx | 一区二区三区欧美在线观看 | 最新欧美精品一区二区三区 | 亚洲骚综合 | 在线播放一级片 | 蜜桃视频在线免费播放 | 进去了(高h) | 99激情 | 欧美精品亚洲人成在线观看 | 99爱在线免费观看 | 免费黄色入口 | 韩国草草影院 | 精品国产一区二区三区成人影院 | 美女黄视频在线观看 | 一级在线观看 | 97超碰资源站 | 男人午夜小视频 |