实现线上修改配置实时更新的方案

需求:刚进公司,leader甩给我一个问题:

  1. 背景:由于项目是springboot项目,没有cloud组件,我们项目在线上经常会有修改配置文件的需求
  2. 问题:以前是只能修改配置文件后,再重新打包部署重启应用,很麻烦
  3. 需求是:线上可修改配置项(不用重新打包部署应用)、可扩展(以后可以增加新的配置)、效率高

问了几个前辈,有以下的技术方案:

  1. 最优:引入nacos配置中心,可以实现热更新。
  2. 次优:redis+db。将配置文件里的配置放到数据库,建一张key value的2列的表用来存放这些配置。项目启动时,db的数据加载到redis,然后bean的属性每次都从redis读取,读取不到从db里加载到redis再读取。当线上通过ui修改配置的时候,采用db+redis延迟双删的策略,手动修改数据库就手动删redis。
  3. 如果既没有nacos,也没有redis,最简单的方案是本地内存+db。同方案2类似,将redis换成本地内存,这种只能给他设置过期时间(因为考虑到集群,需要每个节点的本地内存同步更新),或者写个job每分钟轮询一下配置表,将配置写入本地内存。
  4. 还有一些方案:指定外部配置,更新配置文件的时候指定新的配置文件(或者把原先的配置文件覆盖),然后重启服务;阿波罗,比较适用于复杂的项目;放数据库,页面展示数据库配置数据 ,页面修改配置就持久化到数据库,同时发布修改 bean 属性的事件
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值