【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 表达式或者执行频率
相关推荐
用户31693538118314 小时前
Java连接Redis
redis
倔强的石头_17 小时前
《Kingbase护城河》——数据库存储空间全景探测与精细化瘦身实战
数据库
冬奇Lab1 天前
每日一个开源项目(第134篇):Zvec - 阿里开源的嵌入式向量数据库,向量搜索界的 SQLite
数据库·人工智能·llm
ClouGence2 天前
Oracle CDC 架构优化:从主库直连到 DataGuard 备库同步
数据库·后端·oracle
无响应de神2 天前
三、用户与权限管理
数据库·mysql
小小工匠2 天前
Redis - 事务机制:能实现 ACID 属性吗
数据结构·redis·性能优化·并发·持久化
麦聪聊数据2 天前
数据服务化时代:企业数据能力输出的核心路径
数据库
shushangyun_3 天前
2026年快消品B2B系统推荐:支持终端门店订货、促销政策自动化的工具?
java·运维·网络·数据库·人工智能·spring·自动化
DARLING Zero two♡3 天前
【MySQL数据库】数据类型与表约束
数据库·mysql
ofoxcoding3 天前
在AI API聚合平台配置DeepSeek V3.2提示词缓存实战:快速接入与成本优化指南
人工智能·spring·缓存·ai