4. ZooKeeper 基本操作

ZooKeeper的數據模型及其API支持以下九個基本操作:

操作描述
create在ZooKeeper命名空間的指定路徑中創建一個znode
delete從ZooKeeper命名空間的指定路徑中刪除一個znode
exists檢查路徑中是否存在znode
getChildren獲取znode的子節點列表
getData獲取與znode相關的數據
setData將數據設置/寫入znode的數據字段
getACL獲取znode的訪問控制列表(ACL)策略
setACL在znode中設置訪問控制列表(ACL)策略
sync將客戶端的znode視圖與ZooKeeper同步

我們來使用ZooKeeper Java shell對上面中提到的ZooKeeper操作進行演示:

  1. ThisIsTheRootNode作為數據創建一個名為root的znode:
[zk: localhost(CONNECTED) 0] create /root "ThisIsTheRootNode"
Created /root
  1. 獲取剛創建的root的znode的內容:
[zk: localhost(CONNECTED) 1] get /root
"ThisIsTheRootNode"
…… ……
…… ……
  1. ThisIsChild-1作為數據為root創建一個名為child-1的子節點:
[zk: localhost(CONNECTED) 2] create /root/child-1 "ThisIsChild-1"
Created /root/child-1
  1. ThisIsChild-2作為數據為root創建一個名為child-2的子節點:
[zk: localhost(CONNECTED) 3] create /root/child-2 "ThisIsChild-2"
Created /root/child-2
  1. 列出root的子節點:
[zk: localhost(CONNECTED) 4] ls /root
[child-2, child-1]
  1. 獲取root的訪問控制列表:
[zk: localhost(CONNECTED) 5] getAcl /root
'world,'anyone
: cdrwa
  1. 由于root擁有2個子節點,所以不允許刪除root:
[zk: localhost(CONNECTED) 6] delete /root
Node not empty: /root
  1. 刪除子節點child-1
[zk: localhost(CONNECTED) 7] delete /root/child-1
  1. 刪除子節點child-2
[zk: localhost(CONNECTED) 8] delete /root/child-2
  1. 列出root的內容:
[zk: localhost(CONNECTED) 9] ls2 /root
[]
…… ……
…… ……
  1. 刪除root
[zk: localhost(CONNECTED) 10] delete /root

除了上述描述的操作外,ZooKeeper還支持使用稱為multi的操作對znodes進行批量更新。 這將多個原始操作組合在一起成為一個單元。 一個multi操作本質上也是原子的,這意味著要么所有的更新成功,要么整個更新整個失敗。

ZooKeeper不允許部分寫入或讀取znode數據。 設置znode的數據或讀取時,znode的內容將被替換或完全讀取。 ZooKeeper中的更新操作(如deletesetData操作)必須指定正在更新的znode的版本號。 版本號可以通過使用exists()方法調用來獲得。 如果指定的版本號與znode中的版本號不匹配,則更新操作將失敗。 另外,需要注意的另一件重要的事情是ZooKeeper中的更新是非阻塞(non-blocking)操作。

ZooKeeper中的讀寫操作如下圖所示:
ZooKeeper中的讀寫操作

從前面的圖片中,需要注意這些操作兩個關鍵地方:

  • Read requests:這些在客戶端當前連接的ZooKeeper服務器上進行局部處理
  • Write requests:這些被轉發給領導者,并在生成響應之前通過多數協商一致

轉載于:https://www.cnblogs.com/IcanFixIt/p/7824786.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/281884.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/281884.shtml
英文地址,請注明出處:http://en.pswp.cn/news/281884.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

byte java byte_詳解java中的byte類型

Java中整數類型有:byte占8位, short 占16位, int占32位, long占64位Java也提供了一個byte數據類型,并且是基本類型中的整數類型。java byte是作為最小的數字來處理的,因此它的值域被定義為-128~127,也就是signed byte。下面這篇文章主要給大家…

zabbix 3.0.0beta1安裝-centos6.8版本

zabbix 3.0安裝 zabbix最低需要mysql 5.5 php5.3 查詢mysql版本yum list installed | grep mysql##mysql-libs.x86_64 5.1.73-5.el6_6 anaconda-CentOS-201508042137.x86_64/6.7 卸載mysqlyum remove mysql* 指定mysql源rpm -ivh http://dev.mysql.com/get/mysql-community-rel…

技術走向管理一些思考

在《IT項目管理》一書中針對IT行業定義了一個新的“工種”--多才多藝者,并預言未來的IT產業中多才多藝者的重要性將逐漸凸顯。多才多藝者即是具有技術背景,同一時候了解業務部門、能規劃和實施IT計劃、添加商業價值、培養公司內外部關系的人。 想想還認為…

npm 安裝 chromedriver 失敗的解決辦法

https://segmentfault.com/a/1190000008310875 npm install chromedriver --chromedriver_cdnurlhttp://cdn.npm.taobao.org/dist/chromedriver轉載于:https://www.cnblogs.com/chenxijywc/p/7825024.html

微軟正式發布Azure Functions 2.0

微軟正式發布Azure Functions的第二個版本,這是一個事件驅動的、按需計算的Azure平臺服務。與版本1相比,新版本的Azure Functions包含的多項特性使開發人員可以更輕松地構建可伸縮的無服務器應用程序。2016年初,微軟首次推出Azure Functions預…

CSS-下拉導航條

Web網站中很多時候都會出現下拉導航條&#xff0c;有的是通過CSS實現&#xff0c;有的通過JavaScript插件實現&#xff0c;其實CSS實現起來比較簡單,先來看一個簡版的下拉菜單: Html代碼通過ul列表實現: 123456789101112131415161718<ul class"nav"> <li>…

#UnityTips# 2017.11.14

hi&#xff0c;all。最近比較忙&#xff0c;所以更新也比較慢了。 今天就來和大家分享一個小Tip&#xff0c;它是關于UGUI的坑的。 使用過UGUI的朋友們都知道&#xff0c;Canvas的渲染方式有三種&#xff1a; Screen Space OverlayScreen Space CameraWorld Space其中后兩者都需…

細聊.Net Core中IServiceScope的工作方式

前言自從.Net Core引入IOC相關的體系之后&#xff0c;關于它的討論就從來沒有停止過&#xff0c;因為它是.Net Core體系的底層框架&#xff0c;你只要使用了.Net Core的時候就必然會用到它。當然關于使用它的過程中產生的問題也從來沒停止過。我對待問題的態度向來都是&#xf…

WPF 獲取鼠標屏幕位置、窗口位置、控件位置

原文:WPF 獲取鼠標屏幕位置、窗口位置、控件位置public struct POINT{public int X;public int Y;public POINT(int x, int y){this.X x;this.Y y;}}[DllImport("user32.dll")] public static extern bool GetCursorPos(out POINT lpPoint);//e.GetPosition(this);…

java 復制excel_Java 復制Excel工作表

本文歸納了關于Java如何復制Excel工作表的方法&#xff0c;按不同復制需求&#xff0c;可分為&#xff1a;1. 復制工作表1.1 在同一個工作簿內復制工作表1.2 在不同工作簿間復制工作表2. 復制指定單元格數據對于復制方法copy()&#xff0c;這里簡單整理了一個表格&#xff0c;其…

AngularDart 現已全面采用 Dart 開發

一直以來&#xff0c;Angular 2依然采用TypeScript作為主流開發語言&#xff0c;然后自動編譯成JavaScript 和 Dart。Dart開發者一直在進行Angular 2拆分&#xff0c;將其分為TypeScript/JavaScript版本和Dart版本&#xff0c;并成立了AngularDart團隊。 昨天&#xff0c;Angul…

Blazor學習之旅(4)數據共享

【Blazor】| 總結/Edison Zhou大家好&#xff0c;我是Edison。前幾天沒有發布本篇就發布了第五篇&#xff0c;屬于操作失誤哈&#xff0c;這次把第四篇補上&#xff01;本篇&#xff0c;我們來了解下在Blazor中數據是如何共享的&#xff0c;組件之間又該如何傳遞參數。關于Blaz…

Zynq7000開發系列-5(OpenCV開發環境搭建:Ubuntu、Zynq)

操作系統&#xff1a;Ubuntu14.04.5 LTS 64bit OpenCV&#xff1a;OpenCV 3.1.0、opencv_contrib gcc&#xff1a;gcc version 4.8.4 (Ubuntu 4.8.4-2ubuntu1~14.04.3) arm-xilinx-linux-gnueabi-gcc&#xff1a;gcc version 4.9.2 (Sourcery CodeBench Lite 2015.05-17) 一、U…

# 20172307 2018-2019-1 《程序設計與數據結構》第5周學習總結

20172307 2018-2019-1 《程序設計與數據結構》第5周學習總結 教材學習內容總結 查找 1.線性查找&#xff1a;從該列表頭開始依次比較每一個值&#xff0c;直至找到該目標元素。2.二分查找法&#xff1a;二分查找是從排序列表的中間開始查找&#xff0c;如果沒有在那個中間元素則…

java 生成jni_Javah生成JNI頭文件

在eclipse中建一項目&#xff0c;建一class1 packageesmart.colfile.parse;2 3 publicclassTestHello {4 static{5 System.loadLibrary("TestHello");6 }7 8 publicstaticnativevoidhello(String msg);9 10 publicstaticvoidmain(String[] args) {11 12 hello("…

IBM 的大型機 z Systems 引入 Go 語言

據 cbronline 報道&#xff0c;IBM 正把 Go 語言運用到旗下的大型機上。 IBM 將開源的 Go 語言引入到 z Systems 大型機后&#xff0c;可以給用戶多一個的選擇&#xff0c;即在大型機上使用 Linux 或基于 Go 的應用&#xff0c;同時也使大型機更加靈活。Go 語言在高并發的網絡應…

WPF-10 邏輯樹和可視化樹

我們在WPF-03 資源之Resources結尾中介紹邏輯樹和可視化樹的基本概念&#xff0c;我們這節來介紹這兩棵樹邏輯樹&#xff08;Logical Tree&#xff09;邏輯樹是由每個控件的節點組成&#xff0c;本質上就是XAML文件中的UI元素&#xff0c;我們可以通過LogicalTreeHelper類提供的…

洛谷P4364 [九省聯考2018]IIIDX(線段樹)

傳送門 題解看得……很……迷&#xff1f; 因為取完一個數后&#xff0c;它的子樹中只能取權值小于等于它的數。我們先把權值從大到小排序&#xff0c;然后記$a_i$為他左邊&#xff08;包括自己&#xff09;所有取完他還能取的數的個數。那么當取完一個點$x$的數之后&#xff0…

國產車崛起粉碎德日工業神話

由于二戰戰敗&#xff0c;德國一大批頂尖人才被美蘇瓜分&#xff0c;戰敗國地位和人才斷層導致德國工業基本是第二次工業革命的產物&#xff0c;專精于機械、化工等傳統行業&#xff0c;并有巴斯夫、拜爾、大眾、戴姆勒、寶馬等一批世界級企業。不過&#xff0c;德國世界級的IT…

java hibernate 分頁查詢_4 Hibernate HQL查詢,分頁查詢

/*** HQL查詢的一個例子*/public static void hql(){Session s null;try{s HibernateUtil.getSeesion();//final String hql "from User as u where u.name?";final String hql "from User as u where u.name:name";final Query query s.createQuery…