從dubbo zookeeper注冊地址提取出zookeeper地址的方法
用途
項目中使用了 dubbo,注冊中心使用的 zookeeper,使用 zookeeper 實現(xiàn)了一個簡單的分布式鎖(依賴 curator),因為配置文件存在 dubbo.registry 配置,為了直接使用這個地址來創(chuàng)建分布式鎖,寫了一個簡單的方法來提取 zookeeper 地址。
效果
dubbo.registry 有多種配置方式,支持所有情況,下面是常見的例子和提取結(jié)果:
zookeeper://localhost:2181 zookeeper://localhost:2181?client=zkclient zookeeper://localhost:2181?backup=localhost:2182,localhost:2183 zookeeper://localhost:2181?client=zkclient&backup=localhost:2182,localhost:2183 ------------結(jié)果------------ Optional[localhost:2181] Optional[localhost:2181] Optional[localhost:2181,localhost:2182,localhost:2182] Optional[localhost:2181,localhost:2183,localhost:2183]
代碼
import java.util.Optional;
public class ZookeeperURL {
public static final String PREFIX = "zookeeper://";
public static final String BACKUP = "backup=";
public static Optional<String> convertDubboRegistryToZookeeperURL(String dubboRegistry){
StringBuilder zookeeperURL = new StringBuilder();
if(dubboRegistry != null && dubboRegistry.startsWith(PREFIX)){
dubboRegistry = dubboRegistry.substring(PREFIX.length());
int index = dubboRegistry.indexOf("?");
if(index > 0){
zookeeperURL.append(dubboRegistry.substring(0, index));
dubboRegistry = dubboRegistry.substring(index + 1);
String[] dubboRegistries = dubboRegistry.split("&");
for (int i = 0; i < dubboRegistries.length; i++) {
if(dubboRegistries[i].startsWith(BACKUP)){
String[] backups = dubboRegistries[i].substring(BACKUP.length()).split(",");
for (int j = 0; j < backups.length; j++) {
zookeeperURL.append(",").append(backups[i]);
}
}
}
} else {
zookeeperURL.append(dubboRegistry);
}
return Optional.of(zookeeperURL.toString());
}
return Optional.empty();
}
public static void main(String[] args) {
System.out.println(convertDubboRegistryToZookeeperURL("zookeeper://localhost:2181"));
System.out.println(convertDubboRegistryToZookeeperURL("zookeeper://localhost:2181?client=zkclient"));
System.out.println(convertDubboRegistryToZookeeperURL("zookeeper://localhost:2181?backup=localhost:2182,localhost:2183"));
System.out.println(convertDubboRegistryToZookeeperURL("zookeeper://localhost:2181?client=zkclient&backup=localhost:2182,localhost:2183"));
}
}
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對腳本之家的支持。如果你想了解更多相關(guān)內(nèi)容請查看下面相關(guān)鏈接
相關(guān)文章
java基本教程之synchronized關(guān)鍵字 java多線程教程
這篇文章主要介紹了java的synchronized原理、synchronized基本規(guī)則、synchronized方法 和 synchronized代碼塊、實例鎖和全局鎖2014-01-01
基于Mybatis plus 自動代碼生成器的實現(xiàn)代碼
本文通過實例代碼給大家介紹了基于Mybatis-plus 自動代碼生成器的相關(guān)知識,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下2018-05-05
eclipse實現(xiàn)可認證的DH密鑰交換協(xié)議
這篇文章主要介紹了eclipse實現(xiàn)可認證的DH密鑰交換協(xié)議,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2020-06-06
Spring Boot支持Crontab任務(wù)改造的方法
這篇文章主要介紹了Spring Boot支持Crontab任務(wù)改造的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2019-01-01
Java this、final等關(guān)鍵字總結(jié)
這篇文章主要對java中this、final等關(guān)鍵字進行了總結(jié),需要的朋友可以參考下2017-04-04
Java應(yīng)用服務(wù)器之tomcat部署的詳細教程
這篇文章主要介紹了Java應(yīng)用服務(wù)器之tomcat部署,本文通過實例圖文相結(jié)合給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-07-07

