【分佈式協調zookeeper】部署篇

1、環境準備

操做系統:centOS-6.8 2.6.32-642.el6.x86_64【虛擬機環境】
節點主機:10.0.55.三、10.0.55.五、10.0.55.6
目錄結構: /opt/
軟件版本:   jdk-7u67-linux-x64.rpm
            zookeeper-3.5.0-alpha.tar.gz

2、安裝Java環境

$ rpm -ivh jdk-7u67-linux-x64.rpm 
$ cat /etc/profile
export JAVA_HOME=/usr/java/jdk1.7.0_67
export CLASSPATH=$CLASSPATH:$JAVA_HOME/lib:$JAVA_HOME/jre/lib
export PATH=$JAVA_HOME/bin:$JAVA_HOME/jre/bin:$PATH:$HOME/bin
當即生效
$ source /etc/profile

3、下載zookeeper包並建立zookeeper管理數據

$ wget http://archive.apache.org/dist/zookeeper/zookeeper-3.5.0-alpha/zookeeper-3.5.0-alpha.tar.gz
$ ln -s /opt/zookeeper-3.5.0-alpha /opt/zookeeper
$ mkdir /opt/zookeeper/data
$ echo "1" > /opt/zookeeper/data/myid

4、編輯zookeeper/conf/zoo.cfg配置文件,啓動時須要

$ cp /opt/zookeeper/conf/zoo_sample.cfg /opt/zookeeper/conf/zoo.cfg
--- 查看zoo.cfg內容 ---
tickTime=2000
initLimit=10
syncLimit=5
dataDir=/opt/zookeeper/data
clientPort=2181
server.1=10.0.55.3:2888:3888
server.2=10.0.55.5:2888:3888
server.3=10.0.55.6:2888:3888

5、啓動zookeeper服務並查看

--- 啓動服務 ---
$ /opt/zookeeper/bin/zkServer.sh start
JMX enabled by default
Using config: /opt/zookeeper/bin/../conf/zoo.cfg
Starting zookeeper ... STARTED

--- 檢查端口 ---
netstat -lnpt
Active Internet connections (only servers)
Proto Recv-Q Send-Q Local Address               Foreign Address             State       PID/Program name   
tcp        0      0 0.0.0.0:22678               0.0.0.0:*                   LISTEN      1074/sshd           
tcp        0      0 :::2181                     :::*                        LISTEN      121685/java         
tcp        0      0 :::55369                    :::*                        LISTEN      121685/java         
tcp        0      0 ::ffff:10.0.55.3:3888       :::*                        LISTEN      121685/java         
tcp        0      0 :::8080                     :::*                        LISTEN      121685/java         
tcp        0      0 :::22678                    :::*                        LISTEN      1074/sshd

使用自動化運維工具 ansible 進行批量分發

這裏只介紹如何使用ansible的命令組件模塊進行節點部署java

爲了節省篇幅,這裏不介紹ansible的部署安裝node

一、遠程安裝zookeeper節點

$ ansible webservers -m copy -a 'src=zookeeper-3.5.0-alpha.tar.gz dest=/opt/ owner=root group=root mode=0644'
$ ansible webservers -m shell -a 'tar fxz /opt/zookeeper-3.5.0-alpha.tar.gz -C /opt/'
$ ansible webservers -m shell -a 'ln -s /opt/zookeeper-3.5.0-alpha /opt/zookeeper'
$ ansible webservers -m shell -a 'mkdir /opt/zookeeper/data'
$ ansible webservers -m shell -a 'echo "2" >/opt/zookeeper/data/myid'

二、將配置文件copy到遠端節點

$ ansible webservers -m copy -a 'src=/opt/zookeeper/conf/zoo.cfg dest=/opt/zookeeper/conf/zoo.cfg owner=root group=root mode=0644'

三、批量啓動zookeeper服務並查看

$ ansible webservers -m shell -a '/opt/zookeeper/bin/zkServer.sh stats'
$ ansible webservers -m shell -a 'netstat -lnpt'

四、批量堅持zookeeper狀態

$ ansible webservers -m shell -a '/opt/zookeeper/bin/zkServer.sh status'
10.0.55.5 | SUCCESS | rc=0 >>
Client port found: 2181
Mode: leaderJMX enabled by default              ## 這裏面的mode信息中,該主機被選舉爲 Leader
Using config: /opt/zookeeper/bin/../conf/zoo.cfg

10.0.55.3 | SUCCESS | rc=0 >>
Client port found: 2181
Mode: followerJMX enabled by default            ## 這裏面的mode信息中,該主機被選舉爲 follower
Using config: /opt/zookeeper/bin/../conf/zoo.cfg

10.0.55.6 | SUCCESS | rc=0 >>
Client port found: 2181
Mode: followerJMX enabled by default            ## 這裏面的mode信息中,該主機被選舉爲 follower
Using config: /opt/zookeeper/bin/../conf/zoo.cfg

zookeeper基礎操做

啓動一個CLI客戶端
[root@lbl opt]# ./zookeeper/bin/zkCli.sh
建立、編輯、刪除znode
--- 建立一個/workers路徑的znode ---
[zk: localhost:2181(CONNECTED) 0] create /workers helloworld
Created /workers

--- 使用get -s命令查看znode數據 ---
[zk: localhost:2181(CONNECTED) 1] get -s /workers
helloworld
cZxid = 0x500000006
ctime = Sat Apr 22 10:33:42 CST 2017
mZxid = 0x500000006
mtime = Sat Apr 22 10:33:42 CST 2017
pZxid = 0x500000006
cversion = 0
dataVersion = 0
aclVersion = 0
ephemeralOwner = 0x0
dataLength = 6
numChildren = 0

--- 使用get -w選項,進行監聽/factory的變化 ---
[zk: localhost:2181(CONNECTED) 11] get -w /workers
strong

--- 在 follower節點上啓動客戶端,並修改/workers ---
[root@lbl bin]# ./zkCli.sh 
[zk: localhost:2181(CONNECTED) 2] set /workers weakness

---查看監聽那臺主機,返回的通知信息以下: ---
[zk: localhost:2181(CONNECTED) 12] 
WATCHER::

WatchedEvent state:SyncConnected type:NodeDataChanged path:/workers

--- 刪除workers的znode ---
[zk: localhost:2181(CONNECTED) 7] delete /workers

建立序列znode

[zk: localhost:2181(CONNECTED) 13] create -s /workers/worker-
Created /workers/worker-0000000000
[zk: localhost:2181(CONNECTED) 14] create -s /workers/worker-
Created /workers/worker-0000000001
[zk: localhost:2181(CONNECTED) 15] create -s /workers/worker-
Created /workers/worker-0000000002
[zk: localhost:2181(CONNECTED) 16] create -s /workers/worker-
Created /workers/worker-0000000003

經過stat命令,進行查看workers狀態

[zk: localhost:2181(CONNECTED) 18] stat /workers
cZxid = 0x500000006
ctime = Sat Apr 22 10:33:42 CST 2017
mZxid = 0x500000008
mtime = Sat Apr 22 10:35:25 CST 2017
pZxid = 0x50000000c
cversion = 4
dataVersion = 1
aclVersion = 0
ephemeralOwner = 0x0
dataLength = 8
numChildren = 4

經過瀏覽器查看zookeeper狀態

--- 從zookeeper-3.5.0版本以上,可使用http接口提交4字命令的請求;
--- 在zookeeper服務中嵌入了Jetty server做爲AdminServer管理服務器,其默認端口爲8080;
--- 服務訪問的URL格式是"/commands/[command name]",例如:訪問stats命令
--- 服務器返回的結果是以JSON格式顯示
http://10.0.55.3:8080/commands
http://10.0.55.3:8080/commands/stats

wKiom1lENBLRFspVAABPNi6dSQg152.png-wh_50

wKioL1lENBLxDMYBAABaRKPuFYw217.png-wh_50



【分佈式協調系統zookeeper】基礎篇linux

相關文章
相關標籤/搜索