千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機(jī)構(gòu)

手機(jī)站
千鋒教育

千鋒學(xué)習(xí)站 | 隨時(shí)隨地免費(fèi)學(xué)

千鋒教育

掃一掃進(jìn)入千鋒手機(jī)站

領(lǐng)取全套視頻
千鋒教育

關(guān)注千鋒學(xué)習(xí)站小程序
隨時(shí)隨地免費(fèi)學(xué)習(xí)課程

當(dāng)前位置:首頁(yè)  >  技術(shù)干貨  > 一步一步在CentOS7上搭建Kafka集群

一步一步在CentOS7上搭建Kafka集群

來(lái)源:千鋒教育
發(fā)布人:xqq
時(shí)間: 2023-12-20 06:16:06 1703024166

在當(dāng)今的互聯(lián)網(wǎng)和大數(shù)據(jù)時(shí)代,消息隊(duì)列架構(gòu)成為了許多企業(yè)關(guān)注的焦點(diǎn)。比如,千億日活的短視頻應(yīng)用——抖音,它的消息隊(duì)列就是使用Kafka來(lái)完成的。Kafka作為一種高性能、高可靠性的消息中間件,為許多企業(yè)提供了很好的解決方案。在本文中,我們將帶領(lǐng)您一步一步在CentOS 7上搭建Kafka集群,讓您更好地了解Kafka的使用和應(yīng)用。

一、準(zhǔn)備工作

在開(kāi)始之前,我們需要提前準(zhǔn)備好一些工作:

1. 一臺(tái)安裝了CentOS 7的機(jī)器,并開(kāi)啟了網(wǎng)絡(luò)連接。

2. JDK環(huán)境,Kafka需要JDK 1.8及以上版本,因此我們需要先安裝JDK環(huán)境。

3. ZooKeeper,Kafka依賴于ZooKeeper,因此我們需要先安裝好ZooKeeper。

二、安裝JDK環(huán)境

我們可以從Oracle官網(wǎng)上下載JDK,這里我使用的是openjdk-8-jdk版本。在終端中輸入以下命令進(jìn)行安裝:

sudo yum install -y java-1.8.0-openjdk-devel

然后,我們可以使用以下命令檢查是否正確安裝了JDK環(huán)境:

java -version

如果顯示以下內(nèi)容,則說(shuō)明JDK環(huán)境已經(jīng)安裝成功:

openjdk version "1.8.0_232"OpenJDK Runtime Environment (build 1.8.0_232-b09)OpenJDK 64-Bit Server VM (build 25.232-b09, mixed mode)

三、安裝ZooKeeper

在安裝ZooKeeper之前,我們需要為其創(chuàng)建一個(gè)用戶,并授權(quán):

sudo useradd zookeeper -m -s /bin/bashsudo passwd zookeepersudo chown -R zookeeper:zookeeper /usr/local/zookeeper

接下來(lái),我們可以從官網(wǎng)上下載ZooKeeper,這里我使用的是ZooKeeper 3.4.14版本。在終端中輸入以下命令進(jìn)行安裝:

wget http://mirror.bit.edu.cn/apache/zookeeper/zookeeper-3.4.14/zookeeper-3.4.14.tar.gztar -zxvf zookeeper-3.4.14.tar.gzsudo mv zookeeper-3.4.14/ /usr/local/zookeeper

然后,我們需要?jiǎng)?chuàng)建ZooKeeper的配置文件:

sudo cp /usr/local/zookeeper/conf/zoo_sample.cfg /usr/local/zookeeper/conf/zoo.cfg

現(xiàn)在,我們可以啟動(dòng)ZooKeeper了:

sudo /usr/local/zookeeper/bin/zkServer.sh start

可以使用以下命令檢查是否正確啟動(dòng)了ZooKeeper:

sudo /usr/local/zookeeper/bin/zkServer.sh status

如果顯示以下內(nèi)容,則說(shuō)明ZooKeeper已經(jīng)啟動(dòng)成功:

Mode: standalone

四、安裝Kafka

在安裝Kafka之前,我們需要為其創(chuàng)建一個(gè)用戶,并授權(quán):

sudo useradd kafka -m -s /bin/bashsudo passwd kafkasudo chown -R kafka:kafka /usr/local/kafka

接下來(lái),我們可以從官網(wǎng)上下載Kafka,這里我使用的是Kafka 2.4.1版本。在終端中輸入以下命令進(jìn)行安裝:

wget http://mirror.bit.edu.cn/apache/kafka/2.4.1/kafka_2.12-2.4.1.tgztar -zxvf kafka_2.12-2.4.1.tgzsudo mv kafka_2.12-2.4.1/ /usr/local/kafka

然后,我們需要?jiǎng)?chuàng)建Kafka的配置文件:

sudo cp /usr/local/kafka/config/server.properties /usr/local/kafka/config/server-1.propertiessudo cp /usr/local/kafka/config/server.properties /usr/local/kafka/config/server-2.properties

現(xiàn)在,我們可以啟動(dòng)Kafka了。在終端中輸入以下命令啟動(dòng)Kafka:

sudo /usr/local/kafka/bin/kafka-server-start.sh -daemon /usr/local/kafka/config/server-1.propertiessudo /usr/local/kafka/bin/kafka-server-start.sh -daemon /usr/local/kafka/config/server-2.properties

可以使用以下命令檢查是否正確啟動(dòng)了Kafka:

sudo /usr/local/kafka/bin/kafka-server-stop.sh /usr/local/kafka/config/server-1.propertiessudo /usr/local/kafka/bin/kafka-server-stop.sh /usr/local/kafka/config/server-2.properties

如果顯示以下內(nèi)容,則說(shuō)明Kafka已經(jīng)啟動(dòng)成功:

[2020-03-05 22:10:26,773] INFO Kafka version: 2.4.1 (org.apache.kafka.common.utils.AppInfoParser:109)[2020-03-05 22:10:26,774] INFO Kafka commitId: c57222ae8cd7866b (org.apache.kafka.common.utils.AppInfoParser:110)[2020-03-05 22:10:26,781] INFO [KafkaServer id=1] started (kafka.server.KafkaServer:58)

五、創(chuàng)建主題和分區(qū)

在Kafka中,主題是消息的類別,可以將其理解為一個(gè)消息隊(duì)列。分區(qū)是一個(gè)物理概念,可以將一個(gè)主題分成多個(gè)分區(qū),每個(gè)分區(qū)保存著一部分消息,因此可以分別在不同的節(jié)點(diǎn)上存儲(chǔ)數(shù)據(jù),提高了消息的并發(fā)處理能力。在本文中,我們將為Kafka創(chuàng)建一個(gè)名為test的主題,并將其分成3個(gè)分區(qū)。在終端中輸入以下命令:

sudo /usr/local/kafka/bin/kafka-topics.sh --create --zookeeper localhost:2181 --replication-factor 2 --partitions 3 --topic test

然后,我們可以使用以下命令查看創(chuàng)建的主題信息:

sudo /usr/local/kafka/bin/kafka-topics.sh --describe --zookeeper localhost:2181 --topic test

如果顯示以下內(nèi)容,則說(shuō)明主題和分區(qū)已經(jīng)成功創(chuàng)建:

Topic:test PartitionCount:3 ReplicationFactor:2 Configs:    Topic: test Partition: 0 Leader: 1 Replicas: 1,2 Isr: 1,2    Topic: test Partition: 1 Leader: 2 Replicas: 2,1 Isr: 2,1    Topic: test Partition: 2 Leader: 1 Replicas: 2,1 Isr: 1,2

六、發(fā)送和接收消息

現(xiàn)在,我們已經(jīng)成功創(chuàng)建了一個(gè)名為test的主題,并將其分成了3個(gè)分區(qū)。接下來(lái),讓我們來(lái)發(fā)送和接收一些消息。在終端中輸入以下命令:

1. 啟動(dòng)一個(gè)Kafka生產(chǎn)者:

sudo /usr/local/kafka/bin/kafka-console-producer.sh --broker-list localhost:9092 --topic test

此時(shí),終端會(huì)進(jìn)入等待消息輸入的狀態(tài)。

2. 啟動(dòng)一個(gè)Kafka消費(fèi)者:

sudo /usr/local/kafka/bin/kafka-console-consumer.sh --bootstrap-server localhost:9092 --topic test --from-beginning

此時(shí),終端會(huì)輸出已經(jīng)發(fā)送的消息。

3. 在生產(chǎn)者終端中輸入一些消息,比如:

hello kafka!

4. 在消費(fèi)者終端中,會(huì)輸出剛才發(fā)送的消息:

hello kafka!

至此,我們已經(jīng)成功地在CentOS 7上搭建了Kafka集群,并成功地發(fā)送和接收了一些消息。Kafka作為一種高性能、高可靠性的消息中間件,為許多企業(yè)提供了很好的解決方案。通過(guò)本文的學(xué)習(xí),相信讀者已經(jīng)對(duì)Kafka的使用和應(yīng)用有了更好的了解。

以上就是IT培訓(xùn)機(jī)構(gòu)千鋒教育提供的相關(guān)內(nèi)容,如果您有web前端培訓(xùn)鴻蒙開(kāi)發(fā)培訓(xùn)python培訓(xùn)linux培訓(xùn),java培訓(xùn),UI設(shè)計(jì)培訓(xùn)等需求,歡迎隨時(shí)聯(lián)系千鋒教育。

tags:
聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
10年以上業(yè)內(nèi)強(qiáng)師集結(jié),手把手帶你蛻變精英
請(qǐng)您保持通訊暢通,專屬學(xué)習(xí)老師24小時(shí)內(nèi)將與您1V1溝通
免費(fèi)領(lǐng)取
今日已有369人領(lǐng)取成功
劉同學(xué) 138****2860 剛剛成功領(lǐng)取
王同學(xué) 131****2015 剛剛成功領(lǐng)取
張同學(xué) 133****4652 剛剛成功領(lǐng)取
李同學(xué) 135****8607 剛剛成功領(lǐng)取
楊同學(xué) 132****5667 剛剛成功領(lǐng)取
岳同學(xué) 134****6652 剛剛成功領(lǐng)取
梁同學(xué) 157****2950 剛剛成功領(lǐng)取
劉同學(xué) 189****1015 剛剛成功領(lǐng)取
張同學(xué) 155****4678 剛剛成功領(lǐng)取
鄒同學(xué) 139****2907 剛剛成功領(lǐng)取
董同學(xué) 138****2867 剛剛成功領(lǐng)取
周同學(xué) 136****3602 剛剛成功領(lǐng)取
相關(guān)推薦HOT
從零開(kāi)始如何在Linux上搭建Web服務(wù)器?

從零開(kāi)始:如何在Linux上搭建Web服務(wù)器?搭建一個(gè)Web服務(wù)器是一項(xiàng)非常基礎(chǔ)的運(yùn)維技能,在這篇文章中,我們將介紹如何在Linux系統(tǒng)上從零開(kāi)始搭建...詳情>>

2023-12-20 07:17:41
Linux網(wǎng)絡(luò)性能優(yōu)化讓你的網(wǎng)絡(luò)更快、更穩(wěn)定

Linux網(wǎng)絡(luò)性能優(yōu)化:讓你的網(wǎng)絡(luò)更快、更穩(wěn)定在現(xiàn)代的網(wǎng)絡(luò)時(shí)代,網(wǎng)絡(luò)性能已經(jīng)成為企業(yè)和個(gè)人的重要考慮因素之一。不僅要保證網(wǎng)絡(luò)的高速和穩(wěn)定,...詳情>>

2023-12-20 07:07:08
Nginx入門指南如何配置反向代理和負(fù)載均衡

Nginx是一款高性能的Web服務(wù)器軟件,它在近年來(lái)逐漸流行起來(lái)。Nginx被稱作反向代理服務(wù)器,能夠極大的提高Web服務(wù)器性能,同時(shí)各大公司也普遍采...詳情>>

2023-12-20 06:47:46
開(kāi)始使用Docker成功依賴于自己的容器環(huán)境

開(kāi)始使用Docker:成功依賴于自己的容器環(huán)境Docker是目前最流行的容器技術(shù)之一,已經(jīng)成為許多開(kāi)發(fā)人員、系統(tǒng)管理員和 DevOps 工程師的首選工具。...詳情>>

2023-12-20 06:46:01
使用DockerSwarm在集群中運(yùn)行微服務(wù)

使用Docker Swarm在集群中運(yùn)行微服務(wù)隨著微服務(wù)架構(gòu)的流行,越來(lái)越多的企業(yè)開(kāi)始將應(yīng)用程序拆分成小型服務(wù),并將它們部署到不同的容器中。這種方...詳情>>

2023-12-20 06:42:30
快速通道
久久亚洲中文字幕精品一区四,亚洲日本另类欧美一区二区,久久久久久久这里只有免费费精品,高清国产激情视频在线观看
在线影片亚洲视频 | 中文字幕乱码亚洲第一页 | 亚洲国产欧美日韩另类 | 中文字幕无线码一区二区 | 日韩AV一区二区三区五月天 | 夂久精品国产久精国产 |