Linux下Kafka單機(jī)安裝配置方法(圖文)
介紹
Kafka是一個分布式的、可分區(qū)的、可復(fù)制的消息系統(tǒng)。它提供了普通消息系統(tǒng)的功能,但具有自己獨特的設(shè)計。這個獨特的設(shè)計是什么樣的呢?
首先讓我們看幾個基本的消息系統(tǒng)術(shù)語:
•Kafka將消息以topic為單位進(jìn)行歸納。
•將向Kafka topic發(fā)布消息的程序成為producers.
•將預(yù)訂topics并消費消息的程序成為consumer.
•Kafka以集群的方式運行,可以由一個或多個服務(wù)組成,每個服務(wù)叫做一個broker.
producers通過網(wǎng)絡(luò)將消息發(fā)送到Kafka集群,集群向消費者提供消息,如下圖所示:
客戶端和服務(wù)端通過TCP協(xié)議通信。Kafka提供了Java客戶端,并且對多種語言都提供了支持。
說明:
操作系統(tǒng):CentOS 6.x 64位
Kafka版本:kafka_2.11-0.8.2.1
實現(xiàn)目的:
單機(jī)安裝配置kafka
具體操作:
一、關(guān)閉SELINUX、開啟防火墻9092端口
1、關(guān)閉SELINUX
vi /etc/selinux/config
#SELINUX=enforcing #注釋掉
#SELINUXTYPE=targeted #注釋掉
SELINUX=disabled #增加
:wq! #保存退出
setenforce 0 #使配置立即生效
2、配置防火墻,開啟9092端口
vi /etc/sysconfig/iptables #編輯防火墻配置文件
# Firewall configuration written by system-config-firewall
# Manual customization of this file is not recommended.
*filter
:INPUT ACCEPT [0:0]
:FORWARD ACCEPT [0:0]
:OUTPUT ACCEPT [0:0]
-A INPUT -m state --state ESTABLISHED,RELATED -j ACCEPT
-A INPUT -p icmp -j ACCEPT
-A INPUT -i lo -j ACCEPT
-A INPUT -m state --state NEW -m tcp -p tcp --dport 22 -j ACCEPT
-A INPUT -m state --state NEW -m tcp -p tcp --dport 9092 -j ACCEPT
-A INPUT -j REJECT --reject-with icmp-host-prohibited
-A FORWARD -j REJECT --reject-with icmp-host-prohibited
COMMIT
:wq! #保存退出
service iptables restart #最后重啟防火墻使配置生效
二、安裝JDK
kafka運行需要JDK支持
1、下載JDK
http://download.oracle.com/otn-pub/java/jdk/7u79-b15/jdk-7u79-linux-x64.rpm
注意:直接復(fù)制到下載工具進(jìn)行下載,版本請使用JDK7,JDK8有可能不兼容kafka_2.11-0.8.2.1
下載完成之后,上傳到/usr/local/src目錄下
2、安裝JDK
cd /usr/local/src
chmod +x jdk-7u79-linux-x64.rpm # 添加執(zhí)行權(quán)限
rpm -ivh jdk-7u79-linux-x64.rpm #安裝
安裝完成之后,可以cd /usr/java/ 到安裝目錄查看
3、添加JDK到系統(tǒng)環(huán)境變量
vi /etc/profile #編輯,在最后添加以下代碼
JAVA_HOME=/usr/java/jdk1.7.0_79
PATH=$PATH:$JAVA_HOME/bin:/usr/bin:/usr/sbin:/bin:/sbin:/usr/X11R6/bin
CLASSPATH=.:$JAVA_HOME/lib/tools.jar:$JAVA_HOME/lib/dt.jar
export JAVA_HOME
export PATH
export CLASSPATH
:wq! #保存退出
source /etc/profile #使配置文件立即生效
java -version #查看JDK版本信息
到此,JDK安裝完成。
三、安裝kafka
1、下載kafka
cd /usr/local/src
wget http://archive.apache.org/dist/kafka/0.8.2.1/kafka_2.11-0.8.2.1.tgz
注意,kafka_2.11-0.8.2.1.tgz版本是已經(jīng)編譯好的版本,解壓就能使用。
tar -xzvf kafka_2.11-0.8.2.1.tgz #解壓
mv kafka_2.11-0.8.2.1 /usr/local/kafka #移動到安裝目錄
2、配置kafka
mkdir /usr/local/kafka/log/kafka #創(chuàng)建kafka日志目錄
cd /usr/local/kafka/config #進(jìn)入配置目錄
vi server.properties #編輯修改相應(yīng)的參數(shù)
broker.id=0
port=9092 #端口號
host.name=192.168.0.11 #服務(wù)器IP地址,修改為自己的服務(wù)器IP
log.dirs=/usr/local/kafka/log/kafka #日志存放路徑,上面創(chuàng)建的目錄
zookeeper.connect=localhost:2181 #zookeeper地址和端口,單機(jī)配置部署,localhost:2181
:wq! #保存退出
3、配置zookeeper
mkdir /usr/local/kafka/zookeeper #創(chuàng)建zookeeper目錄
mkdir /usr/local/kafka/log/zookeeper #創(chuàng)建zookeeper日志目錄
cd /usr/local/kafka/config #進(jìn)入配置目錄
vi zookeeper.properties #編輯修改相應(yīng)的參數(shù)
dataDir=/usr/local/kafka/zookeeper #zookeeper數(shù)據(jù)目錄
dataLogDir=/usr/local/kafka/log/zookeeper #zookeeper日志目錄
clientPort=2181
maxClientCnxns=100
tickTime=2000
initLimit=10
syncLimit=5
:wq! #保存退出
四、創(chuàng)建啟動、關(guān)閉kafka腳本
cd /usr/local/kafka
#創(chuàng)建啟動腳本
vi kafkastart.sh #編輯,添加以下代碼
#!/bin/sh
#啟動zookeeper
/usr/local/kafka/bin/zookeeper-server-start.sh /usr/local/kafka/config/zookeeper.properties &
sleep 3 #等3秒后執(zhí)行
#啟動kafka
/usr/local/kafka/bin/kafka-server-start.sh /usr/local/kafka/config/server.properties &
:wq! #保存退出
#創(chuàng)建關(guān)閉腳本
vi kafkastop.sh #編輯,添加以下代碼
#!/bin/sh
#關(guān)閉zookeeper
/usr/local/kafka/bin/zookeeper-server-stop.sh /usr/local/kafka/config/zookeeper.properties &
sleep 3 #等3秒后執(zhí)行
#關(guān)閉kafka
/usr/local/kafka/bin/kafka-server-stop.sh /usr/local/kafka/config/server.properties &
:wq! #保存退出
#添加腳本執(zhí)行權(quán)限
chmod +x kafkastart.sh
chmod +x kafkastop.sh
五、設(shè)置腳本開機(jī)自動執(zhí)行
vi /etc/rc.d/rc.local #編輯,在最后添加一行
sh /usr/local/kafka/kafkastart.sh & #設(shè)置開機(jī)自動在后臺運行腳本
:wq! #保存退出
sh /usr/local/kafka/kafkastart.sh #啟動kafka
sh /usr/local/kafka/kafkastop.sh #關(guān)閉kafka
至此,Linux下Kafka單機(jī)安裝配置完成。
擴(kuò)展閱讀:
Kafka創(chuàng)建topic
/usr/local/kafka/bin/kafka-topics.sh --create --zookeeper localhost:2181 --replication-factor 1 --partitions 1 --topic test
/usr/local/kafka/bin/kafka-topics.sh --list --zookeeper localhost:2181 test
/usr/local/kafka/bin/kafka-console-producer.sh --broker-list localhost:9092 --topic test --from-beginning
相關(guān)文章
ubuntu+php環(huán)境下的Memcached 安裝方法
Memcached是一套分散式的高速緩存系統(tǒng),當(dāng)初是Danga Interactive為了LiveJournal所發(fā)展2011-11-11IO多路復(fù)用之epoll全面總結(jié)(必看篇)
下面小編就為大家?guī)硪黄狪O多路復(fù)用之epoll全面總結(jié)(必看篇)。小編覺得挺不錯的?,F(xiàn)在就分享給大家。也給大家做個參考。一起跟隨小編過來看看吧2016-12-12linux系統(tǒng)之間通過nfs網(wǎng)絡(luò)文件系統(tǒng)掛載設(shè)置方法
NFS允許一個系統(tǒng)在網(wǎng)絡(luò)上與他人共享目錄和文件,通過使用NFS,用戶和程序可以像訪問本地文件一樣訪問遠(yuǎn)端系統(tǒng)上的文件,下面介紹linux系統(tǒng)之間通過nfs網(wǎng)絡(luò)文件系統(tǒng)掛載的設(shè)置方法2014-01-01阿里云 CentOS7.4 安裝 Python3.6的方法講解
下面小編就為大家分享一篇阿里云 CentOS7.4 安裝 Python3.6的方法講解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-01-01Ubuntu下Sublime Text無法輸入中文最簡單的解決方案
今天小編就為大家分享一篇關(guān)于Ubuntu下Sublime Text無法輸入中文最簡單的解決方案,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧2018-10-10Linux下Mysql定時任務(wù)備份數(shù)據(jù)的實現(xiàn)方法
當(dāng)安裝完成操作系統(tǒng)之后,默認(rèn)便會啟動此任務(wù)調(diào)度命令。下面這篇文章主要給大家介紹了關(guān)于在Linux下Mysql定時任務(wù)備份數(shù)據(jù)的實現(xiàn)方法,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考下2018-11-1180端口被system占用導(dǎo)致Apache無法啟動的解決方法
本文給大家介紹80端口被system占用導(dǎo)致Apache無法啟動的解決方法,非常不錯,一起看看吧2016-12-12