【九】springboot整合redis实现启动服务时热点数据保存在全局和缓存

互相交流入口地址 

整体目录:

【一】springboot整合swagger

【二】springboot整合自定义swagger

【三】springboot整合token

【四】springboot整合mybatis-plus

【五】springboot整合mybatis-plus

【六】springboot整合redis

【七】springboot整合AOP实现日志操作

【八】springboot整合定时任务

【九】springboot整合redis实现启动服务时热点数据保存在全局和缓存

【十】springboot整合quartz实现定时任务优化

【十一】springboot整合异步调用并获取返回值

【十二】springboot整合WebService

【十三】springboot整合WebService关于传参数

【十四】springboot整合WebSocket

【十五】springboot整合WebSocket实现聊天室

【十六】RabbitMQ基础篇(下载安装并基础使用,内含各种坑问题)

【十七】RabbitMQ基础篇(延迟队列和死信队列实战)

【十八】springboot实现自定义全局异常处理

【十九】初学Kafka并实战整合SpringCloudStream进行使用

【二十】springboot整合ElasticSearch实战(万字篇)

【二十一】springboot整合过滤器实战

【二十二】springboot整合拦截器实战并对比过滤器

【二十三】springboot整合activiti7(1)实战演示篇

【二十四】springboot整合spring事务详解以及实战

【二十五】springboot使用EasyExcel和线程池实现多线程导入Excel数据

【二十六】springboot整合jedis和redisson布隆过滤器处理缓存穿透

【二十七】springboot实现多线程事务处理

【二十八】springboot之threadLocal参数解析器实现session一样保存当前登录功能 

【二十九】springboot整合logback实现日志管理

【三十】springboot项目上高并发解决示例

目录

第一步:新建实体类以及各层

第二步:新建获取数据的类(重点)

第三步:演示


        介绍:接下来我会把学习阶段学到的框架等知识点进行整合,每一次整合是在前一章的基础上进行的,所以后面的整合不会重复放前面的代码。每次的demo我放在结尾,本次是接着上一章的内容延续的,只增加新增的或者修改的代码。

        前面第七章整合redis后实现了用户登录的某些问题,这一章用于解决一个很常见的问题,即是如何实现在启动时就将一些热点数据保存在全局或者redis中,方便后面的其他接口中使用时,不需要再次从数据库中查询(减轻数据库压力)。

        1、首先还是展示一下目录结构:

watermark,type_ZHJvaWRzYW5zZmFsbGJhY2s,shadow_50,text_Q1NETiBA5bCPeuKZgA==,size_17,color_FFFFFF,t_70,g_se,x_16

        勾出部分为相比上一章多出来的文件。

        2、新建code表

watermark,type_ZHJvaWRzYW5zZmFsbGJhY2s,shadow_50,text_Q1NETiBA5bCPeuKZgA==,size_20,color_FFFFFF,t_70,g_se,x_16

第一步:新建实体类以及各层

watermark,type_ZHJvaWRzYW5zZmFsbGJhY2s,shadow_50,text_Q1NETiBA5bCPeuKZgA==,size_20,color_FFFFFF,t_70,g_se,x_16

watermark,type_ZHJvaWRzYW5zZmFsbGJhY2s,shadow_50,text_Q1NETiBA5bCPeuKZgA==,size_20,color_FFFFFF,t_70,g_se,x_16 watermark,type_ZHJvaWRzYW5zZmFsbGJhY2s,shadow_50,text_Q1NETiBA5bCPeuKZgA==,size_20,color_FFFFFF,t_70,g_se,x_16

watermark,type_ZHJvaWRzYW5zZmFsbGJhY2s,shadow_50,text_Q1NETiBA5bCPeuKZgA==,size_20,color_FFFFFF,t_70,g_se,x_16

watermark,type_ZHJvaWRzYW5zZmFsbGJhY2s,shadow_50,text_Q1NETiBA5bCPeuKZgA==,size_20,color_FFFFFF,t_70,g_se,x_16

        此部分没什么特别的,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();
    }

}

        下面进行一个解读: 

watermark,type_ZHJvaWRzYW5zZmFsbGJhY2s,shadow_50,text_Q1NETiBA5bCPeuKZgA==,size_20,color_FFFFFF,t_70,g_se,x_16

        新建一个公共的静态的变量,用于保存全局变量,可以让其他类访问该变量的值,在spring初始化时就会生成。

watermark,type_ZHJvaWRzYW5zZmFsbGJhY2s,shadow_50,text_Q1NETiBA5bCPeuKZgA==,size_20,color_FFFFFF,t_70,g_se,x_16

        新建一个获取数据的方法,从数据库获取值,并put到刚才新建的变量里,并将这些查询出来的热点数据存入redis,此处的redisUtils在前面第七章有说到。

新建一个定时任务方法,设置自定义时间,前面有说cron如何生成,在此处调用获取数据的方法。ps:开启定时任务需要在启动类加上注解@EnableScheduling。定时从数据库获取数据刷新热点数据的值,并存到全局以及redis。

watermark,type_ZHJvaWRzYW5zZmFsbGJhY2s,shadow_50,text_Q1NETiBA5bCPeuKZgA==,size_20,color_FFFFFF,t_70,g_se,x_16

        在此controller里面,进行了两种储存方式的获取测试。

第三步:演示

        打开swagger接口地址,先请求登录接口获取token,再请求刚才新建的获取热点数据的接口,如下图:

watermark,type_ZHJvaWRzYW5zZmFsbGJhY2s,shadow_50,text_Q1NETiBA5bCPeuKZgA==,size_20,color_FFFFFF,t_70,g_se,x_16

        ps:由于测试,我事先在表里加入了数据,如下:

watermark,type_ZHJvaWRzYW5zZmFsbGJhY2s,shadow_50,text_Q1NETiBA5bCPeuKZgA==,size_20,color_FFFFFF,t_70,g_se,x_16

        此测试可以看出两种方法都能获取热点数据的值,成功。

        手动修改数据库的热点数据值(模仿用户通过正常操作改变了热点数据的值) 。

 watermark,type_ZHJvaWRzYW5zZmFsbGJhY2s,shadow_50,text_Q1NETiBA5bCPeuKZgA==,size_20,color_FFFFFF,t_70,g_se,x_16

        重新请求接口 

watermark,type_ZHJvaWRzYW5zZmFsbGJhY2s,shadow_50,text_Q1NETiBA5bCPeuKZgA==,size_20,color_FFFFFF,t_70,g_se,x_16

        可以看到从redis以及全局获取的数据已经·定时更新成功。

        本期整合到此完毕,接下来会继续更新加强整合,尽情期待。

        访问地址:http://localhost:8087/swagger-ui.html或者http://localhost:8087/doc.html

  • 39
    点赞
  • 37
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 22
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 22
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

小z♂

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

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

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

打赏作者

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

抵扣说明:

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

余额充值