ZooKeeper常用命令行操作
-
通過./zkCli.sh 打開zk的客戶端進入命令行后台
- ls/ls2 列出當前節點下的子節點 ls2還會列出當前節點的狀態
[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
- get 與 stat命令
- stat 列出節點狀態 ls2相當於 ls + stat
[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
- get命令 獲取節點內容和節點狀態
[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 #子節點數量
4.2 zk特性 session的基本原理與create命令使用
-
客戶端與服務端之間的鏈接存在Session(會話)
-
每個會話可以設置一個超時時間
-
心跳機制: 客戶端向服務端的ping包請求
-
心跳結束, session則過期
-
Session過期, 則臨時節點znode會被拋棄
-
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
- 創建臨時節點 &session過期臨時節點刪除
[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]
4.3 set/delete 命令
-
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
- delete 命令: delete path [version]
[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命令的時候盡量使用版本號 避免誤操作
4.4 watcher機制
-
針對每個節點的操作, 都會有一個監督者->watcher
-
當監控的某個對象(znode)發生了變化, 則觸發watcher事件
-
zk中的watcher是一次性的, 觸發后立即銷毀
-
父節點, 子節點增刪改都能觸發其watcher
-
針對不同類型的操作, 觸發的watcher事件也不同:
- (子)節點創建事件
- (子)節點刪除事件
- (子)節點數據變化事件
-
watcher命令行
- 通過get path [watch]設置watcher
- 父節點 增 刪 改操作觸發 watcher
- 子節點 增 刪 改操作觸發 watcher
-
創建父節點觸發: NodeCreated
- stat path [watch]
[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
- get path [watch]
[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
- ls/ls2 path [watch]
[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]