【Redis】缓存预热

目录

常见缓存

● Redis(分布式缓存)

● memcached(分布式)

● Etcd(云原生架构的一个分布式存储,存储配置 ,扩容能力)

● ehcache(单机)

● 本地缓存(Java 内存 Map)

● Caffeine(Java 内存缓存,高性能)

● Google Guava


Redis客户端

  • Spring-Data-Redis
    • Spring Data 是通用的数据访问框架,定义了一组 增删改查 的接口。mysql、redis、jpa实现了这个接口
  • Jedis
    • 独立于 Spring 操作 Redis 的 Java 客户端,要配合 Jedis Pool 使用
  • Lettuce
    • 高阶的操作 Redis 的 Java 客户端
    • 异步、连接池
  • Redisson
    • 分布式操作 Redis 的 Java 客户端,让你像在使用本地的集合一样操作 Redis(分布式 Redis 数据网格)

对比

  1. 如果你用的是 Spring,并且没有过多的定制化要求,可以用 Spring Data Redis,最方便
  2. 如果你用的不是 SPring,并且追求简单,并且没有过高的性能要求,可以用 Jedis + Jedis Pool
  3. 如果你的项目不是 Spring,并且追求高性能、高定制化,可以用 Lettuce,支持异步、连接池
  4. 如果你的项目是分布式的,需要用到一些分布式的特性(比如分布式锁分布式集合),推荐用 redisson

设计缓存key

  • 公司为了节约成本,多个项目有可能共用一个redis。所以这就要求我们redis中的key不能有冲突
  • system:module:func:options
  • 注意:一定要设置过期时间!!!

缓存预热

优点:

  • 提高用户访问速度

缺点:

  • 增加开发成本(你要额外的开发、设计)
  • 预热的时机和时间如果错了,有可能你缓存的数据不对
  • 需要占用额外空间

怎么进行缓存预热

  1. 定时任务执行
  2. 手动触发执行

定时任务的实现

  1. Spring Scheduler(spring boot 默认整合了
  2. Quartz(独立于 Spring 存在的定时任务框架)
  3. XXL-Job 之类的分布式任务调度平台(提供 界面 + sdk)

第一种方式使用:

  1. 主类开启 @EnableScheduling
  2. 给要定时执行的方法添加 @Scheduled 注解,指定 cron 表达式或者执行频率
相关推荐
广州智造2 小时前
OptiStruct实例:3D实体转子分析
数据库·人工智能·算法·机器学习·数学建模·3d·性能优化
技术宝哥5 小时前
Redis(2):Redis + Lua为什么可以实现原子性
数据库·redis·lua
学地理的小胖砸6 小时前
【Python 操作 MySQL 数据库】
数据库·python·mysql
呦呦鹿鸣Rzh6 小时前
缓存的相关内容
缓存
dddaidai1236 小时前
Redis解析
数据库·redis·缓存
数据库幼崽7 小时前
MySQL 8.0 OCP 1Z0-908 121-130题
数据库·mysql·ocp
Amctwd7 小时前
【SQL】如何在 SQL 中统计结构化字符串的特征频率
数据库·sql
工一木子7 小时前
【Java项目脚手架系列】第七篇:Spring Boot + Redis项目脚手架
java·spring boot·redis
betazhou7 小时前
基于Linux环境实现Oracle goldengate远程抽取MySQL同步数据到MySQL
linux·数据库·mysql·oracle·ogg
lyrhhhhhhhh8 小时前
Spring 框架 JDBC 模板技术详解
java·数据库·spring