ZooKeeper環境搭建(單機/集羣)(轉)

前提:html

配置文件主要是在$ZOOKEEPER_HOME/conf/zoo.cfg,剛解壓時爲zoo_sample.cfg,重命名zoo.cfg便可。linux

配置文件經常使用項參考:http://www.cnblogs.com/EasonJim/p/7483880.html數據庫

ZooKeeper基於Java開發,因此在運行前須要安裝JDK。服務器

環境搭建:session

1、ZooKeeper的搭建方式

ZooKeeper安裝方式有三種,單機模式集羣模式以及僞集羣模式併發

  • 單機模式:ZooKeeper只運行在一臺服務器上,適合測試環境;
  • 僞集羣模式:就是在一臺物理機上運行多個ZooKeeper 實例;
  • 集羣模式:ZooKeeper運行於一個集羣上,適合生產環境,這個計算機集羣被稱爲一個「集合體」(ensemble)

ZooKeeper經過複製來實現高可用性,只要集合體中半數以上的機器處於可用狀態,它就可以保證服務繼續。爲何必定要超過半數呢?這跟ZooKeeper的複製策略有關:ZooKeeper確保對ZNode樹的每個修改都會被複制到集合體中超過半數的機器上。ssh

1.一、ZooKeeper的單機模式搭建

下載ZooKeeper:http://www.cnblogs.com/EasonJim/p/7481710.html分佈式

解壓oop

tar -zxvf ZooKeeper-3.4.9.tar.gz 

移動到文件夾:性能

sudo mv ZooKeeper-3.4.9 /usr/local/zk 

配置文件:在conf目錄下刪除zoo_sample.cfg文件,建立一個配置文件zoo.cfg。

只關注如下幾項

tickTime=2000
dataDir=/usr/local/zk/data
dataLogDir=/usr/local/zk/logs        
clientPort=2181

注意:以上路徑的文件夾須要手動建立,且要賦予權限,而且不能放在/tmp文件夾。

建立文件夾:

#建立
sudo mkdir -p /usr/local/zk/data sudo mkdir -p /usr/local/zk/logs
#設置權限
sudo chmod -R 777 /usr/local/data
sudo chmod -R 777 /usr/local/logs 

配置環境變量:爲了從此操做方便,咱們須要對ZooKeeper的環境變量進行配置,方法以下在/etc/profile文件中加入以下內容:

export ZOOKEEPER_HOME=/usr/local/zk
export PATH=.:$HADOOP_HOME/bin:$ZOOKEEPER_HOME/bin:$JAVA_HOME/bin:$PATH

啓動ZooKeeper的Server:zkServer.sh start;關閉ZooKeeper的Server:zkServer.sh stop

1.二、ZooKeeper的僞集羣模式搭建

ZooKeeper不但能夠在單機上運行單機模式ZooKeeper,並且能夠在單機模擬集羣模式 ZooKeeper的運行,也就是將不一樣節點運行在同一臺機器。咱們知道僞分佈模式下Hadoop的操做和分佈式模式下有着很大的不一樣,可是在集羣爲分佈式模式下對ZooKeeper的操做卻和集羣模式下沒有本質的區別。顯然,集羣僞分佈式模式爲咱們體驗ZooKeeper和作一些嘗試性的實驗提供了很大的便利。好比,咱們在實驗的時候,能夠先使用少許數據在集羣僞分佈模式下進行測試。當測試可行的時候,再將數據移植到集羣模式進行真實的數據實驗。這樣不 但保證了它的可行性,同時大大提升了實驗的效率。這種搭建方式,比較簡便,成本比較低,適合測試和學習,若是你的手頭機器不足,就能夠在一臺機器上部署了 3個Server。

1.2.一、注意事項

在一臺機器上部署了3個Server,須要注意的是在集羣爲分佈式模式下咱們使用的每一個配置文檔模擬一臺機器,也就是說單臺機器及上運行多個ZooKeeper實例。可是,必須保證每一個配置文檔的各個端口號不能衝突,除了clientPort不一樣以外,dataDir也不一樣。另外,還要在dataDir所對應的目錄中建立myid文件來指定對應的ZooKeeper服務器實例。

  • clientPort端口:若是在1臺機器上部署多個Server,那麼每臺機器都要不一樣的clientPort,好比Server1是2181,Server2是2182,Server3是2183
  • dataDir和dataLogDir:dataDir和dataLogDir也須要區分下,將數據文件和日誌文件分開存放,同時每一個Server的這兩變量所對應的路徑都是不一樣的
  • server.X和myid: server.X這個數字就是對應,data/myid中的數字。在3個Server的myid文件中分別寫入了0,1,2,那麼每一個Server中的zoo.cfg都配server.0,server.2,server.3就好了。由於在同一臺機器上,後面連着的2個端口,3個Server都不要同樣,不然端口衝突。

下面是我所配置的集羣僞分佈模式,分別經過zoo1.cfg、zoo2.cfg、zoo3.cfg來模擬由三臺機器的ZooKeeper集羣

1.2.1.一、此時須要在/usr/local/zk/conf文件夾下建立三個文件zoo1.cfg、zoo2.cfg、zoo3.cfg

代碼清單zoo1.cfg以下:

# The number of milliseconds of each tick
tickTime=2000

# The number of ticks that the initial
# synchronization phase can take
initLimit=10

# The number of ticks that can pass between
# sending a request and getting an acknowledgement
syncLimit=5

# the directory where the snapshot is stored.
dataDir=/usr/local/zk/data_1

# the port at which the clients will connect
clientPort=2181

#the location of the log file
dataLogDir=/usr/local/zk/logs_1

server.0=localhost:2287:3387
server.1=localhost:2288:3388
server.2=localhost:2289:3389

代碼清單zoo2.cfg以下:

# The number of milliseconds of each tick
tickTime=2000

# The number of ticks that the initial
# synchronization phase can take
initLimit=10

# The number of ticks that can pass between
# sending a request and getting an acknowledgement
syncLimit=5

# the directory where the snapshot is stored.
dataDir=/usr/local/zk/data_2

# the port at which the clients will connect
clientPort=2182

#the location of the log file
dataLogDir=/usr/local/zk/logs_2

server.0=localhost:2287:3387
server.1=localhost:2288:3388
server.2=localhost:2289:3389

代碼清單zoo3.cfg以下:

# The number of milliseconds of each tick
tickTime=2000

# The number of ticks that the initial
# synchronization phase can take
initLimit=10

# The number of ticks that can pass between
# sending a request and getting an acknowledgement
syncLimit=5

# the directory where the snapshot is stored.
dataDir=/usr/local/zk/data_3

# the port at which the clients will connect
clientPort=2183

#the location of the log file
dataLogDir=/usr/local/zk/logs_3

server.0=localhost:2287:3387
server.1=localhost:2288:3388
server.2=localhost:2289:3389

1.2.1.二、在/usr/local/zk建立三個data_{1/2/3}、logs_{1/2/3}

#建立
sudo mkdir -p
/usr/local/zk/data_1 sudo mkdir -p /usr/local/zk/data_2 sudo mkdir -p /usr/local/zk/data_3 sudo mkdir -p /usr/local/zk/logs_1 sudo mkdir -p /usr/local/zk/logs_2 sudo mkdir -p /usr/local/zk/logs_3
#設置權限
sudo chmod -R 777 /usr/local/data_1
sudo chmod -R 777 /usr/local/data_2
sudo chmod -R 777 /usr/local/data_3
sudo chmod -R 777 /usr/local/logs_1
sudo chmod -R 777 /usr/local/logs_2
sudo chmod -R 777 /usr/local/logs_3

1.2.1.三、分別在data_{1/2/3}文件夾下建立myid文件,並寫入0/1/2

echo "0">/usr/local/data_1/myid
echo "1">/usr/local/data_2/myid
echo "2">/usr/local/data_3/myid

1.2.二、啓動

在集羣爲分佈式下,咱們只有一臺機器,按時要運行三個ZooKeeper實例。此時,若是在使用單機模式的啓動命令是行不通的。此時,只要經過下面三條命令就能運行前面所配置的ZooKeeper服務。以下所示:

zkServer.sh start zoo1.cfg
zkServer.sh start zoo2.cfg
zkServer.sh start zoo3.cfg

啓動過程,以下圖所示:

啓動結果,以下圖所示:

在運行完第一條指令以後,會出現一些錯誤異常,產生異常信息的緣由是因爲ZooKeeper服務的每一個實例都擁有全局配置信息,他們在啓動的時候會隨時隨地的進行Leader選舉操做。此時,第一個啓動的ZooKeeper須要和另外兩個ZooKeeper實例進行通訊。可是,另外兩個ZooKeeper實例尚未啓動起來,所以就產生了這的異樣信息。咱們直接將其忽略便可,待把圖中「2號」和「3號」ZooKeeper實例啓動起來以後,相應的異常信息天然會消失。此時,能夠經過下面三條命令,來查詢。

 zkServer.sh status zoo1.cfg
 zkServer.sh status zoo2.cfg
 zkServer.sh status zoo3.cfg

ZooKeeper服務的運行狀態,以下圖所示:

提示:若是以上配置複雜,那麼能夠直接拷貝三個ZooKeeper的運行目錄分別命令爲ZooKeeper_1/ZooKeeper_2/ZooKeeper_3

1.三、ZooKeeper的集羣模式搭建

爲了得到可靠地ZooKeeper服務,用戶應該在一個機羣上部署ZooKeeper。只要機羣上大多數的ZooKeeper服務啓動了,那麼總的ZooKeeper服務將是可用的。集羣的配置方式,和前兩種相似,一樣須要進行環境變量的配置。在每臺機器上conf/zoo.cfg配置文件的參數設置相同

1.3.一、建立myid

在dataDir(/usr/local/zk/data)目錄建立myid文件

Server0機器的內容爲:0

Server1機器的內容爲:1

Server2機器的內容爲:2

echo "0">/usr/local/data/myid
echo "1">/usr/local/data/myid
echo "2">/usr/local/data/myid

1.3.二、編寫配置文件

在conf目錄下刪除zoo_sample.cfg文件,建立一個配置文件zoo.cfg,以下所示,代碼清單zoo.cfg中的參數設置

# The number of milliseconds of each tick
tickTime=2000

# The number of ticks that the initial
# synchronization phase can take
initLimit=10

# The number of ticks that can pass between
# sending a request and getting an acknowledgement
syncLimit=5

# the directory where the snapshot is stored.
dataDir=/usr/local/zk/data

# the port at which the clients will connect
clientPort=2183

#the location of the log file
dataLogDir=/usr/local/zk/log

server.0=hadoop:2288:3388
server.1=hadoop0:2288:3388
server.2=hadoop1:2288:3388

說明:hadoop爲host指向的名稱,固然也能夠直接使用IP。

1.3.三、啓動

分別在3臺機器上啓動ZooKeeper的Server:zkServer.sh start;

2、ZooKeeper的配置

ZooKeeper的功能特性是經過ZooKeeper配置文件來進行控制管理的(zoo.cfg),這樣的設計其實有其自身的緣由,經過前面對ZooKeeper的配置能夠看出,在對ZooKeeper集羣進行配置的時候,它的配置文檔是徹底相同的。集羣僞分佈模式中,有少部分是不一樣的。這樣的配置方式使得在部署ZooKeeper服務的時候很是方便。若是服務器使用不一樣的配置文件,必須確保不一樣配置文件中的服務器列表相匹配。

在設置ZooKeeper配置文檔時候,某些參數是可選的,某些是必須的。這些必須參數就構成了ZooKeeper配置文檔的最低配置要求。另外,若要對ZooKeeper進行更詳細的配置,能夠參考下面的內容。

2.1 基本配置

下面是在最低配置要求中必須配置的參數:

①、client:監聽客戶端鏈接的端口。

②、tickTime:基本事件單元,這個時間是做爲ZooKeeper服務器之間或客戶端與服務器之間維持心跳的時間間隔,每隔tickTime時間就會發送一個心跳;最小 的session過時時間爲2倍tickTime   

③、dataDir:存儲內存中數據庫快照的位置,若是不設置參數,更新食物的日誌將被存儲到默認位置。

應該謹慎的選擇日誌存放的位置,使用專用的日誌存儲設備可以大大提升系統的性能,若是將日誌存儲在比較繁忙的存儲設備上,那麼將會很大程度上影響系統性能。

2.二、高級配置

下面是高級配置參數中可選配置參數,用戶可使用下面的參數來更好的規定ZooKeeper的行爲:

①、dataLogdDir

這個操做讓管理機器把事務日誌寫入「dataLogDir」所指定的目錄中,而不是「dataDir」所指定的目錄。這將容許使用一個專用的日誌設備,幫助咱們避免日誌和快照的競爭。配置以下:

# the directory where the snapshot is stored
dataDir=/usr/local/zk/data  

②、maxClientCnxns

這個操做將限制鏈接到ZooKeeper的客戶端數量,並限制併發鏈接的數量,經過IP來區分不一樣的客戶端。此配置選項能夠阻止某些類別的Dos攻擊。將他設置爲零或忽略不進行設置將會取消對併發鏈接的限制。

例如,此時咱們將maxClientCnxns的值設爲1,以下所示:

# set maxClientCnxns
maxClientCnxns=1

啓動ZooKeeper以後,首先用一個客戶端鏈接到ZooKeeper服務器上。以後若是有第二個客戶端嘗試對ZooKeeper進行鏈接,或者有某些隱式的對客戶端的鏈接操做,將會觸發ZooKeeper的上述配置。

③、minSessionTimeoutmaxSessionTimeout

即最小的會話超時和最大的會話超時時間。在默認狀況下,minSession=2*tickTime;maxSession=20*tickTime。

2.3 集羣配置

①、initLimit

此配置表示,容許follower(相對於Leaderer言的「客戶端」)鏈接並同步到Leader的初始化鏈接時間,以tickTime爲單位。當初始化鏈接時間超過該值,則表示鏈接失敗。

②、syncLimit

此配置項表示Leader與Follower之間發送消息時,請求和應答時間長度。若是Follower在設置時間內不能與Leader通訊,那麼此Follower將會被丟棄。

③、server.A=B:C:D

A:其中A是一個數字,表示這個是服務器的編號;

B:是這個服務器的IP地址;

C:Leader選舉的端口;

D:ZooKeeper服務器之間的通訊端口。

④、myidzoo.cfg

除了修改zoo.cfg配置文件,集羣模式下還要配置一個文件myid,這個文件在dataDir目錄下,這個文件裏面就有一個數據就是A的值,ZooKeeper啓動時會讀取這個文件,拿到裏面的數據與zoo.cfg裏面的配置信息比較從而判斷究竟是那個Server。

3、搭建ZooKeeper服務器集羣(搭建實例)

說明:如下命令要注意權限,非root用戶下要加sudo

搭建要求:

一、ZK服務器集羣規模不小於3個節點,推薦2*N+1。

二、要求各服務器之間系統時間要保持一致。

3.一、安裝配置ZK

①、使用WinScp將Zk傳輸到Hadoop主機上的/usr/local,我用的版本是ZooKeeper-3.4.5.tar.gz。

②、在hadoop的/usr/local目錄下,解壓縮zk....tar.gz,設置環境變量

解壓縮:在/usr/local目錄下,執行命令:tar -zxvf ZooKeeper-3.4.5.tar.gz,以下圖所示:

重命名:解壓後將文件夾,重命名爲zk,執行命令: mv ZooKeeper-3.4.5 zk,以下圖所示:

設置環境變量:執行命令: vi /etc/profile ,添加 :export ZOOKEEPER_HOME=/usr/local/zk,如圖2.3所示的內容。執行命令:source /etc/profile 以下圖所示:

2.二、修改ZK配置文件

①、重命名:將/usr/local/zk/conf目錄下zoo_sample.cfg,重命名爲zoo.cfg,執行命令:mv zoo_sample.cfg zoo.cfg。如以下圖所示:

②、查看:在/usr/local/zk/conf目錄下,修改文件vi zoo.cfg,文件內容以下圖所示。在該文件中dataDir表示文件存放目錄,它的默認設置爲/tmp/ZooKeeper這是一個臨時存放目錄,每次重啓後會丟失,在這咱們本身設一個目錄,/usr/local/zk/data。

③、建立文件夾:mkdir /usr/local/zk/data

④、建立myid:在data目錄下,建立文件myid,值爲0;vi myid ;內容爲0。

⑤、編輯:編輯該文件,執行vi zoo.cfg ,修改dataDir=/usr/local/zk/data。

新增

server.0=hadoop:2888:3888
server.1=hadoop0:2888:3888
server.2=hadoop1:2888:3888

tickTime :這個時間是做爲ZooKeeper服務器之間或客戶端與服務器之間維持心跳的時間間隔,也就是每一個tickTime 時間就會發送一個心跳;

dataDir:顧名思義就是ZooKeeper保存數據的目錄,默認狀況下,ZooKeeper將寫數據的日誌文件也保存在這個目錄裏;

clientPort:這個端口就是客戶端鏈接ZooKeeper服務器的端口,ZooKeeper會監聽這個端口,接受客戶端的訪問請求。

當這些配置項配置好後,就能夠啓動ZooKeeper了,啓動後使用命令echo ruok | nc localhost 2181檢查ZooKeeper是否已經在服務。

2.三、配置其餘節點

①、把haooop主機的zk目錄和/etc/profile目錄,複製到hadoop0和hadoop1中。執行命令:

scp -r /usr/local/zk/ hadoop0:/usr/local/
scp -r /usr/local/zk/ hadoop1:/usr/local/
scp /etc/profile hadoop0:/etc/
scp /etc/profile hadoop1:/etc/

ssh hadoop0
suorce /etc/profile
vi /usr/local/zk/data/myid
exit

ssh hadoop1
suorce /etc/profile
vi /usr/local/zk/data/myid
exit

②、把hadoop1中相應的myid的值改成1,把hadoop2中相應的myid的值改成2。   

4、啓動檢驗

一、啓動,在三個節點上分別執行命令zkServer.sh start

hadoop節點

hadoop0節點

hadoop1節點

二、檢驗,在三個節點上分別執行命令zkServer.sh status,從下面的圖中咱們會發現hadoop和hadoop1爲Follower,hadoop0爲Leader。

hadoop節點

hadoop0節點

hadoop1節點

 

參考:

http://www.cnblogs.com/sunddenly/p/4018459.html(以上內容大部分轉自此篇文章)

http://www.cnblogs.com/qizhelongdeyang/p/6901560.html

http://blog.csdn.net/lemon_tree12138/article/details/51445689

http://blog.sina.com.cn/s/blog_790c59140102w5h1.html

http://blog.csdn.net/shirdrn/article/details/7183503/

http://blog.csdn.net/yinkgh/article/details/52301063

http://www.cnblogs.com/linuxprobe/p/5851699.html

http://www.linuxidc.com/Linux/2015-02/114230.htm

http://www.cnblogs.com/huangxincheng/p/5654170.html

http://www.linuxidc.com/Linux/2013-04/83562.htm

http://www.cnblogs.com/z-sm/p/5691752.html

http://nileader.blog.51cto.com/1381108/795230

http://data.qq.com/article?id=2863

http://blog.csdn.net/tanyujing/article/details/8504481

http://blog.csdn.net/poechant/article/details/6633923

相關文章
相關標籤/搜索