Zookeeper全局唯一ID生成方案解析
系統(tǒng)唯一ID生成分案有很多種,例如:數(shù)據(jù)庫 auto_increment,UUID,Redis生成ID(Redis原子操作INCR和INCRBY),Twiitter的snowflake算法,ZooKeeper生成ID,MongoDb的ObjectId,下面我們就看一下ZooKeeper實現(xiàn)分布式系統(tǒng)唯一ID。
public int idGen() throws Exception {
String zkAddress = "127.0.0.1:2181";
String idNode = "/id";
//重試策略
RetryPolicy retry = new RetryNTimes(3, 2000);
//創(chuàng)建連接客戶端
CuratorFramework client = CuratorFrameworkFactory.builder().
connectString(zkAddress).
sessionTimeoutMs(5000).
connectionTimeoutMs(10000).
retryPolicy(retry).
build();
//啟動客戶端
client.start();
if (null == client.checkExists().forPath(idNode)) {
client.create().withMode(CreateMode.PERSISTENT)
.forPath(idNode);
}
Stat stat = client.setData().withVersion(-1).forPath(idNode);
return stat.getVersion();
}
注意:換了ZooKeeper,數(shù)據(jù)就要從0開始,還沒有直接可以修改指定數(shù)字那里開始,只能寫程序一點點的創(chuàng)建,直到達(dá)到你要想的數(shù)據(jù) ,這是它最大的弊端。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- SpringCloud用Zookeeper搭建配置中心的方法
- springcloud集成zookeeper的方法示例
- SpringBoot+Dubbo+Zookeeper實現(xiàn)簡單分布式開發(fā)的應(yīng)用詳解
- 關(guān)于idea+centos7+zookeeper報錯connectionloss,timeout問題
- 如何用python 操作zookeeper
- SpringBoot中dubbo+zookeeper實現(xiàn)分布式開發(fā)的應(yīng)用詳解
- 基于Spring Cloud Zookeeper實現(xiàn)服務(wù)注冊與發(fā)現(xiàn)
- 2020最新IDEA SpringBoot整合Dubbo的實現(xiàn)(zookeeper版)
- SpringBoot系列教程之dubbo和Zookeeper集成方法
- Python通過zookeeper實現(xiàn)分布式服務(wù)代碼解析
- 在Java中操作Zookeeper的示例代碼詳解
- SpringCloud使用Zookeeper作為注冊中心
相關(guān)文章
MyBatis動態(tài)SQL中的trim標(biāo)簽的使用方法
這篇文章主要介紹了MyBatis動態(tài)SQL中的trim標(biāo)簽的使用方法,需要的朋友可以參考下2017-05-05
java Class文件結(jié)構(gòu)解析常量池字節(jié)碼
這篇文章主要為大家介紹了java Class文件的整體結(jié)構(gòu)解析常量池字節(jié)碼詳細(xì)講解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-07-07
struts2數(shù)據(jù)處理_動力節(jié)點Java學(xué)院整理
Struts2框架框架使用OGNL語言和值棧技術(shù)實現(xiàn)數(shù)據(jù)的流轉(zhuǎn)處理。下面通過本文給大家分享struts2數(shù)據(jù)處理的相關(guān)知識,感興趣的朋友參考下吧2017-09-09

