背景:对于一些配置型数据而言,改动不是很频繁,可以在项目启动的时候直接加载到内存,避免需要数据时去查询数据库,造成不必要的IO消耗
环境:SpringBoot + maven
后端代码:
pom依赖
<dependency>
<groupId>com.google.guava</groupId>
<artifactId>guava</artifactId>
<version>31.0.1-jre</version>
</dependency>
service层
package com.example.demo.service;
import lombok.extern.slf4j.Slf4j;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.stereotype.Service;
import com.google.common.collect.Maps;
import javax.annotation.PostConstruct;
import java.util.HashMap;
import java.util.Map;
/**
* @author jn
* @date 2022/2/24 上午9:20
*/
/**解释
被@PostConstruct修饰的方法会在服务器加载Servlet的时候运行,并且只会被服务器执行一次。
PostConstruct在构造函数之后执行,init()方法之前执行。
这里加载的顺序是:SpringBoot的主启动类启动 --> 扫描到EvaluationServiceImpl --> 初始化allEvaluationMap
--> @PostConstruct修饰的方法 --> loadTeachingOrg()方法
这样当接口注入EvaluationServiceImpl后,直接调用EvaluationServiceImpl的方法loadTeachingOrg就可以拿到内存的数据
不需要再走DB
*/
@Service
@Slf4j
public class EvaluationServiceImpl {
private Logger logger = LoggerFactory.getLogger(EvaluationServiceImpl.class);
Map<Long, String> allEvaluationMap = Maps.newHashMap();
@PostConstruct
void init(){
loadTeachingOrg();
}
public void loadTeachingOrg(){
//假设:查DB得到的数据如下
Map<Long, String> map = new HashMap<>();
map.put(1L, "评价1");
map.put(2L, "评价2");
map.put(3L, "评价3");
//放入内存
allEvaluationMap = map;
}
/**
* 获取当前学期的所有的评价类别
*/
public Map<Long, String> getAllEvaluationMap(){
return allEvaluationMap;
}
}
controller层
@RestController
@RequestMapping("/api/evaluation")
public class EvaluationController {
@Resource
private EvaluationServiceImpl evaluationService;
@RequestMapping("all")
public Map<Long, String> result(){
Map<Long, String> allEvaluationMap = evaluationService.getAllEvaluationMap();
System.out.println(allEvaluationMap);
return allEvaluationMap;
}
}
结果: