nacos 阿里旗下的开源项目,一个更易于构建云原生应用的动态服务发现、配置管理和服务管理平台。html
随着我国科技的进步,愈来愈多的开源技术来自我骄傲的中国,之前要了解某项技术除了查看国内大佬博主的文章就是硬着头皮去看官方的英文文档。如今好多了,国内的开源项目官方文档首先就得有中文版的,可是,这nacos的手册写的略显敷衍🤔。
最近上线了一个项目,上线以前整理生产环境的配置真是让人头大,生怕有遗漏或者填错的地方,若是在现场配置的有问题,改正后还得重启服务才能生效,这不,对方把咱们的端口少写了个数字,某功能出现问题,白天他们又不能重启,只能等到晚上解决。若是可以使用nacos做为动态的配置中心,直接改配置不须要重启就能够解决了。
本章内容介绍的是spring-boot集成nacos ,不是spring-cloud ,导的包不同使用起来也有点差别。java
首先下载安装nacos服务端
启动方法参考Nacos 快速入门
访问地址 http://127.0.0.1:8848/nacos
; 初始用户名和密码都是nacosmysql
登录后左侧导航栏选择命名空间,右上角建立命名空间,分别建立dev 和prod 做为开发和生产环境的配置,不一样空间互相隔离。用来区分环境很是合适。git
左侧导航栏>配置管理-配置列表
建立配置文件须要填写DataId 和GroupId,以及配置内容github
添加nacos配置中心的依赖spring
<dependency> <groupId>com.alibaba.boot</groupId> <artifactId>nacos-config-spring-boot-starter</artifactId> <version>${latest.version}</version> </dependency>
springboot 版本 2.3.2.RELEASE
nacos-config 版本 0.2.7
sql
建立配置文件application-dev.yml
和application-prod.yml
根据在nacos服务端控制台建立的两个命名空间的ID分别填写到开发环境和生产环境的yml文件里数据库
nacos: config: namespace: 133c9c90-6d9c-45cd-8067-06f853607940 server-addr: 127.0.0.1:8848
nacos: config: namespace: 72008218-19b0-4960-ab44-a0cbdd8097a0 server-addr: 127.0.0.1:8848
dataId
和 groupId
@NacosPropertySource
注解填写dataId
和 groupId
,autoRefreshed = true
表示动态刷新的总开关,ture:开启,默认是false.
读取多个配置文件就写多个注解,若是两个配置文件中有相同的配置,排在上面的注解读取的配置内容优先级最高。
同一个配置文件能够被同空间的应用共享。安全
@SpringBootApplication @NacosPropertySource(dataId = "mashu-demo", autoRefreshed = true, groupId = "USER_GROUP") @NacosPropertySource(dataId = "dashu-demo", autoRefreshed = true, groupId = "USER_GROUP")
@NacosValue
注解获取配置内容,autoRefreshed = true
表示开启动态刷新springboot
@NacosValue(value = "${name}", autoRefreshed = true) private String name;
启动参数根据-Dspring.profiles.active=dev
或-Dspring.profiles.active=prod
切换开发和生产环境
读取application-dev.yml 仍是 application-prod.yml 依据是"-"
后面的单词,即: dev/prod
至此多环境动态配置完成。
为了保证数据的安全性,nacos还支持将数据同步到数据库。
这个须要在nacos服务端配置,在下载的nacos安装包里面nacos-server-1.2.1\nacos\conf\nacos-mysql.sql
有msyql初始化的sql脚本。
根据实际状况修改配置文件nacos-server-1.2.1\nacos\conf\application.properties
spring.datasource.platform=mysql ### Count of DB: db.num=1 ### Connect URL of DB: db.url.0=jdbc:mysql://127.0.0.1:3306/nacos?characterEncoding=utf8&connectTimeout=1000&socketTimeout=3000&autoReconnect=true db.user=root db.password=123456
注意:若是以前没有作持久化,作了持久化以后会把以前的配置干掉。😒
nacos还支持java客户端对配置内容的操做和配置变动的监听。
1.导包:
<dependency> <groupId>com.alibaba.nacos</groupId> <artifactId>nacos-client</artifactId> <version>1.2.0</version> </dependency>
2.根据ip和命名空间获取配置文件对象ConfigService
String serverAddr = "127.0.0.1:8848"; String namespace = "72008218-19b0-4960-ab44-a0cbdd8097a0"; Properties properties = new Properties(); properties.put("serverAddr", serverAddr); properties.put("namespace", namespace); ConfigService configService = NacosFactory.createConfigService(properties);
configService对象有几个经常使用的方法:
1.getConfig()得到配置内容
String dataId = "dashu-demo"; String groupId = "USER_GROUP"; String content = configService.getConfig(dataId, groupId, 5000);
2.publishConfig()发布配置
String content = "name: mashu"; configService.publishConfig(dataId, group, content);
3.removeConfig()删除配置
configService.removeConfig(dataId, group);
4.addListener()添加监听
Listener listener = new Listener() { @Override public void receiveConfigInfo(String configInfo) { System.out.println("变动后读取到的配置内容:" + "\r\n" + configInfo); } @Override public Executor getExecutor() { return null; } configService.addListener(dataId, groupId, listener);
5.removeListener()删除监听
configService.removeListener(dataId, groupId, listener);
以上配置内容的获取,添加,删除,监听都是全量的。