文章目录
1.在父工程中添加spring-cloud-alibaba的管理依赖:
一、认识Nacos
Nacos 是阿里巴巴的产品,现在是 SpringCloud 中的一个组件。相比 Eureka 功能更加丰富,在国内受欢迎程度较高
二、服务注册到Nacos
1.在父工程中添加spring-cloud-alibaba的管理依赖:
2、添加nacos的客户端依赖
3、修改application.yml文件
三、Nacos服务分级存储模型
1、修改application.yml
2、在Nacos控制台可以看到集群变化
3、Nacos服务分级存储模型
- 一级是服务,例如 userservice
- 二级是集群,例如杭州或上海
- 三级是实例,例如杭州机房的某台部署了userservice的服务器
4、如何设置实例的集群属性
修改application.yml文件,添加spring.cloud.nacos.discovery.cluster-name属性即可
四、NacosRule负载均衡
1、根据集群负载均衡
2、NacosRule负载均衡策略
- 优先选择同集群服务实例列表
- 本地集群找不到提供者,才去其他集群寻找,并且会警告
- 确定了可用的实例列表后,再采用随机负载均衡挑选实例
五、服务实例的权重设置
1、在Nacos控制台可以设置实例的权重值,说先选中实例后面的编辑按钮
2、将权重设置为0.1,测试发现8082被访问到的频率大大降低
3、实例的权重控制
- Nacos控制台可以设置实例的权重值,0~1之间
- 同集群内的多个实例,权重越高被访问的频率越高
- 权重设置为0则完全不会被访问
六、环境隔离-namespace
Nacos中服务存储和数据存储的最外层都是一个名为namespace的东西,用来做最外层隔离
1、在Nacos控制台可以创建namespace,用来隔离不同环境
2、然后填写一个新的命名空间信息
3、保存后会在控制台看到这个命名空间的id:
4、修改application.yml,添加namespace
5、Nacos环境隔离:
- namespace用来做环境隔离
- 每个namespace都有唯一id
- 不同namespace下的服务不可见
七、Nacos注册中心原理
八、临时实例和非临时实例
服务注册到Nacos时,可以选择注册为临时或非临时实例,通过下面配置来设置
临时实例宕机时,会从nacos的服务列表中删除,而非临时实例则不会
九、Nacos和Eureka区别
- Nacos与eureka的共同点
- 都支持服务注册和服务拉去
- 都支持服务提供者心跳方式做健康检测
- Nacos与Eureka的区别
- Nacos支持服务端主动检测提供者状态:临时实例采用心跳模式,非临时实例采用主动检测方式
- 临时实例心跳不正常会被剔除,非临时实例则不会被剔除
- Nacos支持服务列表变更的消息推送模式,服务列表更新更及时
- Nacos集群模式采用AP方式,当集群中存在非临时实例时,采用CP模式;Eureka采用AP方式
十、统一配置管理
配置更改热更新
1、在Nacos中添加配置信息
2、在弹出表单中填写配置信息
十一、微服务配置拉取
配置获取的步骤如下:
1、引入Nacos的配置管理客户端依赖
2、在userservice的 resource 目录添加一个 bootstrap.yml 文件,这个文件是引导文件。优先级高于 application.yml,服务名称+开发环境+文件后缀名决定了程序启动时去nacos读取哪个文件
十二、配置热更新
Nacos中的配置文件变更后,微服务无需重启就可以感知。不过需要通过下面两种配置实现
方式一:在 @Value 注入的变量所在类上添加注解 @RefreshScope
方式二:使用 @ConfigurationProperties 注解
十三、多环境配置共享
微服务启动时会从nacos读取多个配置文件
- 服务名称-开发环境.yaml,例如:userservice-dev.yaml
- 服务名称.yaml,例如:userservice.yaml
无论 profile 何如变化,服务名称.yaml 这个文件一定会被加载,因为多环境共享配置可以写入这个文件
多种配置的优先级: