SpringCloud运行时刷新数据源相关配置

本文介绍了一种在SpringCloud中实现数据库配置动态刷新的方法,无需重启应用即可更新配置。通过使用@RefreshScope注解及DataSource配置,结合定时任务验证配置变更的有效性。

数据库的相关配置,一般来说是不会频繁变的,特别是当数据库连接使用的是域名而不是ip地址的时候,这样即使ip地址变化了,也不影响业务系统。这里呢,我们讲一下如果真的是迫不得已的时候,有没有不重启就可以更改配置的方法。

思路

有很多种方案,这里我们讲一下基于SpringCloud的RefreshScope的方案。

数据库配置实例

spring:
  datasource:
    platform: postgres
    url: jdbc:postgresql://192.168.99.100:5432/postgres
    driverClassName: org.postgresql.Driver
    username: postgres
    password: 123456
    validation-query: SELECT 1
    test-while-idle: true
    test-on-borrow: true

Java配置

@Configuration
public class DbConfig {

    @Bean
    @RefreshScope //refresh
    @Primary
    @ConfigurationProperties(prefix = "spring.datasource")
    public DataSource dataSource() {
        return DataSourceBuilder.create().build();
    }
}

更新

调用一下服务的refresh端点就可以了

curl -i -X POST http://localhost:9001/refresh

验证

@Component
public class ScheduleTask {

    @Autowired
    UserRepository userRepository;

    @Scheduled(fixedDelay = 5*1000 /**ms**/,initialDelay = 5*1000)
    public void testDataSourceConn() {
        try{
            System.out.println("call jdbc");
            userRepository.findAll();
        }catch (Exception e){
            e.printStackTrace();
        }
    }
}

这里跑一个定时任务,不停地调用数据查询方法,然后中途改下密码,然后refresh一下,看是否报错

doc

转载于:https://my.oschina.net/go4it/blog/1486306

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值