ZooKeeper是一個分佈式服務協調框架,能夠用來維護分佈式配置信息、服務註冊中心、實現分佈式鎖等。在Hbase、Hadoop、kafka等項目中都有普遍的應用。隨着分佈式、微服務的普及,ZooKeeper已經成爲咱們平常開發工做中沒法繞過的一環,本文將從安裝配置到最基礎的使用入手,對其進行介紹。apache
在 http://mirror.bit.edu.cn/apache/zookeeper/stable/ 下載推薦的stable版本。能夠直接下載編譯好的bin文件。
目前最新的stable版本是3.5.5服務器
將下載的文件解壓至工做目錄,個人工做目錄是/var/workspace/zookeepersession
tar -xzvf apache-zookeeper-3.5.5-bin.tar.gz -C /var/workspace/zookeeper
此時若是直接啓動zookeeper是會失敗的,提示找不到zoo.cfg文件。併發
須要咱們把conf目錄中提供的zoo_sample.cfg示例配置文件,複製爲一份zoo.cfg,zoo.cfg是默認的啓動配置文件框架
cp ../conf/zoo_sample.cfg ../conf/zoo.cfg
默認啓動,使用config/zoo.cfg配置文件在後臺啓動分佈式
前臺啓動,會將啓動日誌打印在終端。終端關閉後服務也關閉。微服務
使用zcCli.sh -server host:port 訪問ZooKeeper服務器。
不加-server參數時,默認使用127.0.0.1:2181oop
ZooKeeper使用相似資源文件目錄的方式來管理節點,每一個節點能夠存儲數據。
ZooKeeper有四種不一樣類型的節點:學習
使用zkCli.sh鏈接到服務端後,可使用help展現常見命令的使用方式。url
列出某個路徑下的節點
可使用create {path} 建立節點。
使用 create -s {path} 能夠建立有序節點,後面添加十位遞增的數字後綴。
使用 create -e 建立臨時節點,當斷開鏈接後,臨時節點會被刪除。
ZooKeeper的節點能夠存儲數據,使用set 方法將數據存在節點中。
使用get 方法,從節點中獲取數據。
set -v {currentVersion} {path} {data}
節點的數據每次更新時,都會遞增,若是要更新節點,請使用上面的命令修改,若是currentVersion不是最新版本時,則更新失敗,相似樂觀鎖CAS。
能夠經過delete刪除節點。
經過上面的學習,咱們已經學會了ZooKeeper最基本的安裝部署及使用方式。須要牢記:
原文連接 本文爲雲棲社區原創內容,未經容許不得轉載。