SpringBoot集成Curator實(shí)現(xiàn)Zookeeper基本操作的代碼示例
Zookeeper是一個(gè)Apache開源的分布式的應(yīng)用,為系統(tǒng)架構(gòu)提供協(xié)調(diào)服務(wù)。從設(shè)計(jì)模式角度來審視:該組件是一個(gè)基于觀察者模式設(shè)計(jì)的框架,負(fù)責(zé)存儲和管理數(shù)據(jù),接受觀察者的注冊,一旦數(shù)據(jù)的狀態(tài)發(fā)生變化,Zookeeper就將負(fù)責(zé)通知已經(jīng)在Zookeeper上注冊的觀察者做出相應(yīng)的反應(yīng),從而實(shí)現(xiàn)集群中類似Master/Slave管理模式。ZooKeeper的目標(biāo)就是封裝好復(fù)雜易出錯(cuò)的關(guān)鍵服務(wù),將簡單易用的接口和性能高效、功能穩(wěn)定的系統(tǒng)提供給用戶。
zookeeper安裝單機(jī)模式
http://www.javacui.com/opensource/445.html
官網(wǎng)
https://curator.apache.org/releases.html#Current_Release
POM引入
<!-- curator --> <dependency> <groupId>org.apache.curator</groupId> <artifactId>curator-recipes</artifactId> <version>5.2.0</version> </dependency> <!-- fastjson --> <dependency> <groupId>com.alibaba</groupId> <artifactId>fastjson</artifactId> <version>1.2.79</version> </dependency>
application.yml定義連接屬性
server: port: 80 curator: connectString: 192.168.3.22:2181 # zookeeper 地址 retryCount: 1 # 重試次數(shù) elapsedTimeMs: 2000 # 重試間隔時(shí)間 sessionTimeoutMs: 60000 # session超時(shí)時(shí)間 connectionTimeoutMs: 10000 # 連接超時(shí)時(shí)間
使用Springboot配置讀取
package com.example.springboot.config; import lombok.Data; import org.springframework.boot.context.properties.ConfigurationProperties; import org.springframework.stereotype.Component; /** * @Auther: Java小強(qiáng) * @Date: 2022/2/4 - 19:37 * @Decsription: com.example.springboot.config * @Version: 1.0 */ @Data @Component @ConfigurationProperties(prefix = "curator") public class CuratorConf { private int retryCount; private int elapsedTimeMs; private String connectString; private int sessionTimeoutMs; private int connectionTimeoutMs; }
公用連接創(chuàng)建對象
package com.example.springboot.tool; import com.example.springboot.config.CuratorConf; import org.apache.curator.framework.CuratorFramework; import org.apache.curator.framework.CuratorFrameworkFactory; import org.apache.curator.retry.RetryNTimes; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; /** * @Auther: Java小強(qiáng) * @Date: 2022/2/4 - 19:37 * @Decsription: com.example.springboot.tool * @Version: 1.0 */ @Configuration public class ZkConfiguration { @Autowired private CuratorConf curatorConf; /** * 這里會自動調(diào)用一次start,請勿重復(fù)調(diào)用 */ @Bean(initMethod = "start") public CuratorFramework curatorFramework() { return CuratorFrameworkFactory.newClient( curatorConf.getConnectString(), curatorConf.getSessionTimeoutMs(), curatorConf.getConnectionTimeoutMs(), new RetryNTimes(curatorConf.getRetryCount(), curatorConf.getElapsedTimeMs())); } }
編寫測試類,實(shí)現(xiàn)各種基礎(chǔ)操作,并挨個(gè)測試
package com.example.springboot; import com.alibaba.fastjson.JSON; import com.example.springboot.tool.ZkConfiguration; import org.apache.curator.framework.CuratorFramework; import org.apache.curator.framework.api.BackgroundCallback; import org.apache.curator.framework.api.CuratorEvent; import org.apache.zookeeper.data.Stat; import org.junit.jupiter.api.Test; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.boot.test.context.SpringBootTest; import java.nio.charset.StandardCharsets; import java.util.List; /** * @Auther: Java小強(qiáng) * @Date: 2022/2/4 - 19:33 * @Decsription: com.example.springboot * @Version: 1.0 */ @SpringBootTest(classes = Application.class) public class CuratorTest { @Autowired private ZkConfiguration zk; // 測試連接 @Test void contextLoads() { CuratorFramework client= zk.curatorFramework(); System.out.println(client.toString()); } // 創(chuàng)建節(jié)點(diǎn) @Test void createPath() throws Exception{ CuratorFramework client= zk.curatorFramework(); // 父節(jié)點(diǎn)不存在則創(chuàng)建 String path = client.create().creatingParentsIfNeeded().forPath("/javacui/p1" , "Java小強(qiáng)博客".getBytes(StandardCharsets.UTF_8)); System.out.println(path); byte[] data = client.getData().forPath("/javacui/p1"); System.out.println(new String(data)); } // 賦值,修改數(shù)據(jù) @Test void setData() throws Exception{ CuratorFramework client = zk.curatorFramework(); int version = 0; // 當(dāng)前節(jié)點(diǎn)的版本信息 Stat stat = new Stat(); client.getData().storingStatIn(stat).forPath("/javacui/p1"); version = stat.getVersion(); // 如果版本信息不一致,說明當(dāng)前數(shù)據(jù)被修改過,則修改失敗程序報(bào)錯(cuò) client.setData().withVersion(version).forPath("/javacui/p1", "Java崔的博客".getBytes(StandardCharsets.UTF_8)); byte[] data = client.getData().forPath("/javacui/p1"); System.out.println(new String(data)); } // 查詢節(jié)點(diǎn) @Test void getPath() throws Exception{ CuratorFramework client= zk.curatorFramework(); // 查內(nèi)容 byte[] data = client.getData().forPath("/javacui/p1"); System.out.println(new String(data)); // 查狀態(tài) Stat stat = new Stat(); client.getData().storingStatIn(stat).forPath("/javacui/p1"); System.out.println(JSON.toJSONString(stat, true)); } // 刪除節(jié)點(diǎn) @Test void deletePath() throws Exception{ CuratorFramework client= zk.curatorFramework(); // deletingChildrenIfNeeded如果有子節(jié)點(diǎn)一并刪除 // guaranteed必須成功比如網(wǎng)絡(luò)抖動時(shí)造成命令失敗 client.delete().guaranteed().deletingChildrenIfNeeded().inBackground(new BackgroundCallback() { @Override public void processResult(CuratorFramework curatorFramework, CuratorEvent curatorEvent) throws Exception { System.out.println("刪除成功"); // { "path":"/javacui/p1","resultCode":0,"type":"DELETE"} System.out.println(JSON.toJSONString(curatorEvent, true)); } }).forPath("/javacui/p1"); } // 查詢子節(jié)點(diǎn) @Test void getPaths() throws Exception{ CuratorFramework client= zk.curatorFramework(); List<String> paths = client.getChildren().forPath("/javacui"); for(String p : paths){ System.out.println(p); } } }
以上就是SpringBoot集成Curator實(shí)現(xiàn)Zookeeper基本操作的代碼示例的詳細(xì)內(nèi)容,更多關(guān)于SpringBoot Zookeeper基本操作的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
Java中JDom解析XML_動力節(jié)點(diǎn)Java學(xué)院整理
JDOM是一種解析XML的Java工具包。DOM適合于當(dāng)今流行的各種語言,包括Java,JavaScripte,VB,VBScript,Perl,C,C++等。下面通過本文給大家介紹Java中JDom解析XML的方法,感興趣的朋友一起學(xué)習(xí)吧2017-07-07總結(jié)十個(gè)實(shí)用但偏執(zhí)的Java編程技術(shù)
Java是世界上最流行的程序語言,從1995年問世以來,Java的生態(tài)系統(tǒng)在一直在蓬勃的發(fā)展著。下面這篇文章主要總結(jié)了十個(gè)實(shí)用但偏執(zhí)的Java編程技術(shù),需要的朋友可以參考借鑒,下面來一起學(xué)習(xí)學(xué)習(xí)吧。2017-01-01Springboot如何使用filter對request body參數(shù)進(jìn)行校驗(yàn)
這篇文章主要介紹了Springboot如何使用filter對request body參數(shù)進(jìn)行校驗(yàn),具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-03-03升級springboot中spring框架的版本的實(shí)現(xiàn)方法
本文主要介紹了升級springboot中spring框架的版本的實(shí)現(xiàn)方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2024-08-08javaweb圖書商城設(shè)計(jì)之訂單模塊(5)
這篇文章主要為大家詳細(xì)介紹了javaweb圖書商城設(shè)計(jì)之訂單模塊,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-11-11