前言:
前段时间接手一个小项目需求,其中有一块逻辑是用户调用api接口;用户侧会传来两个字段,其中一个字段标识调用的接口信息(内部接口转发),另一个字段用于查询和更新用户套餐信息;这些信息都存在mysql表里面;调用api肯定会涉及高并发,所以想着怎么减少和数据库的交互;想来想去查询用户套餐信息和更新用户套餐信息貌似没法跳过,只能暂时把存储接口信息的表一次性加载到内存,这样判断就直接在内存进行,减少一次mysql查询;下面就来说说spring boot里面怎么整。
1. @PostConstruct 注解
首先这个注解是由Java提供的,它用来修饰一个非静态的void方法。它会在服务器加载Servlet的时候运行,并且只运行一次。@PostConstruct主要应用场景是在初始化Servlet时加载一些缓存数据。用法举例如下:
@Component
public class TempData {
public static List<T> list;
private DoMapper doMapper;
public TempData(DoMapper doMapper) {
this.doMapper= doMapper;
}
@PostConstruct
public void init(){
list= doMapper.getTempData();
}
}