0%

Nacos及Gateway的使用

使用Nacos作为注册中心和配置中心及Gateway网关的使用


一、使用Nacos配置中心统一管理配置

1、引入依赖
1
2
3
4
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
</dependency>
2、创建一个bootstrap.properties
1
2
spring.application.name=mall-coupon
spring.cloud.nacos.config.server-addr=127.0.0.1:8848
3、需要给配置中心默认添加一个数据集(当前应用名.properties)

4、给当前应用名.properties添加任何配置

5、动态获取配置

​ 在Controller上添加注解@RefreshScope:动态获取并刷新配置

​ @Value:(“${配置项的名字}”):获取配置

1
2
3
4
5
6
7
8
9
10
11
@RefreshScope
@RestController
@RequestMapping("coupon/coupon")
public class CouponController {
@Autowired
private CouponService couponService;

@Value("${coupon.user.name}")
private String name;
@Value("${coupon.user.age}")
private Integer age;

如果配置中心和当前应用的配置文件中配置了相同的项,优先使用配置中心的配置

二、细节

1、命名空间:配置隔离

​ 默认:public(保留空间);默认新增的所有配置都在public空间。

​ a)、开发、测试、生产:利用命名空间来做环境隔离。

在bootstrap.properties配置上,需要使用哪个命名空间的配置

1
2
##值为命名空间的值
spring.cloud.nacos.config.namespace=e01c3046-2b37-4f3f-9efc-e3aa88d1bc2a

​ b)、每一个微服务之间互相隔离配置,每一个微服务都创建自己的命名空间,只加载自己命名空间下的所有配置

1
spring.cloud.nacos.config.namespace=40b47f31-5902-44cb-a90c-41c8b564d32d

2、配置集:所有配置的集合
3、配置集ID(Data ID)
4、配置分组

​ 默认所有的配置集都属于DEFAULT_GROUP配置组

1
2
##指定使用哪个配置组
spring.cloud.nacos.config.group=dev

每个微服务创建自己的命名空间,

三、同时加载多个配置集

1
2
3
4
5
6
7
8
9
10
11
spring.cloud.nacos.config.ext-config[0].data-id=datasource.yml
spring.cloud.nacos.config.ext-config[0].group=dev
spring.cloud.nacos.config.ext-config[0].refresh=true

spring.cloud.nacos.config.ext-config[1].data-id=mybatis.yml
spring.cloud.nacos.config.ext-config[1].group=dev
spring.cloud.nacos.config.ext-config[1].refresh=true

spring.cloud.nacos.config.ext-config[2].data-id=others.yml
spring.cloud.nacos.config.ext-config[2].group=dev
spring.cloud.nacos.config.ext-config[2].refresh=true

​ 1、每个微服务任何配置信息,任何配置文件都可以放在配置中心中

​ 2、只需要在bootstrap.properties说明加载配置中心中哪些配置文件即可

​ 3、@Value、@ConfigurationProperties

​ 以前spring boot任何从配置文件中获取值的方法都可以使用(优先配置中心有的)

Nacos官方文档:https://nacos.io/zh-cn/docs/quick-start.html


四、网关

工作流程:客户端想要发送一个请求给目标服务,中间加了一层Gateway做的API网关,客户端先将请求发给API网关,Gateway通过GatewayHandlerMapping映射信息查看当前请求能否被路由或者被处理,如果能被处理,将请求交给Handler,Handler经过一系列的Filter处理请求,处理完毕后将请求路由给指定的服务,指定服务处理完毕后,再次交给Filter处理返回,最终返回给客户端。

总结:请求到达网关,网关利用断言Predicate判断请求是否符合某个路由Route规则,如果符合就按照路由规则路由到指定的地方。到达指定地方就需要经给一些特定的Filter

配置示例
1
2
3
4
5
6
7
8
9
10
11
12
13
spring:
cloud:
gateway:
routes:
- id: test_route
uri: https://www.baidu.com
predicates:
- Query=url,baidu

- id: qq_route
uri: https://www.qq.com
predicates:
- Query=url,qq

Gateway官方文档:https://docs.spring.io/spring-cloud-gateway/docs