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

本文涉及的产品
云数据库 Redis 版,标准版 2GB
推荐场景:
搭建游戏排行榜
云原生内存数据库 Tair,内存型 2GB
简介: 【九】springboot整合redis实现启动服务时热点数据保存在全局和缓存


       介绍:接下来我会把学习阶段学到的框架等知识点进行整合,每一次整合是在前一章的基础上进行的,所以后面的整合不会重复放前面的代码。每次的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

相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore &nbsp; &nbsp; ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库&nbsp;ECS 实例和一台目标数据库&nbsp;RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&amp;RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
目录
相关文章
|
5天前
|
canal 缓存 NoSQL
Redis缓存与数据库如何保证一致性?同步删除+延时双删+异步监听+多重保障方案
根据对一致性的要求程度,提出多种解决方案:同步删除、同步删除+可靠消息、延时双删、异步监听+可靠消息、多重保障方案
Redis缓存与数据库如何保证一致性?同步删除+延时双删+异步监听+多重保障方案
|
6天前
|
存储 NoSQL Redis
SpringCloud基础7——Redis分布式缓存,RDB,AOF持久化+主从+哨兵+分片集群
Redis持久化、RDB和AOF方案、Redis主从集群、哨兵、分片集群、散列插槽、自动手动故障转移
SpringCloud基础7——Redis分布式缓存,RDB,AOF持久化+主从+哨兵+分片集群
|
15天前
|
NoSQL Linux Redis
Linux Redis 服务设置开机自启动
【9月更文挑战第2天】在 Linux 系统中,可使用两种方法设置 Redis 开机自启动:一是通过创建 `redis.service` 文件并利用 systemd 进行管理,包括定义服务参数和启动脚本;二是编辑 `/etc/rc.local` 文件,在其中添加启动命令。推荐使用 systemd 方法,因为它更符合现代 Linux 系统的设计理念。设置完成后,可通过 `sudo systemctl status redis.service` 检查服务状态。
|
16天前
|
缓存 NoSQL 关系型数据库
MySQL与Redis缓存一致性的实现与挑战
在现代软件开发中,MySQL作为关系型数据库管理系统,广泛应用于数据存储;而Redis则以其高性能的内存数据结构存储特性,常被用作缓存层来提升数据访问速度。然而,当MySQL与Redis结合使用时,确保两者之间的数据一致性成为了一个重要且复杂的挑战。本文将从技术角度分享MySQL与Redis缓存一致性的实现方法及其面临的挑战。
40 2
|
19天前
|
Java UED Maven
紧跟技术潮流:手把手教你构建响应式Vaadin应用,让用户体验无缝接轨!
【8月更文挑战第31天】本文从零开始,详细介绍如何使用强大的Java框架Vaadin构建流畅且响应式的Web应用程序。首先,确保安装JDK 1.8+、Maven 3.3.9+及IDE。接着,创建Maven项目并添加Vaadin依赖。然后,通过继承`UI`类创建主界面,并定义自定义主题与样式。利用Vaadin的响应式布局组件,如`HorizontalLayout`和`VerticalLayout`,实现多设备兼容性。
26 0
|
19天前
|
缓存 NoSQL Redis
Entity Framework Core 与 Redis 强强联手!实现高速缓存,提升应用性能超厉害
【8月更文挑战第31天】在现代应用开发中,结合 Entity Framework Core 与 Redis 可显著提升数据访问速度。Entity Framework Core 是一个强大的 ORM 框架,但处理频繁访问的数据时可能遇到性能瓶颈。Redis 作为高性能内存数据库,具备快速读写能力。两者结合利用 Redis 高速缓存,减少直接数据库访问,提高应用响应速度及性能。
27 0
|
4月前
|
NoSQL Java Redis
SpringBoot集成Redis
SpringBoot集成Redis
488 0
|
4月前
|
NoSQL Java Redis
【极光系列】springboot集成redis
【极光系列】springboot集成redis
71 3
|
4月前
|
缓存 NoSQL Java
springboot中集成redis,二次封装成工具类
springboot中集成redis,二次封装成工具类
|
4月前
|
监控 NoSQL Java
Spring Boot集成Redis启动失败【Caused by: java.lang.ClassNotFoundException: org.apache.commons.pool2.impl.G】
Spring Boot集成Redis启动失败【Caused by: java.lang.ClassNotFoundException: org.apache.commons.pool2.impl.G】