Spring-Cloud-Gateway集成Nacos如何做负载均衡?
迪丽瓦拉
2024-05-29 12:05:40
0

spring-cloud-alibaba的低版本

如果所用的SpringCloud和Nacos的版本信息如下:

Hoxton.SR10
2.2.6.RELEASE

网关的依赖如下:

org.springframework.cloudspring-cloud-starter-gatewaycom.alibaba.cloudspring-cloud-starter-alibaba-nacos-discovery

看下它是如何做路由转发的。
org.springframework.cloud.gateway.handler.FilteringWebHandler.GatewayFilterAdapter#filter()上打断点:
在这里插入图片描述

继续往下执行:在这里插入图片描述
这里就把请求匹配到了路由表中的某条路由记录,然后把请求的url做了重写。
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述
以上可以看出来,底层还是用ribbon做的负载均衡。

从nacos的依赖中也能看出来:
在这里插入图片描述

spring-cloud-alibaba的高版本

Springcloud2020开始弃用了Ribbon,因此Alibaba在2021版本nacos中删除了Ribbon的jar包,改用SpringCloudLoadbalancer 来实现负载均衡,因此如果SpringCloud的版本和SpringCloudAlibaba的版本是如下

2021.0.5
2021.0.4.0

gateway是需要单独引入负载均衡组件的:

org.springframework.cloudspring-cloud-starter-gatewayorg.springframework.cloudspring-cloud-starter-loadbalancercom.alibaba.cloudspring-cloud-starter-alibaba-nacos-discovery

gateway的配置:

spring:cloud:nacos:discovery:server-addr: localhost:8848loadbalancer:enabled: true # 默认就是truenacos:enabled: true # 默认没有开启gateway:discovery:locator:# true 默认路由机制# 开启服务注册和发现功能,服务网关自动根据服务发现为每一个服务创建一个路由,这个路由将以(大写服务名)开头的请求路径转发到对应的服务中# 访问地址:127.0.0.1:8800/大写服务名/服务上下文/Controller/Method## false 关闭默认路由机制,需要手动配置routes,默认通过路由名进行跳转的方式将失效,将请求路径上的服务名配置为小写# 访问地址:127.0.0.1:8800/小写写服务名/服务上下文/Controller/Methodenabled: false # 默认就是falselower-case-service-id: trueroutes:- id: userserviceuri: lb://userservicepredicates:- Path=/user/**

同样打断点跟一下:
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述
测试代码下载:https://github.com/xjs1919/enumdemo/tree/master/gateway-demo

相关内容