19.SpringCloud实战项目-SpringCloud整合Alibaba-Nacos配置中心

SpringCloud实战项目全套学习教程连载中

PassJava 学习教程 简介

PassJava-Learning项目是PassJava(佳必过)项目的学习教程。对架构、业务、技术要点进行讲解。

PassJava 是一款Java面试刷题的开源系统,可以用零碎时间利用小程序查看常见面试题,夯实Java基础。

PassJava 项目可以教会你如何搭建SpringBoot项目,Spring Cloud项目

采用流行的技术,如 SpringBoot、MyBatis、Redis、 MySql、 MongoDB、 RabbitMQ、Elasticsearch,采用Docker容器化部署。

更好的阅读体验

文档地址:

备用地址:https://jackson0714.github.io/PassJava-Learning

文档连载目录

打造一款 刷Java 知识的小程序

打造一款 刷Java 知识的小程序(二)

1.传统配置方式

application.properties文件中定义两个配置:

member.nickname = "悟空聊架构" member.age = "18"

示例控制器中定义私有变量nickname和age,@value代表从配置中取值

@Value("${member.nickname}") private String nickname; @Value("$member.age") private Integer age;

示例控制器中定义方法:获取nick和age的值

@RequestMapping("/test-local-config") public R testLocalConfig() { return R.ok().put("nickname", nickname).put("age", age); }

测试结果

mark

总结:从配置文件中获取配置。

这种方式的缺点是什么呢?如果要修改配置参数,则需要重新启动服务。如果服务很多,则需要重启所有服务,非常不方便。

有没有什么办法不停服务修改配置而且使其生效呢?

答案:有的,用Spring Cloud Alibaba的Nacos 组件就可以完成。

2.引入Nacos依赖

PassJava-Common项目的pom.xml文件引入Spring Cloud Alibaba Nacos Config依赖

<dependency> <groupId>com.alibaba.cloud</groupId> <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId> </dependency> 3.配置Nacos元数据

passjava-member 添加 /src/main/resources/bootstrap.properties 配置文件(注意:bootstrap.properties 优先级高于其他配置文件)

配置 Nacos Config 元数据

bootstrap.properties

spring.application.name=passjava-member spring.cloud.nacos.config.server-addr=127.0.0.1:8848 4.Nacos后台新增配置

Data ID: passjava-member.properties

Group: DEFAULT_GROUP

配置格式:

member.nick="悟空" member.age=10

Nacos后台新增配置

5.开启动态刷新配置功能

添加注解@RefreshScope开启动态刷新配置功能

@RefreshScope @RestController @RequestMapping("member/sample") public class SampleController {}

可以从控制台看到日志信息:

Refresh keys changed: [member.age] 2020-04-19 23:34:07.154 INFO 8796 --- [-127.0.0.1_8848] c.a.nacos.client.config.impl.CacheData : [fixed-127.0.0.1_8848] [notify-ok] dataId=passjava-member.properties, group=DEFAULT_GROUP, md5=df136e146c83cbf857567e75acb11e2b, listener=com.alibaba.cloud.nacos.refresh.NacosContextRefresher$1@4f49b78b 2020-04-19 23:34:07.154 INFO 8796 --- [-127.0.0.1_8848] c.a.nacos.client.config.impl.CacheData : [fixed-127.0.0.1_8848] [notify-listener] time cost=529ms in ClientWorker, dataId=passjava-member.properties, group=DEFAULT_GROUP, md5=df136e146c83cbf857567e75acb11e2b, listener=com.alibaba.cloud.nacos.refresh.NacosContextRefresher$1@4f49b78b

member.age 更新了,通知了member服务,刷新了配置。对应的配置id为passjava-member.properties,分组为DEFAULT_GROUP。监听器为com.alibaba.cloud.nacos.refresh.NacosContextRefresher

6.测试结果

访问::10000/member/sample/test-local-config

结果:nickname和age和Nacos后台配置一致

结论:只用在Nacos后台改配置即可实时修改配置。

注意:Nacos的配置项优先级高于application.propertite里面的配置。

测试结果

7.命名空间

我们现在有5个微服务,每个微服务用到的配置可能都不一样,那不同微服务怎么样获取自己微服务的配置呢?

这里可以用到命名空间,我们针对每个微服务,都创建一个命名空间。

创建命名空间

创建命名空间

# 创建5个命名空间 passjava-channel passjava-content passjava-member passjava-question passjava-study

命名空间

命名空间下创建配置

我们打开配置列表菜单,可以看到有五个命名空间。

命名空间下创建配置

选中passjava-channel命名空间,然后新增配置项,与之前新增配置的步骤一致,也可以通过克隆命名空间来克隆配置。

克隆配置

修改指定的命名空间

bootstrap.properties配置命名空间

spring.cloud.nacos.config.namespace=passjava-member

测试配置是否生效

修改passjava-member.properties的配置内容

passjava-member.properties

重启member服务

访问方法:/member/sample/test-local-config

执行结果:

{ "msg": "success", "code": 0, "nickname": "\"悟空member\"", "age": 30 }

说明获取的是passjava-member命名空间的配置

8.分组

如果我们有多套环境,比如开发环境,测试环境,生产环境,每一套环境的配置参数不一样,那配置中心该如何配置呢?

我们可以使用配置中心的分组功能。每一套环境都是一套分组。

首先创建一套dev环境配置项,然后克隆配置到test和prod环境

dev环境

dev、test、prod分组

bootstrap.properties配置当前使用的分组:prod

spring.cloud.nacos.config.group=prod

测试获取生产环境配置

{ "msg": "success", "code": 0, "nickname": "\"悟空-prod\"", "age": 10 }

可以看到获取到的是prod分组的配置

9.多配置集

我们可以将application.yml文件中的datasource、mybatis-plus等配置进行拆解,放到配置中心。group可以创建3套,dev/test/prod。

1.配置中心新建datasource.yml 配置

datasource.yml 配置

2.配置中心新建mybatis.yml 配置

mybatis.yml配置

3.配置中心新建more.yml 配置

more.yml配置

4.克隆dev环境配置到test和prod环境

mark

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/wssffj.html