How to do - ubuntu下安裝和部署zookeeper(最強(qiáng)解析

ZooKeeper的安裝部署

安裝環(huán)境:

Linux ubuntu 4.4.0-87-generic #110-Ubuntu SMP Tue Jul 18 12:55:35 UTC 2017 x86_64 x86_64 x86_64 GNU/Linux

預(yù)置條件:安裝jdk降狠,ubuntu上:sudo apt-get update / sudo apt-get install openjdk-8-jdk

Step1 :下載杠巡,目前穩(wěn)定版本是3.5.5,連接地址是:http://apache.claz.org/zookeeper/stable/apache-zookeeper-3.5.5-bin.tar.gz

wget http://apache.claz.org/zookeeper/stable/apache-zookeeper-3.5.5-bin.tar.gz

Step2:解壓和配置

tar -xzvf apache-zookeeper-3.5.5-bin.tar.gz

mv apache-zookeeper-3.5.5-bin /usr/local/zookeeper

cp conf/zoo_sample.cfg conf/zoo.cfg

配置參數(shù)含義如下:

tickTime=2000

dataDir=/var/zookeeper/data

dataLogDir=/var/zookeeper/log

clientPort=2181

initLimit=5

syncLimit=2

maxClientCnxns=60

tickTime : ZooKeeper 中使用的基本時間單元, 以毫秒為單位, 默認(rèn)值是 2000惑畴。它用來調(diào)節(jié)心跳和超時黍少。例如, 默認(rèn)的會話超時時間是兩倍的 tickTime寡夹。

dataDir : ZooKeeper 用來存儲內(nèi)存數(shù)據(jù)庫快照的目錄。

dataLogDir: 數(shù)據(jù)庫更新的事物日志保存的目錄厂置,如果沒有設(shè)置該目錄菩掏,否則數(shù)據(jù)庫更新的事務(wù)日志也將會存儲在dataDir目錄下。建議配置 dataLogDir 參數(shù)來指定 ZooKeeper 事務(wù)日志的存儲目錄昵济。

clientPort:ZooKeeper服務(wù)監(jiān)聽的端口智绸。

initLimit: 默認(rèn)值是 10, 即 tickTime 屬性值的 10 倍。它用于配置允許 followers 連接并同步到 leader 的最大時間访忿。如果 ZooKeeper 管理的數(shù)據(jù)量很大的話可以增加這個值瞧栗。

syncLimit: 默認(rèn)值是 5, 即 tickTime 屬性值的 5 倍。它用于配置leader 和 followers 間進(jìn)行心跳檢測的最大延遲時間醉顽。如果在設(shè)置的時間內(nèi) followers 無法與 leader 進(jìn)行通信, 那么 followers 將會被丟棄沼溜。

maxClientCnxns: 在 socket 級別限制單個客戶端與單臺服務(wù)器之前的并發(fā)連接數(shù)量, 可以通過 IP 地址來區(qū)分不同的客戶端。它用來防止某種類型的 DoS 攻擊, 包括文件描述符耗盡游添。默認(rèn)值是 60系草。將其設(shè)置為 0 將完全移除并發(fā)連接數(shù)的限制。

更多配置信息請參考:?https://zookeeper.apache.org/doc/current/zookeeperAdmin.html#sc_configuration

Step3:啟動ZooKeeper服務(wù):

啟動方式如下:

cd bin

zkServer.sh start

Step4:測試ZooKeeper服務(wù)

測試方式:

./zkCli.sh

發(fā)現(xiàn)2181端口綁定在ipv6的地址上唆涝,導(dǎo)致我們使用ipv4連接不了

root@ubuntu:/usr/local/zookeeper/bin# netstat -antp

Active Internet connections (servers and established)

Proto Recv-Q Send-Q Local Address? ? ? ? ? Foreign Address? ? ? ? State? ? ? PID/Program name

tcp? ? ? ? 0? ? ? 0 0.0.0.0:22? ? ? ? ? ? ? 0.0.0.0:*? ? ? ? ? ? ? LISTEN? ? ? 955/sshd

tcp? ? ? ? 0? ? ? 0 127.0.0.1:6010? ? ? ? ? 0.0.0.0:*? ? ? ? ? ? ? LISTEN? ? ? 1194/0

tcp? ? ? ? 0? ? ? 0 192.168.1.4:22? ? ? ? ? 192.168.1.3:34542? ? ? ESTABLISHED 1154/sshd: lizhiyon

tcp? ? ? ? 0? ? ? 0 192.168.1.4:22? ? ? ? ? 192.168.1.3:34541? ? ? ESTABLISHED 1152/sshd: lizhiyon

tcp6? ? ? 0? ? ? 0 :::42863? ? ? ? ? ? ? ? :::*? ? ? ? ? ? ? ? ? ? LISTEN? ? ? 1274/java

tcp6? ? ? 0? ? ? 0 :::8080? ? ? ? ? ? ? ? :::*? ? ? ? ? ? ? ? ? ? LISTEN? ? ? 1274/java

tcp6? ? ? 0? ? ? 0 :::22? ? ? ? ? ? ? ? ? :::*? ? ? ? ? ? ? ? ? ? LISTEN? ? ? 955/sshd

tcp6? ? ? 0? ? ? 0 ::1:6010? ? ? ? ? ? ? ? :::*? ? ? ? ? ? ? ? ? ? LISTEN? ? ? 1194/0

tcp6? ? ? 0? ? ? 0 :::2181? ? ? ? ? ? ? ? :::*? ? ? ? ? ? ? ? ? ? LISTEN? ? ? 1274/java


? ? 解決辦法:

vim zkServer.sh找都;

在start)部分找到“ nohup $JAVA "-Dzookeeper.log.dir=${ZOO_LOG_DIR}"”,給其添加一個選項"-Djava.net.preferIPv4Stack=true"廊酣,這樣啟動的時候就會自動綁定IPV4端的IP能耻;

Step 5 : 開機(jī)自啟動

在/etc/init.d目錄下創(chuàng)建zookeeper文件,在文件里輸入以下內(nèi)容,當(dāng)然要注意JAVA_HOME的路徑要跟你自己的環(huán)境一致:

#!/bin/bash

#Configurations injected by install_server below....

EXEC=/usr/local/zookeeper/bin/zkServer.sh

JAVA_HOME=/usr/lib/jvm/java-8-openjdk-amd64

PATH=${JAVA_HOME}/bin:$PATH

###############

# SysV Init Information

# chkconfig: - 58 74

# description: zookeeper is the zookeeper daemon.

### BEGIN INIT INFO

# Provides: zookeeper

# Required-Start: $network $local_fs $remote_fs

# Required-Stop: $network $local_fs $remote_fs

# Default-Start: 2 3 4 5

# Default-Stop: 0 1 6

# Should-Start: $syslog $named

# Should-Stop: $syslog $named

# Short-Description: start and stop zookeeper

# Description: zookeeper daemon

### END INIT INFO

case $1 in

? ? ? ? start) su root /usr/local/zookeeper/bin/zkServer.sh start;;

? ? ? ? stop) su root /usr/local/zookeeper/bin/zkServer.sh stop;;

? ? ? ? status) su root /usr/local/zookeeper/bin/zkServer.sh status;;

? ? ? ? restart) su /usr/local/zookeeper/bin/zkServer.sh restart;;

? ? ? ? *) echo "require start|stop|status|restart" ;;

esac

然后添加zookeeper服務(wù):

在Ubuntu中晓猛,/etc/init.d已被/usr/lib/systemd所取代饿幅。腳本仍然可以通過“服務(wù)”啟動和停用。但主要命令現(xiàn)在是'systemctl'戒职。chkconfig命令被留下栗恩,現(xiàn)在你用systemctl來做這件事。

所以洪燥,而不是:

chkconfig enable zookeeper

而應(yīng)該查找服務(wù)名稱磕秤,然后啟用它

systemctl status zookeeper

systemctl enable zookeeper.service


視頻教程? ???戳這里~

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市捧韵,隨后出現(xiàn)的幾起案子市咆,更是在濱河造成了極大的恐慌,老刑警劉巖再来,帶你破解...
    沈念sama閱讀 219,427評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件蒙兰,死亡現(xiàn)場離奇詭異,居然都是意外死亡其弊,警方通過查閱死者的電腦和手機(jī)癞己,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,551評論 3 395
  • 文/潘曉璐 我一進(jìn)店門膀斋,熙熙樓的掌柜王于貴愁眉苦臉地迎上來梭伐,“玉大人,你說我怎么就攤上這事仰担『叮” “怎么了?”我有些...
    開封第一講書人閱讀 165,747評論 0 356
  • 文/不壞的土叔 我叫張陵摔蓝,是天一觀的道長赂苗。 經(jīng)常有香客問我,道長贮尉,這世上最難降的妖魔是什么拌滋? 我笑而不...
    開封第一講書人閱讀 58,939評論 1 295
  • 正文 為了忘掉前任,我火速辦了婚禮猜谚,結(jié)果婚禮上败砂,老公的妹妹穿的比我還像新娘。我一直安慰自己魏铅,他們只是感情好昌犹,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,955評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著览芳,像睡著了一般斜姥。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,737評論 1 305
  • 那天铸敏,我揣著相機(jī)與錄音缚忧,去河邊找鬼。 笑死杈笔,一個胖子當(dāng)著我的面吹牛搔谴,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播桩撮,決...
    沈念sama閱讀 40,448評論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼敦第,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了店量?” 一聲冷哼從身側(cè)響起芜果,我...
    開封第一講書人閱讀 39,352評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎融师,沒想到半個月后右钾,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,834評論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡旱爆,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,992評論 3 338
  • 正文 我和宋清朗相戀三年舀射,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片怀伦。...
    茶點(diǎn)故事閱讀 40,133評論 1 351
  • 序言:一個原本活蹦亂跳的男人離奇死亡脆烟,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出房待,到底是詐尸還是另有隱情邢羔,我是刑警寧澤,帶...
    沈念sama閱讀 35,815評論 5 346
  • 正文 年R本政府宣布桑孩,位于F島的核電站拜鹤,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏流椒。R本人自食惡果不足惜敏簿,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,477評論 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望宣虾。 院中可真熱鬧惯裕,春花似錦、人聲如沸安岂。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,022評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽域那。三九已至咙边,卻和暖如春猜煮,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背败许。 一陣腳步聲響...
    開封第一講書人閱讀 33,147評論 1 272
  • 我被黑心中介騙來泰國打工王带, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人市殷。 一個月前我還...
    沈念sama閱讀 48,398評論 3 373
  • 正文 我出身青樓愕撰,卻偏偏與公主長得像,于是被迫代替她去往敵國和親醋寝。 傳聞我的和親對象是個殘疾皇子搞挣,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,077評論 2 355

推薦閱讀更多精彩內(nèi)容