从Zookeeper获取dubbo提供者ip

创建ZkClient对象,从Children获取即可

pkg参数是包名

实际情况中会获取提供者会有多个,可能配置了禁用的提供者,所以需要获取全列表。

有dubboadmin的还是优先建议看dubboadmin

代码如下

 

public RestResponse<List<String>> getProviderIPList(@RestParam(name = "pkg") String pkg) throws IOException {
        RestResponse<List<String>>  result = new RestResponse();
        String propertiyPath = this.getClass().getResource("/").getPath() + File.separator+"application.properties";
        Properties pro = new Properties();
        FileInputStream in = new FileInputStream(propertiyPath);
        pro.load(in);
        in.close();
        String zkAddress = pro.getProperty("dubbo.zookeeperAddress");
        String[] split = zkAddress.split("//");
        StringBuffer stringBuffer = new StringBuffer();
        if(split!=null){
            stringBuffer.append(split[split.length - 1]);
        }else{
            stringBuffer.append("zk01.local:2181");
        }
        ZkClient zkClient = new ZkClient(stringBuffer.toString(), 5000);
        List<String> list = zkClient.getChildren("/dubbo/"+pkg+"/providers");
        Iterator<String> it = list.iterator();
        List<String> providers =new ArrayList<>();
        while (it.hasNext()) {
            String str = (String)it.next();
            providers.add(str);
        }
        result.setResult(providers);
        return result;
    }

引入包为

import org.I0Itec.zkclient.ZkClient;

POM引入依赖

<!-- https://mvnrepository.com/artifact/com.101tec/zkclient -->
<dependency>
    <groupId>com.101tec</groupId>
    <artifactId>zkclient</artifactId>
    <version>0.11</version>
</dependency>

 

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在集成Dubbo时,需要配置zookeeper的地址和Dubbo的管理员密码。在配置文件中,可以通过设置dubbo.registry.address属性来指定zookeeper的地址,例如dubbo.registry.address=zookeeper://127.0.0.1:2181。同时,还需要设置Dubbo的管理员密码,可以通过设置dubbo.admin.root.password和dubbo.admin.guest.password属性来指定密码。\[1\] 在启动Dubbo之前,确保已经启动了zookeeper服务端,并且启动了dubbo-admin。如果没有启动zookeeper服务端,可能会导致无法查看到服务,同时provider也无法访问。\[2\] 另外,如果使用的是新版的zookeeper,可能会遇到一些问题。解决方法是添加相关的依赖,例如curator-framework、curator-recipes和zookeeper,并且排除掉与日志相关的依赖。可以在pom.xml文件中添加如下代码来解决这个问题: ``` <!--引入zookeeper--> <dependency> <groupId>org.apache.curator</groupId> <artifactId>curator-framework</artifactId> <version>2.12.0</version> </dependency> <dependency> <groupId>org.apache.curator</groupId> <artifactId>curator-recipes</artifactId> <version>2.12.0</version> </dependency> <dependency> <groupId>org.apache.zookeeper</groupId> <artifactId>zookeeper</artifactId> <version>3.4.14</version> <exclusions> <exclusion> <groupId>org.slf4j</groupId> <artifactId>slf4j-log4j12</artifactId> </exclusion> </exclusions> </dependency> ```\[3\] #### 引用[.reference_title] - *1* *2* [【DubboDubbo整合Zookeeper](https://blog.csdn.net/qq_45888932/article/details/123074983)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [SpringBoot集成 Dubbo + Zookeeper + Dubbo Admin:服务注册发现实战与详细步骤](https://blog.csdn.net/m0_46360532/article/details/118770746)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值