讀寫nacos的配置中心的參數(shù)及變動監(jiān)聽方式
nacos有配置中心的功能,那么spring應(yīng)用如何下載nacos的配置參數(shù)?
最簡單的方法
是借組sentinel的NacosDataSource完成這個操作,如下例子:

@Configuration
@Slf4j
@Getter
public class AuthenConfig {
@Value("${spring.cloud.nacos.discovery.server-addr}")
private String nacosAddrs;
private String groupId="my-seta-business";
private String dataId="my-seta-business:authen-Config";
private EasyShiroProperties properties;
@PostConstruct
public void init(){
ReadableDataSource<String, EasyShiroProperties> nacosDataSource = new NacosDataSource<>(nacosAddrs, groupId, dataId,
source -> JsonUtils.fromJson(source, new TypeReference<>() {
}));
synchronized (nacosDataSource.getProperty()) {
nacosDataSource.getProperty().addListener(new PropertyListener(){
private void updateLocal(Object value){
properties=(EasyShiroProperties)value;
}
@Override
public void configUpdate(Object value) { //nacos的配置更新時觸發(fā)
log.info("configUpdate:"+value);
updateLocal(value);
}
@Override
public void configLoad(Object value) {//第一次下載nacos配置時觸發(fā)
log.info("configLoad:"+value);
updateLocal(value);
}
});
}
}
}
監(jiān)聽器有兩個事件
一個是首次下載觸發(fā)的configLoad,一個是nacos配置更新觸發(fā)的configUpload。
那么如何用代碼更新nacos上的配置?用ConfigService的publishConfig,下面例子:
String groupId="my-seta-business";
String dataId="my-seta-business:authen-Config";
try {
ConfigService configService = NacosFactory.createConfigService("128.30.14.249:8848");
System.out.println(configService.publishConfig(dataId, groupId, "{\"sessionTimeOut\":3600,\"cacheEnabled\":true,\"sessionRegion\":\"my-seata-business-region\",\"sessionTokenName\":\"access-token\",\"jwtTokenName\":\"access-token\"}"));
} catch (NacosException e) {
e.printStackTrace();
}
值得注意的是
同一個服務(wù)里面即使用上述方法更新配置到nacos,也不會觸發(fā)configUpdate事件,configUpdate必須是本服務(wù)以外的地方發(fā)生更新才會觸發(fā),可見作者比較嚴(yán)謹(jǐn)。
如果我沒用sentinel,只想用ConfigService監(jiān)聽配置中心的數(shù)據(jù)異動又怎樣做呢?ConfigService也有監(jiān)聽事件,代碼如下 :
/**
* Created by rocklee on 2022/4/20 14:13
*/
@Slf4j
@Configuration
public class AccountConfig implements InitializingBean , DisposableBean {
@Value("${spring.application.name}")
private String app;
@Value("${spring.profiles.active:}")
private String profile;
@Value("${spring.cloud.nacos.config.file-extension}")
private String fileExtension;
@Value("${spring.cloud.nacos.config.server-addr}")
private String configServerAddr;
private ConfigService configService;
@PostConstruct
public void init(){
}
@Override
public void afterPropertiesSet() throws Exception {
String dataId=app+(StringUtils.isBlank(profile)?"": "-"+profile)+"."+fileExtension;
final String group="DEFAULT_GROUP";
Properties properties=new Properties();
properties.put(PropertyKeyConst.SERVER_ADDR, configServerAddr);
configService= NacosFactory.createConfigService(properties);
log.info("nacos config:"+configService.getConfig(dataId,group,1000));
try {
configService.addListener(dataId, group, new AbstractListener() {
@Override
public void receiveConfigInfo(String configInfo) {
System.out.println(configInfo);
}
});
} catch (NacosException e) {
e.printStackTrace();
}
}
@Override
public void destroy() throws Exception {
configService.shutDown();
}
}
總結(jié)
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
通過Spring AOP實現(xiàn)異常捕捉機(jī)制
在開發(fā)過程中,異常處理是一個不可忽視的重要環(huán)節(jié),合理、優(yōu)雅地處理異常不僅能提高代碼的魯棒性,還能提升系統(tǒng)的用戶體驗,本文將介紹如何通過Spring AOP實現(xiàn)一個高效的異常捕捉機(jī)制,使得異常處理變得更加優(yōu)雅和統(tǒng)一,需要的朋友可以參考下2024-08-08
在SpringBoot項目中實現(xiàn)讀寫分離的流程步驟
SpringBoot作為一種快速開發(fā)框架,廣泛應(yīng)用于Java項目中,在一些大型應(yīng)用中,數(shù)據(jù)庫的讀寫分離是提升性能和擴(kuò)展性的一種重要手段,本文將介紹如何在SpringBoot項目中優(yōu)雅地實現(xiàn)讀寫分離,并通過適當(dāng)?shù)拇a插入,詳細(xì)展開實現(xiàn)步驟,同時進(jìn)行拓展和分析2023-11-11
java 使用URLDecoder和URLEncoder對中文進(jìn)行處理
這篇文章主要介紹了java 使用URLDecoder和URLEncoder對中文進(jìn)行處理的相關(guān)資料,需要的朋友可以參考下2017-02-02
深度解析Java中的JSONObject從基礎(chǔ)到高級應(yīng)用
在當(dāng)今前后端分離的架構(gòu)中,JSONObject已成為Java開發(fā)者處理JSON數(shù)據(jù)的瑞士軍刀,本文將深入解析JSONObject的核心機(jī)制與實戰(zhàn)技巧,感興趣的朋友跟隨小編一起看看吧2025-09-09
淺談@RequestBody和@RequestParam可以同時使用
這篇文章主要介紹了@RequestBody和@RequestParam可以同時使用,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-03-03

