spring-cloud 配置管理
作用:
- 实现配置热更新
- 实现网关配置热部署
配置模板
spring:
datasource:
driver-class-name: com.mysql.cj.jdbc.Driver
url: jdbc:mysql://${db.gulimall.host:192.168.229.128}:${db.gulimall.port:3306}/{$db.gulimall.database:my_db}
username: ${db.gulimall.user:root}
password: ${db.gulimall.password:dzjdzj}
${导入时需要额外在配置文件声明的内容:没有声明的话,填值的默认内容}
通常共享的配置为shared-开头
实现从nacos导入配置
使用springcloud与springboot的启动流程有所不同,所以cloud统一结合了一下

不一定非要bootstrap,使用application.properties也可以,关键在于这个流程中进行的顺序(只要别配置nacos到yml文件即可)
导入依赖
<!-- nacos配置管理依赖 -->
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
<version>2021.0.5.0</version>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-bootstrap</artifactId>
<version>3.0.3</version>
</dependency>
配置模板
spring:
application:
name: hhhh
profiles:
active: dev #为什么这个和application name也要放这里?下面有填坑
cloud:
nacos:
config:
shared-configs:
- dataId: shared-jdbc.yaml
file-extension: yaml
server-addr: 192.168.229.128:8848
关于dataId,其实可以配置的不止dataId,共有以下三个
private String dataId;
private String group;
private boolean refresh;
配置热更新
之前配置的那些mybatis,mysql都不支持热更新
这是相当合理的行为:
- springboot会生成不少组件,如果这些支持热更新,那么需要他们把对应bean的属性更改,但是他们并没有这样
- 通常这些东西实现热更新是高风险行为,如果真该热更新,应该停服重启
真正该热更新的是我们业务中的需要热更新的业务
如:购物车的存储上限
需要配置一个配置类
@Data
@Component
@ConfigurationProperties(prefix="db.gulimall")
public class CartProperties{
private int maxSize;//最好与配置文件同名,大概通过get/set设置,这是规范
}
填坑为什么还要application name 和 profile active
因为在连上nacos后,启动项目会自动找application name-active.yaml和application name.yaml来读取配置
所以nacos配置某服务特有配置文件时
要按照对应的规格application name-profile active.yaml

动态路由
正常情况下,路由不需要实现热更新,如果要实现,由于是springcloud的实现,所以我们需要额外处理业务
注意点
- nacos关于网关的配置只支持JSON形式
[
{
"id":"item",
"predicates":[{
"name":"Path",
"args":{"genkey 0":"/items/**","genkey 1":"search/**"}
}],
"filters":[],
"uri":"lb;//item-service"
},
]
- 使用cloud route更新的RouteDefinitionWriter写入以及删除机制(注入RouteDefinitionWriter)
- 他插入的模式不太一样,需要用到Mono,Mono类似一个容器,然后just是发射的功能/意思,subscribe是订阅
- 在更新时,要先删除旧有的routeDifinition
- 需要使用到NacosConfigManager组件来定义监听器
- ctrl+shift+U:转为大写
- 还要@PostConstruct在组件注入后再调用该方法生成监听器
模板:
@Component
@RequiredArgsConstructor
public class RouteConfigLoader {
private final NacosConfigManager configManager;
private final static String DATA_ID="gateway.json";
private final static String GROUP="DEFAULT";
private final RouteDefinitionWriter writer;
private Set<String> oldIds=new HashSet<>();
@PostConstruct
public void routeInit() throws NacosException {
String configInfo = configManager.getConfigService().getConfigAndSignListener(DATA_ID, GROUP, 5000, new Listener() {
@Override
public Executor getExecutor() {
return Executors.newSingleThreadExecutor();
}
@Override
public void receiveConfigInfo(String configInfo) {
updateRoutes(configInfo);
}
});
updateRoutes(configInfo);
}
private void updateRoutes(String configInfo) {
List<RouteDefinition> routeDefinitions = JSONUtil.toList(configInfo, RouteDefinition.class);
//删除旧有的routes
for (String oldId : oldIds) {
writer.delete(Mono.just(oldId)).subscribe();//删除
}
//新增目前的routes
oldIds.clear();
for (RouteDefinition routeDefinition : routeDefinitions) {
writer.save(Mono.just(routeDefinition)).subscribe();//添加进去
oldIds.add(routeDefinition.getId());
}
}
}
spring-cloud 配置管理的更多相关文章
- Spring Cloud Netflix项目进入维护模式
任何项目都有其生命周期,Spring Could Netflix也不例外,官宣已进入维护模式,如果在新项目开始考虑技术选型时要考虑到这点风险,并考虑绕道的可能性. 原创: itmuch IT牧场 这 ...
- 大白话入门 Spring Cloud
首先我给大家看一张图,如果大家对这张图有些地方不太理解的话,我希望你们看完我这篇文章会恍然大悟. 什么是Spring cloud 构建分布式系统不需要复杂和容易出错.Spring Cloud 为最常见 ...
- 使用spring cloud实现分布式配置管理
<7天学会spring cloud系列>之创建配置管理服务器及实现分布式配置管理应用. 本文涉及到的项目: 开源项目:http://git.oschina.net/zhou666/spri ...
- Spring Cloud 入门教程(二): 配置管理
使用Config Server,您可以在所有环境中管理应用程序的外部属性.客户端和服务器上的概念映射与Spring Environment和PropertySource抽象相同,因此它们与Spring ...
- Spring Cloud Alibaba | Nacos配置管理
目录 Spring Cloud Alibaba | Nacos配置管理 1. pom.xml 项目依赖 2. 在 bootstrap.properties 中配置 Nacos server 的地址和应 ...
- Spring Cloud Alibaba基础教程:Nacos服务发现与配置管理
随着微服务概念的流行,越来越多的公司采用`Spring Cloud`全家桶构建微服务系统,实现业务的快速迭代.`Spring Cloud`提供了快速构建分布式微服务常用组件,包括`Spring Clo ...
- Spring Cloud Alibaba 实战(十二) - Nacos配置管理
本章主要内容是:使用Nacos管理配置以及实现配置管理的原因,配置如何管理以及动态刷新和最佳实现总结,最后是Nacos配置刷新原理解读 该技术类似于Spring Cloud Config 1 配置管理 ...
- Spring Cloud Alibaba学习笔记(22) - Nacos配置管理
目前业界流行的统一配置管理中心组件有Spring Cloud Config.Spring Cloud Alibaba的Nacos及携程开源的Apollo,本文将介绍Nacos作为统一配置管理中心的使用 ...
- Spring Cloud Config 分布式配置管理 5.3
Spring Cloud Config简介 在传统的单体式应用系统中,我们通常会将配置文件和代码放在一起,但随着系统越来越大,需要实现的功能越来越多时,我们又不得不将系统升级为分布式系统,同时也会将系 ...
- Spring Cloud Alibaba 使用Nacos作为配置管理中心
为什么需要配置中心? 动态配置管理是 Nacos 的三大功能之一,通过动态配置服务,我们可以在所有环境中以集中和动态的方式管理所有应用程序或服务的配置信息. 动态配置中心可以实现配置更新时无需重新部署 ...
随机推荐
- 详解KubeEdge EdgeMesh v1.15 边缘CNI特性
本文分享自华为云社区<KubeEdge EdgeMesh v1.15 边缘CNI特性原理及功能详解>,作者:达益鑫 |南开大学,刘家伟.吴锟 |DaoCloud,王杰章 |华为云 特性研发 ...
- 基于 eBPF 的 Serverless 多语言应用监控能力建设
作者:竞霄 监控能力作为基础运维能力和核心稳定性措施,开发运维人员可以通过监控系统有效进行故障定位,预防潜在风险,分析长期趋势进行容量规划和性能调优,是软件开发生命周期中必不可少的一环.与此同时,Se ...
- 如虎添翼!高德地图+Serverless 护航你的假日出行
作者 | 刘金龙(福辰) 高德团队 引言 "前方事故多发地段,请注意保持车距..." "您已疲劳驾驶,请注意休息..." "前方经过泰山旅游景 ...
- ElasticSearch使用实践(文档操作)
可以使用Docker安装ES和Kibana: 使用docker-compose安装ElasticSearch和Kibana: version: '3.1' services: elasticsearc ...
- zookeeper源码(03)启动流程
本文将从启动类开始详细分析zookeeper的启动流程: 加载配置的过程 集群启动过程 单机版启动过程 启动类 org.apache.zookeeper.server.quorum.QuorumPee ...
- 【C】C语言头文件互锁和包含问题
[来源] https://mp.weixin.qq.com/s/4tPHkwEd5n-xHNHJHtCoBw
- 【linux】Linux内核结构体--kfifo 环状缓冲区
1.前言 最近项目中用到一个环形缓冲区(ring buffer),代码是由linux内核的kfifo改过来的.缓冲区在文件系统中经常用到,通过缓冲区缓解cpu读写内存和读写磁盘的速度.例如一个进程A产 ...
- Java - 输出空心菱形
1. 思路:发现菱形的规律 ,定义三个变量,左边距和右边距,中间的边距 . 具体规律观察上图 . 2.上代码: //输出空心菱形 public class ForToLingXing { pub ...
- Docker镜像精简方法之二 COPY vs ADD 与镜像层
Docker镜像精简方法之二 COPY vs ADD 与镜像层 摘要 昨天只是讲了一下大体的思路. 但是没有实操. 今天想着修改一下默认的打包镜像的命令,验证一下效果 原始命令 FROM adopto ...
- Python学习之四_部分battery的学习
Python学习之四_部分battery的学习 CentOS升级pip的方法 yum install python3 之后, 一般centos的版本都很低, 有时候很多module 是无法安装的. 一 ...