SpringCloud实战项目全套学习教程连载中
PassJava 学习教程
简介
PassJava-Learning项目是PassJava(佳必过)项目的学习教程。对架构、业务、技术要点进行讲解。PassJava 是一款Java面试刷题
的开源系统,可以用零碎时间利用小程序查看常见面试题,夯实Java基础。PassJava 项目可以教会你如何搭建SpringBoot项目,Spring Cloud项目采用流行的技术,如 SpringBoot、MyBatis、Redis、 MySql、 MongoDB、 RabbitMQ、Elasticsearch,采用Docker容器化部署。更好的阅读体验
文档地址:http://www.jayh.club备用地址:https://jackson0714.github.io/PassJava-Learning文档连载目录
打造一款 刷Java 知识的小程序打造一款 刷Java 知识的小程序(二)01.五分钟搞懂分布式基础概念02.快速搭建Linux环境-运维必备03.配置虚拟机网络04.安装Docker05.Docker安装mysql06.Docker安装redis07.本地开发环境配置08.配置Git09.初始化项目和添加微服务10.PassJava-微服务划分图11.初始化数据库和表12.搭建管理后台13.自动生成前后端代码14.整合MyBatis-Plus实现CRUD15.生成所有微服务的CRUD代码16.Spring Cloud Alibaba 组件简介17.SpringCloud整合Alibaba-Nacos组件18.SpringCloud整合OpenFeign组件19.SpringCloud整合Alibaba-Nacos配置中心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);}
测试结果
总结:从配置文件中获取配置。
这种方式的缺点是什么呢?如果要修改配置参数,则需要重新启动服务。如果服务很多,则需要重启所有服务,非常不方便。
有没有什么办法不停服务修改配置而且使其生效呢?
答案:有的,用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 元数据
spring.application.name=passjava-memberspring.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
5.开启动态刷新配置功能
添加注解@RefreshScope开启动态刷新配置功能
@RefreshScope@RestController@RequestMapping("member/sample")public class SampleController {}
可以从控制台看到日志信息:
Refresh keys changed: [member.age]-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 -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.测试结果
访问:http://localhost:10000/member/sample/test-local-config
结果:nickname和age和Nacos后台配置一致
结论:只用在Nacos后台改配置即可实时修改配置。
注意:Nacos的配置项优先级高于application.propertite里面的配置。
7.命名空间
我们现在有5个微服务,每个微服务用到的配置可能都不一样,那不同微服务怎么样获取自己微服务的配置呢?
这里可以用到命名空间,我们针对每个微服务,都创建一个命名空间。
创建命名空间
# 创建5个命名空间passjava-channelpassjava-contentpassjava-memberpassjava-questionpassjava-study
命名空间下创建配置
我们打开配置列表菜单,可以看到有五个命名空间。
选中passjava-channel命名空间,然后新增配置项,与之前新增配置的步骤一致,也可以通过克隆命名空间来克隆配置。
修改指定的命名空间
bootstrap.properties配置命名空间
spring.cloud.nacos.config.namespace=passjava-member
测试配置是否生效
修改passjava-member.properties的配置内容
重启member服务
访问方法:/member/sample/test-local-config
执行结果:
{"msg": "success","code": 0,"nickname": ""悟空member"","age": 30}
说明获取的是passjava-member命名空间的配置
8.分组
如果我们有多套环境,比如开发环境,测试环境,生产环境,每一套环境的配置参数不一样,那配置中心该如何配置呢?
我们可以使用配置中心的分组
功能。每一套环境都是一套分组。
首先创建一套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
配置
2.配置中心新建mybatis.yml
配置
3.配置中心新建more.yml
配置
4.克隆dev环境配置到test和prod环境
5.bootstrap.properties增加nacos配置,application.yml注释配置
spring.application.name=passjava-memberspring.cloud.nacos.config.server-addr=127.0.0.1:8848spring.cloud.nacos.config.namespace=passjava-memberspring.cloud.nacos.config.group=prodspring.cloud.nacos.config.extension-configs[0].data-id=datasource.ymlspring.cloud.nacos.config.extension-configs[0].group=devspring.cloud.nacos.config.extension-configs[0].refresh=truespring.cloud.nacos.config.extension-configs[1].data-id=mybatis.ymlspring.cloud.nacos.config.extension-configs[1].group=devspring.cloud.nacos.config.extension-configs[1].refresh=truespring.cloud.nacos.config.extension-configs[2].data-id=more.ymlspring.cloud.nacos.config.extension-configs[2].group=devspring.cloud.nacos.config.extension-configs[2].refresh=true
6.测试配置是否生效
测试passjava-member.properties和more.yml配置是否生效
请求url:http://localhost:10000/member/sample/test-local-config
返回配置的nick和age,且端口是10000,且member服务注册到注册中心
{"msg": "success","code": 0,"nickname": ""悟空-prod1"","age": 22}
测试datasource.yml和mybatis.yml配置是否生效
请求url:http://localhost:10000/member/member/list
返回数据库查询结果
{"msg": "success","code": 0,"page": {"totalCount": 0,"pageSize": 10,"totalPage": 0,"currPage": 1,"list": []j}}
说明以上配置都生效了。
更多配置项
配置项 key 默认值 说明 服务端地址 spring.cloud.nacos.config.server-addr DataId前缀 spring.cloud.nacos.config.prefix spring.application.name Group spring.cloud.nacos.config.group DEFAULT_GROUP dataID后缀及内容文件格式 spring.cloud.nacos.config.file-extension properties dataId的后缀,同时也是配置内容的文件格式,目前只支持 properties 配置内容的编码方式 spring.cloud.nacos.config.encode UTF-8 配置的编码 获取配置的超时时间 spring.cloud.nacos.config.timeout 3000 单位为 ms 配置的命名空间 spring.cloud.nacos.config.namespace 常用场景之一是不同环境的配置的区分隔离,例如开发测试环境和生产环境的资源隔离等。 AccessKey spring.cloud.nacos.config.access-key SecretKey spring.cloud.nacos.config.secret-key 相对路径 spring.cloud.nacos.config.context-path 服务端 API 的相对路径 接入点 spring.cloud.nacos.config.endpoint UTF-8 地域的某个服务的入口域名,通过此域名可以动态地拿到服务端地址 是否开启监听和自动刷新 spring.cloud.nacos.config.refresh-enabled true10.使用Nacos总结
1.引入Nacos依赖
2.配置Nacos数据源
3.配置中心配置数据集DataId
和配置内容
4.开启动态刷新配置@RefreshScope
5.获取配置项的值@value
6.优先使用配置中心的配置
7.使用命名空间namespace
来创建各服务的配置
8.使用分组group
来区分不同环境
9.使用多配置集extension-configs
区分不同类型的配置
代码地址
/Jackson0714/PassJava-Platform