zookeeper的安裝、配置與使用

一、zookeeper架構

zookeeper服務器端運行於兩種模式下:獨立模式(standalone)和仲裁模式(quorum)。獨立模式:有一個單獨的服務器,zookeeper狀態沒法複製。仲裁模式:具備一組zookeeper服務器,咱們稱爲zookeeper集羣(zookeeper ensemble),它們以前能夠進行狀態的複製,並同時服務於客戶端的請求。node

二、開始使用zookeeper

下載地址:https://archive.apache.org/dist/zookeeper/zookeeper-3.5.5/apache-zookeeper-3.5.5-bin.tar.gz
zookeeper是用Java語言編寫的,系統中必定要安裝jdk才能啓動zookeeper。
首先咱們以獨立模式運行zookeeper並建立一個會話。
上傳至Linux服務器,解壓:apache

[root@localhost opt]# tar xvf apache-zookeeper-3.5.5-bin.tar.gz -C /opt/

若是使用的是Windows系統,可使用winzip的解壓縮工具進行解壓發行包。vim

在發行包(distribution)的目錄中,你會發如今bin目錄中有啓動zookeeper的腳本。以.sh結尾的腳步運行在Unix平臺,以.cmd結尾的腳本則用於Windows。在conf目錄中保存配置文件 。lib目錄包括Java的jar文件,它們是運行zookeeper所須要的第三方支持。
修改配置文件:服務器

[root@localhost zookeeper]# cd conf/
[root@localhost conf]# mv zoo_sample.cfg zoo.cfg
[root@localhost conf]# vim zoo.cfg
dataDir=/opt/zookeeper/dataDir

官方不推薦使用默認的dataDir,修改dataDir保存退出。
zookeeper的配置項:
zookeeper的配置項在zoo.cfg配置文件中配置,另外有些配置能夠經過Java系統屬性來進行配置。下面列出了3個重要的配置項:session

  • clientPort:zookeeper對客戶端提供服務的端口
  • dataDir:用來保存快照文件的目錄。若是沒有設置dataLogDir,事務日誌也會保存到這個目錄
  • dataLogDir:用來保存事務日誌文件的目錄。由於zookeeper在提交一個事務以前,須要保證事務日誌記錄的落盤,因此須要爲dataLogDir分配一個獨佔的存儲設備。

啓動服務器,執行以下命令:架構

[root@localhost conf]# cd ..
[root@localhost zookeeper]# bin/zkServer.sh start
ZooKeeper JMX enabled by default
Using config: /opt/zookeeper/bin/../conf/zoo.cfg
Starting zookeeper ... STARTED

這個服務器端命令使得zookeeper服務器在後臺中運行。若是在前臺運行以便查看服務器輸出,可使用如下命令運行:dom

[root@localhost zookeeper]# bin/zkServer.sh start-foreground

這個選項提供了大量詳細信息的輸出,以便容許查看服務器發生了什麼。
啓動後,查看日誌文件是否有報錯信息:ide

[root@localhost zookeeper]# cd logs/
[root@localhost logs]# ll
total 8
-rw-r--r-- 1 root root 7516 Oct 21 18:28 zookeeper-root-server-localhost.localdomain.out
[root@localhost logs]# grep -E -i "((exception)|(error))" *

查詢結果爲空,則沒有報錯信息。
如今使用zookeeper客戶端鏈接zookeeper服務器,運行以下命令:工具

[root@localhost zookeeper]# bin/zkCli.sh
.........
2019-10-21 18:37:35,242 [myid:localhost:2181] - INFO  [main-SendThread(localhost:2181):ClientCnxn$SendThread@959] - Socket connection established, initiating session, client: /0:0:0:0:0:0:0:1:39276, server: localhost/0:0:0:0:0:0:0:1:2181
2019-10-21 18:37:35,308 [myid:localhost:2181] - INFO  [main-SendThread(localhost:2181):ClientCnxn$SendThread@1394] - Session establishment complete on server localhost/0:0:0:0:0:0:0:1:2181, sessionid = 0x1000132e0500000, negotiated timeout = 30000

WATCHER::

WatchedEvent state:SyncConnected type:None path:null
[zk: localhost:2181(CONNECTED) 0]

經過上面信息,得知zookeeper客戶端與服務器端創建的鏈接。ui

三、zookeeper基本命令

查看根(root)下的全部znode:

[zk: localhost:2181(CONNECTED) 3] ls -R /
/
/zookeeper
/zookeeper/config
/zookeeper/quota

建立一個名爲workers的znode:

[zk: localhost:2181(CONNECTED) 4] create /workers
Created /workers
[zk: localhost:2181(CONNECTED) 7] ls -R /
/
/workers
/zookeeper
/zookeeper/config
/zookeeper/quota

刪除建立的workers節點,並退出zkCli:

[zk: localhost:2181(CONNECTED) 8] delete /workers
[zk: localhost:2181(CONNECTED) 9] ls -R /
/
/zookeeper
/zookeeper/config
/zookeeper/quota
[zk: localhost:2181(CONNECTED) 10] quit

WATCHER::

WatchedEvent state:Closed type:None path:null
2019-10-21 19:35:46,321 [myid:] - INFO  [main:ZooKeeper@1422] - Session: 0x1000132e0500000 closed
2019-10-21 19:35:46,322 [myid:] - INFO  [main-EventThread:ClientCnxn$EventThread@524] - EventThread shut down for session: 0x1000132e0500000

關閉zookeeper服務器:

[root@localhost zookeeper]# bin/zkServer.sh stop
ZooKeeper JMX enabled by default
Using config: /opt/zookeeper/bin/../conf/zoo.cfg
Stopping zookeeper ... STOPPED

經過查看zkServer.sh腳本得知可接受6個參數,以下:start:啓動服務start-foreground:前臺啓動服務print-cmd:打印命令行信息stop:中止服務restart:重啓服務(先中止,後啓動)status:服務狀態

相關文章
相關標籤/搜索