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
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值