Java調(diào)用Zookeeper的實現(xiàn)步驟
watch機制
Zookeeper watch是一種監(jiān)聽通知機制,可以隨時監(jiān)聽一些數(shù)據(jù)的變化,從而實現(xiàn)數(shù)據(jù)的及時性。
Zookeeper所有的讀操作getData(), getChildren()和 exists()都可以設(shè)置監(jiān)聽(watch)?!緦懖僮鲃t是不能設(shè)置監(jiān)視點的?!?br />
Watch的三個關(guān)鍵點:
- 一次有效:當(dāng)設(shè)置監(jiān)視的數(shù)據(jù)發(fā)生改變時,該監(jiān)視事件會被發(fā)送到客戶端,并且該監(jiān)聽將會停止,除非重啟注冊監(jiān)聽;
- 順序保證:網(wǎng)絡(luò)延遲或者其他因素可能導(dǎo)致不同的客戶端在不同的時刻感知某一監(jiān)視事件,但是不同的客戶端所看到的一切具有一致的順序;
- 可以監(jiān)聽數(shù)據(jù)和子節(jié)點:getData()和 exists()可以設(shè)置監(jiān)聽數(shù)據(jù)變化;getChildren 可以設(shè)置監(jiān)聽子節(jié)點變化;
常用API
/** * 構(gòu)造器 * @param connectString 集群的IP:端口號;多個服務(wù)器時,中間用逗號分割 * @param sessionTimeout 超時時間,單位:毫秒 * @param watcher 監(jiān)聽器,監(jiān)聽節(jié)點變化 * @throws IOException */ public ZooKeeper(String connectString, int sessionTimeout, Watcher watcher) throws IOException /** * * @param path 節(jié)點路徑 * @param data 數(shù)據(jù) * @param acl 訪問控制列表 * @param createMode 節(jié)點類型 * @return * @throws KeeperException * @throws InterruptedException */ public String create(String path, byte[] data, List<ACL> acl, CreateMode createMode) throws KeeperException, InterruptedException /** * * @param path 節(jié)點路徑 * @param watch 監(jiān)聽器 * @return 所有的子節(jié)點的名稱 * @throws KeeperException * @throws InterruptedException */ public List<String> getChildren(String path, boolean watch) throws KeeperException, InterruptedException /** * * @param path 節(jié)點路徑 * @param watcher 監(jiān)聽器 * @param stat 狀態(tài)信息【可以為null】 * @return 節(jié)點數(shù)據(jù)的二進制數(shù)組【可以通過new String()轉(zhuǎn)換成字符串信息】 * @throws KeeperException * @throws InterruptedException */ public byte[] getData(String path, Watcher watcher, Stat stat) throws KeeperException, InterruptedException /** * * @param path 節(jié)點路徑 * @param watch 監(jiān)聽器 * @param cb 回調(diào)函數(shù) * @param ctx 上下文參數(shù) ?【該參數(shù)不太理解,望知道的留言講解,謝謝】 */ public void getData(String path, boolean watch, AsyncCallback.DataCallback cb, Object ctx) /** * * @param path 節(jié)點路徑 * @param data 數(shù)據(jù) * @param version 版本號【初始通常賦值為-1,每次更新會自動+1】 * @return 狀態(tài)信息 * @throws KeeperException * @throws InterruptedException */ public Stat setData(String path, byte[] data, int version) throws KeeperException, InterruptedException /** *如果Stat為null,則節(jié)點不存在 * @param path 節(jié)點路徑 * @param watch 監(jiān)聽器 * @return 狀態(tài)信息 * @throws KeeperException * @throws InterruptedException */ public Stat exists(String path, boolean watch) throws KeeperException, InterruptedException /** * 如果要刪除的節(jié)點有子節(jié)點,會報錯:KeeperException$NotEmptyException: KeeperErrorCode = Directory not empty for * 如果節(jié)點不存在,會報錯:KeeperException$NoNodeException: KeeperErrorCode = NoNode for * @param path 節(jié)點路徑 * @param version 版本號[version = -1 : 匹配所有的版本] * @throws InterruptedException * @throws KeeperException */ public void delete(String path, int version) throws InterruptedException, KeeperException
JAVA調(diào)用
初始化
try {
ZooKeeper zooKeeper = new ZooKeeper("172.23.34.13:2181", 15000, event -> {
if (event.getType() == Watcher.Event.EventType.None && event.getState() == Watcher.Event.KeeperState.SyncConnected) {
System.out.println("Connectted successful.");
}
});
} catch (IOException e) {
e.printStackTrace();
}
創(chuàng)建節(jié)點: create
@Test
public void create() throws KeeperException, InterruptedException {
//參數(shù):1,節(jié)點路徑; 2,要存儲的數(shù)據(jù); 3,節(jié)點的權(quán)限; 4,節(jié)點的類型
String nodePath = zooKeeper.create("/java/2183", "This is Java Node 2183.".getBytes(), ZooDefs.Ids.OPEN_ACL_UNSAFE, CreateMode.PERSISTENT);
System.out.println(nodePath);
}
獲取子節(jié)點: ls
public void getChildren() throws KeeperException, InterruptedException {
List<String> children = zooKeeper.getChildren("/", true);
for (String child : children) {
System.out.println("child: "+child);
}
}
同步獲取節(jié)點內(nèi)容: get
@Test
public void getData() throws KeeperException, InterruptedException {
String path = "/java";
byte[] bytes = zooKeeper.getData(path, event -> {
if (event.getType() == Watcher.Event.EventType.NodeDataChanged && path.equals(event.getPath())) {
System.out.println("Date changed.");
}
}, null);
System.out.printf("The data of %s is : %s \n",path, new String(bytes));
}
異步獲取節(jié)點內(nèi)容: get
@Test
public void getDataAsync() {
String path = "/java";
zooKeeper.getData(path, false, new AsyncCallback.DataCallback() {
@Override
public void processResult(int i, String s, Object o, byte[] bytes, Stat stat) {
System.out.printf("The data of %s is : %s \n",path, new String(bytes));
}
},"1000");
//休眠20秒,查看響應(yīng)結(jié)果
try {
Thread.sleep(20000);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
指定版本號更新數(shù)據(jù):set
@Test
public void setData() throws KeeperException, InterruptedException {
Stat stat = zooKeeper.setData("/java", "This is from java.".getBytes(), -1);
//更新節(jié)點后,version會自動+1。故,返回值為0
System.out.println(stat.getAversion());
}
多線程下更新數(shù)據(jù):set
@Test
public void setDataThread() throws KeeperException, InterruptedException {
String path = "/java";
Stat stat = new Stat();
//1,先獲取節(jié)點的當(dāng)前版本
zooKeeper.getData(path,false,stat);
//2,在當(dāng)前版本的基礎(chǔ)上修改節(jié)點內(nèi)容
zooKeeper.setData(path, "This is from java.".getBytes(), stat.getVersion());
}
判斷節(jié)點是否存在
@Test
public void exists() throws KeeperException, InterruptedException {
Stat stat = zooKeeper.exists("/java", false);
if (stat == null) {
System.out.println("Not Exists.");
}else {
System.out.println("Exists.");
}
}
刪除節(jié)點
@Test
public void delete() throws KeeperException, InterruptedException {
//version = -1 : 匹配所有的版本
zooKeeper.delete("/java/2182", -1);
}
到此這篇關(guān)于Java調(diào)用Zookeeper的實現(xiàn)步驟的文章就介紹到這了,更多相關(guān)Java調(diào)用Zookeeper內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Spring-AOP @AspectJ切點函數(shù)之@annotation()用法
這篇文章主要介紹了Spring-AOP @AspectJ切點函數(shù)之@annotation()用法,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-07-07
MyBatis saveBatch 性能調(diào)優(yōu)的實現(xiàn)
本文主要介紹了MyBatis saveBatch 性能調(diào)優(yōu)的實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-07-07
IDEA打開java項目后里面的java文件不能運行解決辦法
這篇文章主要給大家介紹了關(guān)于IDEA打開java項目后里面的java文件不能運行的解決辦法,有時候想運行別人的項目,但是別人的項目并非IDEA項目(甚至只有源碼),當(dāng)我們打開項目時候,并不能運行,需要的朋友可以參考下2023-10-10
Java中FileOutputStream流的write方法
這篇文章主要為大家詳細(xì)介紹了Java中FileOutputStream流的write方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-08-08

