SpringBoot启动时将数据库数据加载到内存

本文探讨了为何需要将数据库参数存入缓存,分析了内存与Redis作为缓存的优劣,介绍了SpringBoot启动时加载参数至内存的两种常见方法:@PostConstruct与CommandLineRunner接口。

为什么需要将参数存入缓存?以及选择何种方式

为了避免频繁的查询数据库,我们需要将参数表的参数做成缓存,缓存的方式有两种,一种是加载到工程的内存中,另一种是加载到redis中。

因为微服务的服务太多,如果用前一种方法的话,就需要多个服务都要初始化参数,而且如果参数变了,需要用到参数的服务都需要重新部署,或者做定时任务定时刷新参数缓存,但这样就会出现一段时间内各服务参数不一致的情况。

所以我们采用redis作为参数缓存的中间件。

总结: 应根据自己业务场景,选择加载到内存还是redis。

SpringBoot启动时将数据库参数表参数加载到内存

SpringBoot工程启动时将数据库参数表参数加载到内存中
参考URL: https://blog.youkuaiyun.com/yang1519784522/article/details/103741850/

常见思路

springBoot启动时让方法自动执行的几种实现方式
参考URL: https://www.cnblogs.com/lsgspace/p/10508180.html

网上实现方法很多,这里列举最常见两种思路。根据其特定,依据业务需求自己选择。

思路1: 使用@PostConstruct

被@PostConstruct修饰的方法会在服务器加载Servlet的时候运行,并且只会被服务器调用一次,类似于Serclet的inti()方法。被@PostConstruct修饰的方法会在构造函数之后,init()方法之前运行。

这是最简单的方式。但是会影响服务提供,比如这个方法要执行五分钟 这五分钟之内是无法提供服务的,这个方法是在服务初始化后之前运行, 所以 此方法运行不结束,服务就无法初始化, 在这过程路也无法提供服务。

    @PostConstruct
     public  void pingStart(){
        System.out.println(" ping start:");
        getPingip();
        System.out.println(" ping end: ");
    }

总结:服务初始化过程中,执行该方法,该方法不结束无法提供服务。

思路2: 实现CommandLineRunner接口

实现CommandLineRunner接口,@Order注解里面的参数是类执行的顺序,由小到大顺序。

监听接口方式,启动服务,执行方式时仍然提供服务,服务初始化之后,执行方法。


@Component
public class SettingConfig implements CommandLineRunner {
    @Override
    public void run(String... strings) throws Exception {	
       //xx
    }

总结:服务初始化之后,执行方法。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

西京刀客

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值