Dubbo高级用法

#博学谷IT学习技术支持#


上一章实现了springboot集成dubbo,本篇文章主要介绍一下dubbo的一些高级用法。因为会继续使用上一章的内容,没看过上一章的小伙伴可以去先去看一下。
SpringBoot集成Dubbo

Dubbo高级用法

1.启动时检查

因为我们的consumer服务引用了GoodsService,如果此时provider没有注册GoodsService服务,那么consumer服务将会启动失败。我们可以看到启动失败的原因是在zookeeper注册中心没有找到GoodsService对应的提供方。

在这里插入图片描述
为了解决consumer对provider的这种启动依赖关系,dubbo提供了check检查字段,默认值为true,也就是在启动是去检查。check可以在@Reference注解中使用,这个启动时就不会去检查是否存在provider,不会影响服务的正常启动。

    @Reference(check = false)
    private GoodsService goodsService;

2.负载均衡

Dubbo中内置了五种负载均衡算法

算法特性备注
RandomLoadBalance加权随机默认算法,默认权重相同
RoundRobinLoadBalance加权轮询借鉴于 Nginx 的平滑加权轮询算法,默认权重相同,
LeastActiveLoadBalance最少活跃优先 + 加权随机背后是能者多劳的思想
ShortestResponseLoadBalance最短响应优先 + 加权随机更加关注响应速度
ConsistentHashLoadBalance一致性 Hash确定的入参,确定的提供者,适用于有状态请求

我们这里使用轮询算法来看一下负载均衡的配置;
我们使用三个provider去提供服务,并且把相应的端口注入进来,并修改yml配置文件
因为idea默认只能启动一个相同的服务,因此要先设置一下idea,允许启动多个实例
不同版本的idea配置不通,下面两个作为参考
在这里插入图片描述

在这里插入图片描述
下面是我们yml配置里面端口的修改,只要保证server.port和protocol.port和其他的实例不同就可以,启动一个实例后,修改yml,然后再继续启动第二个即可

server:
  port: 8000
protocol:
  port: 20880
  name: dubbo
server:
  port: 8001
protocol:
  port: 20881
  name: dubbo
server:
  port: 8002
protocol:
  port: 20882
  name: dubbo

为了方便我们观察具体走了那个服务,我们可以将server.port注入到GoodsServiceImpl中,并在getData()方法中加入端口信息;

  @Value("${server.port}")
  private String port;
  
  @Override
  public String getData(String data) {
      System.out.println("getData被调用了!" + port);
      return port;
  }

把三个provider启动起来

我们把consumer修改一下,将之前的getGoods()方法注释掉,新增一下getData()方法请求路径还是get。在@Reference注解,加上loadbalance,值为我们所要使用的负载均衡类中NAME属性对应的值
启动consumer服务
在这里插入图片描述

@Reference(loadbalance = "roundrobin")
private GoodsService goodsService;

@RequestMapping("/get")
public Object getData() {
   return goodsService.getData("");
}

启动之后,我们在浏览器访问consumer的getData()接口,多访问几次,可以看到端口是按顺序访问,这样,我们的负载均衡就配置完成了
在这里插入图片描述

3.直连提供者

当提供者有多台服务,但是只想访问其中某一台服务时,可以直连提供者;
在consumer里的@Reference注解中使用url属性,属性内容为我们要连接的提供者url地址

    @Reference(loadbalance = "roundrobin", url = "dubbo://localhost:20880")
    private GoodsService goodsService;

这个url地址,是在提供者里面配置的协议及端口,可以参考下面这一段配置,如果port是20881,我们就要加上面url中的端口改为20881。相应的如果协议修改了,我们url中的协议也要跟着改

server:
  port: 8000
dubbo:
  protocol:
  port: 20880
  name: dubbo

接下来测试一下:
还是启动了三个提供者,使用了负载均衡,如果设置直连提供者的话,三个服务会轮询被访问。这里设置了直连,正常来说只能访问到20880端口的提供者。在浏览器访问看下;
在这里插入图片描述
可以看到无论访问多少次,都只访问20880端口的提供方。这个8000返回的是20880dubbo协议端口对应的服务的server.port。这里,直连提供者就完成了

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Spring Boot 和 Dubbo 可以搭配使用来构建分布式系统。下面是一些关于如何将它们整合在一起的提示: 1. 添加 Dubbo Starter 依赖:在 Spring Boot 项目中,您需要添加 Dubbo Starter 依赖,以便可以使用 Dubbo 相关的类和注解。您可以在 pom.xml 文件中添加以下依赖: ```xml <dependency> <groupId>com.alibaba.spring.boot</groupId> <artifactId>dubbo-spring-boot-starter</artifactId> <version>${dubbo.version}</version> </dependency> ``` 2. 配置 Dubbo:在 application.properties 或 application.yml 文件中配置 Dubbo 相关的属性,例如应用名称、注册中心地址、协议等。 3. 编写 Dubbo 服务:在 Spring Boot 应用程序中编写 Dubbo 服务的实现类,使用 @Service 注解标记服务实现类。例如: ```java @Service public class HelloServiceImpl implements HelloService { @Override public String sayHello(String name) { return "Hello, " + name; } } ``` 4. 暴露 Dubbo 服务:在服务实现类上添加 @Service 和 @DubboService 注解,其中 @DubboService 注解用于暴露服务。例如: ```java @Service @DubboService public class HelloServiceImpl implements HelloService { @Override public String sayHello(String name) { return "Hello, " + name; } } ``` 5. 调用 Dubbo 服务:在 Spring Boot 应用程序中调用 Dubbo 服务,使用 @Reference 注解来自动注入服务对象。例如: ```java @RestController public class HelloController { @Reference private HelloService helloService; @GetMapping("/hello") public String hello(@RequestParam String name) { return helloService.sayHello(name); } } ``` 这些是将 Spring Boot 和 Dubbo 结合使用的基本步骤。当然,还有其他更高级的配置和用法,您可以参考 Dubbo 和 Spring Boot 的官方文档来深入学习。 ### 回答2: Spring Boot是一款开源的Java Web开发框架,它能够帮助开发人员快速构建和部署微服务应用。而Dubbo是阿里巴巴开源的一个高性能的分布式服务框架,它可以轻松地实现服务之间的远程调用和负载均衡。在实际开发中,我们常常需要将Spring Boot和Dubbo整合在一起,以实现分布式应用的开发。 Spring Boot和Dubbo整合的主要步骤如下: 1. 引入Dubbo依赖包 在pom.xml文件中添加Dubbo的依赖包,这对于Dubbo的后续使用是非常关键的。 2. 配置Dubbo服务 在Spring Boot配置文件application.yml或application.properties中,配置Dubbo相关的属性,包括zookeeper地址、Dubbo应用名称、Dubbo协议等。 3. 配置Dubbo服务提供方 Dubbo服务提供方需要以Java类的形式暴露服务,可以使用Dubbo的@Service注解进行标记。同时,需要在Dubbo服务提供方的配置文件中配置Dubbo服务提供方的端口和协议等。 4. 配置Dubbo服务消费方 Dubbo服务消费方需要以Java类的形式调用Dubbo服务,可以使用Dubbo的@Reference注解进行标记。同时,需要在Dubbo服务消费方的配置文件中配置Dubbo服务消费方的端口和协议等。 5. 启动Dubbo服务 在Spring Boot启动配置中,需要注册并启动Dubbo服务的相关组件,包括服务提供方、服务消费方和Dubbo配置。 总的来说,Spring Boot和Dubbo整合的过程需要涉及到Dubbo依赖包的引入、服务配置的编写、服务提供方和服务消费方的配置和启动等方面。通过整合,可以使得开发人员能够更快地开发分布式应用,并且避免一些常见的错误。 ### 回答3: Spring Boot和Dubbo是两个流行的Java框架,它们都为开发者提供了快速、简单和可扩展的开发体验。Spring Boot提供了一个轻量级的框架来快速构建基于Spring的应用程序,而Dubbo则提供了一种可靠的远程服务调用和治理方案。在许多情况下,开发者需要将这两个框架结合起来,以便能够更好地管理和部署分布式应用程序。下面介绍Spring Boot和Dubbo整合的步骤。 1.引入Dubbo依赖 首先,在使用Spring Boot框架开发应用程序时,需要引入Dubbo框架的依赖。可以使用Maven或Gradle等构建工具来管理项目的依赖。在pom.xml文件中添加以下配置: ``` <dependency> <groupId>com.alibaba.boot</groupId> <artifactId>dubbo-spring-boot-starter</artifactId> <version>{latest.version}</version> </dependency> ``` 这个依赖将自动启用Dubbo配置,包括Dubbo服务发现、容错机制和协议等。 2.创建Dubbo服务 在Spring Boot应用程序中创建Dubbo服务非常简单,只需创建一个普通的Java接口,然后使用@DubboService注解将其标记为Dubbo服务。例如,我们可以创建一个UserService接口,如下所示: ``` public interface UserService { User getUserById(Integer id); } ``` 然后在实现类中使用@DubboService注解: ``` @Service @DubboService public class UserServiceImpl implements UserService { @Override public User getUserById(Integer id) { // TODO: query user from database return null; } } ``` 3.创建Dubbo消费者 类似于创建Dubbo服务,创建Dubbo消费者也非常简单。只需创建一个普通的Java接口,并使用@DubboReference注解来注入Dubbo服务,然后在业务逻辑中调用该服务即可。例如,我们可以创建一个OrderService接口,如下所示: ``` public interface OrderService { Order getOrderById(Integer id); } ``` 然后在消费者类中使用@DubboReference注解来注入UserService接口: ``` @Service public class OrderServiceImpl implements OrderService { @DubboReference private UserService userService; @Override public Order getOrderById(Integer id) { User user = userService.getUserById(id); Order order = new Order(); // TODO: query order from database and set user return order; } } ``` 通过以上步骤,我们已经成功集成了Spring Boot和Dubbo框架。现在我们可以使用Spring Boot的自动配置机制来快速构建Dubbo应用程序。在实际应用中,还可以使用Dubbo提供的多种协议和容错机制来保证应用程序的可靠性和稳定性。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值