介绍:接下来我会把学习阶段学到的框架等知识点进行整合,每一次整合是在前一章的基础上进行的,所以后面的整合不会重复放前面的代码。每次的demo我放在结尾,本次是接着上一章的内容延续的,只增加新增的或者修改的代码。
前面第七章整合redis后实现了用户登录的某些问题,这一章用于解决一个很常见的问题,即是如何实现在启动时就将一些热点数据保存在全局或者redis中,方便后面的其他接口中使用时,不需要再次从数据库中查询(减轻数据库压力)。
1、首先还是展示一下目录结构:
勾出部分为相比上一章多出来的文件。
2、新建code表
第一步:新建实体类以及各层
此部分没什么特别的,controller层的代码,下面会将,先建立核心代码(获取热点数据)。
第二步:新建获取数据的类(重点)
@Component public class GetRedisData { @Resource CodeService codeService; @Resource RedisUtils redisUtils; public static Map<String, String> codes = new HashMap<String, String>(); public void getData(){ System.out.println("开启刷新热点数据"); //系统启动中。。。从数据库获取值 List<Code> codeList = codeService.getCodes(); for (Code code : codeList) { codes.put(code.getCodename() , code.getNumber()); //存入redis,以便于后面都从redis获取值,而不是每次从数据库直接查询 redisUtils.getAndSet(code.getCodename(),code.getNumber()); } } @PreDestroy public void destroy() { //系统运行结束 } @Scheduled(cron = "0/10 0/1 * * * ? ") public void getDataSchedul() { //每隔10秒执行一次 getData(); } }
下面进行一个解读:
新建一个公共的静态的变量,用于保存全局变量,可以让其他类访问该变量的值,在spring初始化时就会生成。
新建一个获取数据的方法,从数据库获取值,并put到刚才新建的变量里,并将这些查询出来的热点数据存入redis,此处的redisUtils在前面第七章有说到。
新建一个定时任务方法,设置自定义时间,前面有说cron如何生成,在此处调用获取数据的方法。ps:开启定时任务需要在启动类加上注解@EnableScheduling。定时从数据库获取数据刷新热点数据的值,并存到全局以及redis。
在此controller里面,进行了两种储存方式的获取测试。
第三步:演示
打开swagger接口地址,先请求登录接口获取token,再请求刚才新建的获取热点数据的接口,如下图:
ps:由于测试,我事先在表里加入了数据,如下:
此测试可以看出两种方法都能获取热点数据的值,成功。
手动修改数据库的热点数据值(模仿用户通过正常操作改变了热点数据的值) 。
重新请求接口
可以看到从redis以及全局获取的数据已经·定时更新成功。
本期整合到此完毕,接下来会继续更新加强整合,尽情期待。
访问地址:http://localhost:8087/swagger-ui.html或者http://localhost:8087/doc.html