kafka單機安裝

来源:https://www.cnblogs.com/HappyTeemo/archive/2023/02/10/17109537.html
-Advertisement-
Play Games

一、安裝 kafka是由scala語言寫成的,後面用Java重構了,但是不管怎樣,都要編譯到jvm虛擬機中執行。 centos:yum install java-11-openjdk ubuntu:apt install default-jdk java -version 下載kafka 下載 wg ...


一、安裝

kafka是由scala語言寫成的,後面用Java重構了,但是不管怎樣,都要編譯到jvm虛擬機中執行。

centos:yum install java-11-openjdk
ubuntu:apt install default-jdk

java -version

下載kafka

下載
wget  https://archive.apache.org/dist/kafka/2.0.0/kafka_2.11-2.0.0.tgz
解壓
tar -zxvf kafka_2.11-2.2.0.tgz

cd kafka_2.11-2.2.0

簡單配置下

vim  config/server.properties

#broker 的全局唯一編號,不能重覆
broker.id=0
#能否刪除 topic
delete.topic.enable=true
#處理網路請求的線程數量
num.network.threads=3
#用來處理磁碟 IO 的現成數量
num.io.threads=8
#發送套接字的緩衝區大小
socket.send.buffer.bytes=102400
#接收套接字的緩衝區大小
socket.receive.buffer.bytes=102400
#請求套接字的緩衝區大小
socket.request.max.bytes=104857600
#kafka 運行日誌存放的路徑
log.dirs=/opt/module/kafka/logs
#topic 在當前 broker 上的分區個數
num.partitions=1
#用來恢復和清理 data 下數據的線程數量
num.recovery.threads.per.data.dir=1
#segment 文件保留的最長時間,超時將被刪除
log.retention.hours=168

二、啟動

建議使用screen,開兩個

啟動zk【預設埠2181】
bin/zookeeper-server-start.sh config/zookeeper.properties

啟動Kafka
bin/kafka-server-start.sh config/server.properties

三、測試使用

#創建單分區單副本的 topic demo:
bin/kafka-topics.sh --create --zookeeper localhost:2181 --replication-factor 1 --partitions 1 --topic demo

#查看 topic 列表:
bin/kafka-topics.sh --list --zookeeper localhost:2181

#發送消息【生產者】
bin/kafka-console-producer.sh --broker-list localhost:9092 --topic demo

#接收消息併在終端列印:
bin/kafka-console-consumer.sh --bootstrap-server localhost:9092 --topic demo --from-beginning

#查看描述 topics 信息
bin/kafka-topics.sh --describe --zookeeper localhost:2181 --topic demo

Topic:demo      PartitionCount:1        ReplicationFactor:1     Configs:
        Topic: demo     Partition: 0    Leader: 1       Replicas: 1     Isr: 1

第一行給出了所有分區的摘要,每個附加行給出了關於一個分區的信息。 由於我們只有一個分區,所以只有一行。

“Leader”: 是負責給定分區的所有讀取和寫入的節點。
“Replicas”: 是複製此分區日誌的節點列表,無論它們是否是領導者,或者即使他們當前處於活動狀態。
“Isr”: 是一組“同步”副本。這是複製品列表的子集,當前活著並被引導到領導者

四、集群配置

Kafka 支持兩種模式的集群搭建:可以在單機上運行多個 broker 實例來實現集群,也可在多台機器上搭建集群,下麵介紹下如何實現單機多 broker 實例集群,其實很簡單,只需要如下配置即可。

單機多broker 集群配置利用單節點部署多個 broker。 不同的 broker 設置不同的 id,監聽埠及日誌目錄。 例如:

cp config/server.properties config/server-2.properties
cp config/server.properties config/server-3.properties
vim config/server-2.properties
vim config/server-3.properties

修改 :

broker.id=2
listeners = PLAINTEXT://your.host.name:9093
log.dir=/data/kafka/logs-2

broker.id=3
listeners = PLAINTEXT://your.host.name:9094
log.dir=/data/kafka/logs-3

啟動Kafka服務:(也可以用screen)

bin/kafka-server-start.sh config/server-2.properties &
bin/kafka-server-start.sh config/server-3.properties &

至此,單機多broker實例的集群配置完畢。

多機多broker集群配置

分別在多個節點按上述方式安裝 Kafka,配置啟動多個 Zookeeper 實例。

假設三台機器 IP 地址是 : 192.168.153.135, 192.168.153.136, 192.168.153.137

分別配置多個機器上的 Kafka 服務,設置不同的 broker id,zookeeper.connect 設置如下:

vim config/server.properties

裡面的 zookeeper.connect

修改為:

zookeeper.connect=192.168.153.135:2181,192.168.153.136:2181,192.168.153.137:2181

五、配置

外網訪問

配置:server.properties


修改成內網地址
listeners=PLAINTEXT://:9092
改成外網地址
advertised.listeners=PLAINTEXT://主機IP:9092
當你停下來休息的時候,不要忘記別人還在奔跑!
您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 一、前言 上一篇我們完成了軟體的基本功能,如果想在用戶使用我們的app時,自動檢測新版本並讓自動完成安裝,這樣豈不是更好?本篇我們就來探究一下遠程更新的過程,並完成實際的功能。另外在使用過程中發現,登錄之後重啟app,會發現需要再次登錄,使用很不方便,我們也在第三部分解決這個問題。 二、fusion ...
  • 《Terraform 101 從入門到實踐》這本小冊在南瓜慢說官方網站和GitHub兩個地方同步更新,書中的示例代碼也是放在GitHub上,方便大家參考查看。 軍書十二捲,捲捲有爺名。 為什麼需要狀態管理 Terraform的主要作用是管理雲平臺上的資源,通過聲明式的HCL配置來映射資源,如果雲平臺 ...
  • 效果圖: // 這裡設置預設初始步驟StepContentFn('.starBox', "已申請:楊博:2020/2/3:已申請審批意見, 已立項:楊博:2020/5/5:已立項審批意見, 實施中:張三:2020/5/9:實施中意見, 等待中:楊博:2020/6/6:等待中審批意見,已完結:楊博:2 ...
  • 一、Typora軟體的下載與使用 (1)、軟體下載 百度網盤windowsx64已破解:https://pan.baidu.com/s/1ksoh9TeprB5LkZ3tKB-AAA?pwd=p6w6 提取碼:p6w6 ios下載地址:https://mac.qdrayst.com/02/Typor ...
  • 1.什麼是函數模版 函數模板,實際上是建立一個通用函數,其函數類型和形參類型不具體制定,用一個虛擬的類型來代表。這個通用函數就成為函數模板 2.怎麼編寫函數模版 //T代表泛型的數據類型,不是只能寫T, template<class T>//讓編譯器看到這句話後面緊跟著的函數里有T不要報錯 void ...
  • 2023-02-10 一、配置SSM環境 1、添加日誌文件 在“shf-parent/web-admin/src/main/resources”下創建“logback.xml” <?xml version="1.0" encoding="UTF-8"?> <configuration debug=" ...
  • 教程簡介 批處理腳本語法 - 從簡單和簡單的步驟學習批處理腳本,從基本到高級概念,包括概述,環境,命令,文件,語法,變數,註釋,字元串,數組,決策,操作符,日期和時間,輸入/輸出,返回代碼,函數,進程,別名,設備,註冊表,網路,列印,調試,日誌記錄。 教程目錄 批處理腳本 - 語法 批處理腳本 - ...
  • 參考:https://blog.csdn.net/weixin_42401159/article/details/112187778 https://cloud.tencent.com/developer/article/1406445 在處理一些自然語言文字的過程中,會遇到一些錶面很奇怪的現象。 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...