组团学

Dubbo集成ZooKeeper实现服务注册

阅读 (4536302)

1、服务动态上下线感知

服务动态上下线感知,就是服务调用者要感知到服务提供者上下线的变化。

2、负载均衡

负载均衡这个概念大家都比较熟悉,就是当服务提供者是由多个节点组成的集群环境时,服务调用者需要通过负载均衡算法来动态选择一台目标服务器进行远程通信。负载均衡的目的是通过多个节点的集群来均衡服务器的访问压力,提升整体性能。实现负载均衡的前提是,要得到目标服务集群的所有地址,在服务调用者端进行计算,而地址的获取也同样依赖于第三方软件。

3、Apache Dubbo集成ZooKeeper实现服务注册

步骤:

1、在springboot-provider项目的sample-provider模块中添加zookeeper相关依赖

2、修改application.properties文件,修改dubbo.registry.address的地址为zookeeper服务器地址,表示当前Dubbo服务需要注册到zookeeper上

dubbo.registry.address=zookeeper://localhost:2181

3、服务调用方修改application.properties,设置Dubbo服务注册中心的地址即可,当Dubbo调用方发起远程调用时,会去注册中心获取目标服务的URL地址以完成最终通信。

dubbo.registry.address=zookeeper://localhost:2181

4、服务调用方添加操作zookeeper的依赖

        <dependency>
            <groupId>org.apache.curator</groupId>
            <artifactId>curator-framework</artifactId>
            <version>4.0.1</version>
        </dependency>
        <dependency>
            <groupId>org.apache.curator</groupId>
            <artifactId>curator-recipes</artifactId>
            <version>4.0.1</version>
        </dependency>

5、修改HelloController

@RestController public class HelloController { @Reference private IHelloService helloService; @GetMapping("/hello") public String hello(){ return helloService.sayHello("sss"); } }
需要 登录 才可以提问哦