Nacos注册中心

Nacos服务分级存储模型

  1. 一级是服务,例如userservice
  2. 二级是集群,例如杭州或上海
  3. 三级是实例,例如杭州机房的某台部署了userservice的服务器

服务跨集群调用问题

服务调用尽可能选择本地集群的服务,跨集群调用延迟较高本地集群不可访问时,再去访问其它集群

image.png

服务集群属性

修改application.yml,添加如下内容

  1. spring:
  2. datasource:
  3. url: jdbc:mysql://localhost:3306/cloud_order?serverTimezone=GMT%2B8&useSSL=false&allowPublicKeyRetrieval=true
  4. username: root
  5. password: root
  6. driver-class-name: com.mysql.cj.jdbc.Driver
  7. application:
  8. name: userServer
  9. cloud:
  10. nacos:
  11. server-addr: localhost:8848
  12. #配置集群名称,也就是机房位置,例如:HZ,杭州
  13. discovery:
  14. cluster-name: HZ

根据集群负载均衡

配置yml文件

  1. userService:
  2. ribbon:
  3. NFLoadBalancerRuleClassName: com.alibaba.cloud.nacos.ribbon.NacosRule # 负载均衡规则

根据权重负载均衡

在Nacos中后台配置权重 0-1 ,权重越大访问频率越高
image.png

环境隔离

Nacos中使用namespace进行环境隔离
image.png
在yml中加入配置选项

  1. spring:
  2. cloud:
  3. nacos:
  4. server-addr: localhost:8848
  5. discovery:
  6. cluster-name: SH
  7. namespace: 452e6df5-0717-48db-9020-1f4439f96d6e #命名空间的ID

Nacos配置管理

1.1.统一配置管理

1.1.1.在nacos中添加配置文件

在Nacos中的配置列表中新建配置
image.png
image.png

注意:项目的核心配置,需要热更新的配置才有放到nacos管理的必要。基本不会变更的一些配置还是保存在微服务本地比较好。

1.1.2.从微服务拉取配置

微服务要拉取nacos中管理的配置,并且与本地的application.yml配置合并,才能完成项目启动。
但如果尚未读取application.yml,又如何得知nacos地址呢?
因此spring引入了一种新的配置文件:bootstrap.yaml文件,会在application.yml之前被读取,流程如下:

image.png
1)引入nacos-config依赖
首先,在user-service服务中,引入nacos-config的客户端依赖:

  1. <!--nacos配置管理依赖-->
  2. <dependency>
  3. <groupId>com.alibaba.cloud</groupId>
  4. <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
  5. </dependency>

2)添加bootstrap.yaml
然后,在user-service中添加一个bootstrap.yaml文件,内容如下:

  1. spring:
  2. application:
  3. name: userservice # 服务名称
  4. profiles:
  5. active: dev #开发环境,这里是dev
  6. cloud:
  7. nacos:
  8. server-addr: localhost:8848 # Nacos地址
  9. config:
  10. file-extension: yaml # 文件后缀名

这里会根据spring.cloud.nacos.server-addr获取nacos地址,再根据
${spring.application.name}-${spring.profiles.active}.${spring.cloud.nacos.config.file-extension}作为文件id,来读取配置。
本例中,就是去读取userservice-dev.yaml:
image.png
3)读取nacos配置
在user-service中的UserController中添加业务逻辑,读取pattern.dateformat配置:

image.png1.2 Nacos实现热更新

通过@RefreshScop 或者 @ComponentProperties()实现

  • 在类的方法上新增@RefreshScop属性

image.png

  • 新增配置类,添加@ConfigurationProperties(prefix = “key”)

image.png

1.3.配置共享

其实微服务启动时,会去nacos读取多个配置文件,例如:

  • [spring.application.name]-[spring.profiles.active].yaml,例如:userservice-dev.yaml
  • [spring.application.name].yaml,例如:userservice.yaml

[spring.application.name].yaml不包含环境,因此可以被多个环境共享。

1)添加一个环境共享配置

image.png

2) 读取配置文件信息

image.png

3)运行两个UserApplication,使用不同的profile

image.png

4)重启环境

这个使用的是不包含环境的
image.png
这个使用的是包含环境的
image.png

5)配置共享的优先级

image.png