經過./zkCli.sh 打開zk的客戶端進入命令行後臺node
[zk: localhost:2181(CONNECTED) 5] ls2 / [cluster, controller_epoch, brokers, zookeeper, admin, isr_change_notification, consumers, log_dir_event_notification, latest_producer_id_block, config] cZxid = 0x0 ctime = Thu Jan 01 08:00:00 CST 1970 mZxid = 0x0 mtime = Thu Jan 01 08:00:00 CST 1970 pZxid = 0x4e cversion = 14 dataVersion = 0 aclVersion = 0 ephemeralOwner = 0x0 dataLength = 0 numChildren = 10
[zk: localhost:2181(CONNECTED) 6] stat / cZxid = 0x0 ctime = Thu Jan 01 08:00:00 CST 1970 mZxid = 0x0 mtime = Thu Jan 01 08:00:00 CST 1970 pZxid = 0x4e cversion = 14 dataVersion = 0 aclVersion = 0 ephemeralOwner = 0x0 dataLength = 0 numChildren = 10
[zk: localhost:2181(CONNECTED) 8] get /zookeeper cZxid = 0x0 #該節點建立(Create)時的id ctime = Thu Jan 01 08:00:00 CST 1970 mZxid = 0x0 #該節點修改(Modify)後的id mtime = Thu Jan 01 08:00:00 CST 1970 pZxid = 0x0 #子節點列表最後一次被修改的事務id cversion = -1 #子節點的版本號 dataVersion = 0 #當前節點數據的版本號 節點數據改變時這個值會變化 aclVersion = 0 # 權限版本, 權限發生變化時版本號回發生變化 ephemeralOwner = 0x0 dataLength = 0 #數據長度 numChildren = 1 #子節點數量
客戶端與服務端之間的連接存在Session(會話)shell
每一個會話能夠設置一個超時時間session
心跳機制: 客戶端向服務端的ping包請求併發
心跳結束, session則過時命令行
Session過時, 則臨時節點znode會被拋棄code
create命令對象
[zk: localhost:2181(CONNECTED) 10] create /czk czk-data #建立永久節點 Created /czk [zk: localhost:2181(CONNECTED) 11] get /czk czk-data cZxid = 0x50 ctime = Sat Dec 29 17:17:53 CST 2018 mZxid = 0x50 mtime = Sat Dec 29 17:17:53 CST 2018 pZxid = 0x50 cversion = 0 dataVersion = 0 aclVersion = 0 ephemeralOwner = 0x0 dataLength = 12 numChildren = 0
[zk: localhost:2181(CONNECTED) 12] create -e /czk/tmp czk-data Created /itheima/tmp [zk: localhost:2181(CONNECTED) 13] get /czk itheima-data cZxid = 0x50 ctime = Sat Dec 29 17:17:53 CST 2018 mZxid = 0x50 mtime = Sat Dec 29 17:17:53 CST 2018 pZxid = 0x51 cversion = 1 dataVersion = 0 aclVersion = 0 ephemeralOwner = 0x0 dataLength = 12 numChildren = 1
[zk: localhost:2181(CONNECTED) 1] ls /czk [] [zk: localhost:2181(CONNECTED) 2] create -s /czk/sec seq Created /itheima/sec0000000001 [zk: localhost:2181(CONNECTED) 3] create -s /czk/sec seq Created /itheima/sec0000000002 [zk: localhost:2181(CONNECTED) 4] ls /czk [sec0000000001, sec0000000002]
set命令:事件
set path data [version] # set 路徑 數據 [版本號] []內爲可選參數
[zk: localhost:2181(CONNECTED) 17] get /czk czk-data1 cZxid = 0x5b ctime = Sat Dec 29 17:45:26 CST 2018 mZxid = 0x66 mtime = Sat Dec 29 18:00:12 CST 2018 pZxid = 0x65 cversion = 5 dataVersion = 1 aclVersion = 0 ephemeralOwner = 0x0 dataLength = 13 numChildren = 3 [zk: localhost:2181(CONNECTED) 18] set /czk czk-data2 cZxid = 0x5b ctime = Sat Dec 29 17:45:26 CST 2018 mZxid = 0x67 mtime = Sat Dec 29 18:02:15 CST 2018 pZxid = 0x65 cversion = 5 dataVersion = 2 aclVersion = 0 ephemeralOwner = 0x0 dataLength = 13 numChildren = 3 [zk: localhost:2181(CONNECTED) 19] get /czk czk-data2 cZxid = 0x5b ctime = Sat Dec 29 17:45:26 CST 2018 mZxid = 0x67 mtime = Sat Dec 29 18:02:15 CST 2018 pZxid = 0x65 cversion = 5 dataVersion = 2 aclVersion = 0 ephemeralOwner = 0x0 dataLength = 13 numChildren = 3
[zk: localhost:2181(CONNECTED) 22] set /czk czk-data3 1 version No is not valid : /czk #版本不匹配 修改失敗 當前版本2 [zk: localhost:2181(CONNECTED) 23] set /czk czk-data3 2 cZxid = 0x5b ctime = Sat Dec 29 17:45:26 CST 2018 mZxid = 0x69 mtime = Sat Dec 29 18:29:21 CST 2018 pZxid = 0x65 cversion = 5 dataVersion = 3 aclVersion = 0 ephemeralOwner = 0x0 dataLength = 13 numChildren = 3 [zk: localhost:2181(CONNECTED) 24] get /czk itheima-data3 cZxid = 0x5b ctime = Sat Dec 29 17:45:26 CST 2018 mZxid = 0x69 mtime = Sat Dec 29 18:29:21 CST 2018 pZxid = 0x65 cversion = 5 dataVersion = 3 aclVersion = 0 ephemeralOwner = 0x0 dataLength = 13 numChildren = 3
[zk: localhost:2181(CONNECTED) 25] ls /czk [sec0000000003, sec0000000001, sec0000000002] [zk: localhost:2181(CONNECTED) 27] delete /czk/sec000000000 sec0000000003 sec0000000001 sec0000000002 [zk: localhost:2181(CONNECTED) 27] delete /czk/sec0000000001 [zk: localhost:2181(CONNECTED) 28] ls /czk [sec0000000003, sec0000000002] [zk: localhost:2181(CONNECTED) 29] set /czk/sec000000000 sec0000000003 sec0000000002 [zk: localhost:2181(CONNECTED) 29] set /czk/sec0000000002 test2 cZxid = 0x64 ctime = Sat Dec 29 17:49:38 CST 2018 mZxid = 0x6b mtime = Sat Dec 29 18:54:33 CST 2018 pZxid = 0x64 cversion = 0 dataVersion = 1 aclVersion = 0 ephemeralOwner = 0x0 dataLength = 5 numChildren = 0 [zk: localhost:2181(CONNECTED) 30] delete /czk/sec000000000 sec0000000003 sec0000000002 [zk: localhost:2181(CONNECTED) 30] delete /czk/sec0000000002 0 version No is not valid : /czk/sec0000000002
總結 使用set / delete命令的時候儘可能使用版本號 避免誤操做事務
針對每一個節點的操做, 都會有一個監督者->watcherget
當監控的某個對象(znode)發生了變化, 則觸發watcher事件
zk中的watcher是一次性的, 觸發後當即銷燬
父節點, 子節點增刪改都能觸發其watcher
針對不一樣類型的操做, 觸發的watcher事件也不一樣:
watcher命令行
建立父節點觸發: NodeCreated
[zk: localhost:2181(CONNECTED) 33] stat /czk watch Node does not exist: /itcast [zk: localhost:2181(CONNECTED) 35] create /czk 123 WATCHER::Created /czk WatchedEvent state:SyncConnected type:NodeCreated path:/czk
[zk: localhost:2181(CONNECTED) 36] get /czk watch 123 cZxid = 0x6d ctime = Sat Dec 29 19:43:13 CST 2018 mZxid = 0x6d mtime = Sat Dec 29 19:43:13 CST 2018 pZxid = 0x6d cversion = 0 dataVersion = 0 aclVersion = 0 ephemeralOwner = 0x0 dataLength = 3 numChildren = 0 [zk: localhost:2181(CONNECTED) 37] set /itcast 789 WATCHER:: WatchedEvent state:SyncConnected type:NodeDataChanged path:/czk cZxid = 0x6d ctime = Sat Dec 29 19:43:13 CST 2018 mZxid = 0x6e mtime = Sat Dec 29 19:47:24 CST 2018 pZxid = 0x6d cversion = 0 dataVersion = 1 aclVersion = 0 ephemeralOwner = 0x0 dataLength = 3 numChildren = 0
[zk: localhost:2181(CONNECTED) 38] ls /czk watch [] [zk: localhost:2181(CONNECTED) 39] delete /czk WATCHER:: WatchedEvent state:SyncConnected type:NodeDeleted path:/czk
ls爲父節點設置watcher, 建立子節點觸發:NodeChildrenChanged
ls爲父節點設置watcher, 刪除子節點觸發:NodeChildrenChanged
ls爲父節點設置watcher, 修改子節點不觸發事件
[zk: localhost:2181(CONNECTED) 49] ls /czk watch [sec0000000003, dir1, sec0000000002] [zk: localhost:2181(CONNECTED) 51] create /czk/dir2 123 WATCHER::Created /czk/dir2 WatchedEvent state:SyncConnected type:NodeChildrenChanged path:/czk [zk: localhost:2181(CONNECTED) 52] ls /czk watch [sec0000000003, dir2, dir1, sec0000000002] [zk: localhost:2181(CONNECTED) 53] delete /czk/dir2 WATCHER:: WatchedEvent state:SyncConnected type:NodeChildrenChanged path:/czk [zk: localhost:2181(CONNECTED) 54]