背景
配置的数据存在变动情况,在项目开发时,可以重启服务器进行更新,但项目发布后,就不能存在这种操作,所以配置中心出现了
含义
配置中心最基础的功能就是存储一个键值对,用户发布一个配置(configKey),然后客户端获取这个配置项(configValue);进阶的功能就是当某个配置项发生变更时,不停机就可以动态刷新服务内部的配置项.
语法
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
</dependency>
修改配置文件
#application改成boostrap.yml文件,注意添加完依赖才能生效
spring:
application:
name: sca-provider
cloud:
nacos:
discovery:
server-addr: 127.0.0.1:8848
config:
server-addr: 127.0.0.1:8848
group: DEFAULT_GROUP # Group, default is DEFAULT_GROUP
file-extension: yml # Configure the data format of the content, default to properties
添加配置(这里是日志配置)
//需要的包
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
@RefreshScope //动态刷新配置
@RestController
public class ProviderController{
private static final log = LoggerFactory.getLogger(ProviderController.class);
@Value("${logging.level.com.cy:error}")
private String logLevel;
@GetMapping("/provider/doGetLogLevel")
public String doGetLogLevel(){
log.trace("==log.trace==");//跟踪
log.debug("==log.debug==");//调试
log.info("==log.info==");//常规信息
log.warn("==log.warn==");//警告
log.error("==log.error==");//错误信息
return "log level is "+logLevel;
}
}
Nacos配置管理模型
由三个部分构成,分为: namespace/group/DataId
默认创建的配置都存储到了public命名空间
关系
具体操作
#添加config下的namespace可以确定具体的哪个命名空间
#修改group可以确定属于哪个组的配置文件
spring:
cloud:
nacos:
config:
group: DEFAULT_GROUP_51
namespace: 6058fd3f-0d4d-44f2-85d6-5fc7d2348046
共享配置设计及读取
# 共享配置
spring:
cloud:
nacos:
config:
#group: DEFAULT_GROUP_51
namespace: 6058fd3f-0d4d-44f2-85d6-5fc7d2348046
shared-configs[0]:
data-id: app-common-dev.yml #共享文件的Id
group: DEFAULT_GROUP_51 #共享文件的组名
refresh: true #默认false
在指定的业务类中读取和应用共享配置
@Value("${page.pageSize:10}")
private Integer pageSize;
@GetMapping("/provider/doGetPageSize")
public String doGetPageSize(){
//return String.format()
return "page size is "+pageSize;
}