nacos 阿里旗下的开源我的项目,一个更易于构建云原生利用的动静服务发现、配置管理和服务治理平台。
随着我国科技的提高,越来越多的开源技术来自我自豪的中国,以前要理解某项技术除了查看国内大佬博主的文章就是硬着头皮去看官网的英文文档。当初好多了,国内的开源我的项目官网文档首先就得有中文版的,然而,这 nacos 的手册写的略显搪塞????。
最近上线了一个我的项目,上线之前整顿生产环境的配置真是让人头大,惟恐有脱漏或者填错的中央,如果在现场配置的有问题,改过后还得重启服务能力失效,这不,对方把咱们的端口少写了个数字,某性能呈现问题,白天他们又不能重启,只能等到早晨解决。如果可能应用 nacos 作为动静的配置核心,间接改配置不须要重启就能够解决了。
本章内容介绍的是 spring-boot 集成 nacos , 不是 spring-cloud , 导的包不一样应用起来也有点差别。
nacos 服务端
首先下载安装 nacos 服务端
启动办法参考 Nacos 疾速入门
拜访地址 http://127.0.0.1:8848/nacos
; 初始用户名和明码都是 nacos
创立命名空间
登陆后左侧导航栏抉择命名空间,右上角创立命名空间,别离创立 dev 和 prod 作为开发和生产环境的配置,不同空间相互隔离。用来辨别环境十分适合。
创立配置文件
左侧导航栏 > 配置管理 - 配置列表
创立配置文件须要填写 DataId 和GroupId, 以及 配置内容
spring-boot 集成 nacos 配置核心
增加 nacos 配置核心的依赖
<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
yml 配置 nacos 服务端地址和命名空间
创立配置文件 application-dev.yml
和application-prod.yml
依据在 nacos 服务端控制台创立的两个命名空间的 ID 别离填写开发环境和生产环境的配置
- application-dev.yml
nacos:
config:
namespace: 133c9c90-6d9c-45cd-8067-06f853607940
server-addr: 127.0.0.1:8848
- application-prod.yml
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
示意开启动静刷新
@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
留神:如果之前没有做长久化,做了长久化之后会把之前的配置干掉。????
java SDK
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);
以上配置内容的获取,增加,删除,监听都是全量的。