背景
配置的数据存在变动情况,在项目开发时,可以重启服务器进行更新,但项目发布后,就不能存在这种操作,所以配置中心出现了
含义
配置中心最基础的功能就是存储一个键值对,用户发布一个配置(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;
}
本文介绍了如何在项目中使用Nacos作为配置中心,通过存储键值对并动态刷新服务内部配置,避免了项目发布后重启服务器的需求。详细讲解了Nacos配置的添加、修改以及在Spring Boot应用中的使用,包括`bootstrap.yml`配置、`@RefreshScope`注解、日志级别动态调整等。同时,还展示了如何进行命名空间、组和DataId的管理,以及共享配置的设计与读取。
1497

被折叠的 条评论
为什么被折叠?



