#博学谷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。这里,直连提供者就完成了