【Redis 二】Redis客户端(Jedis、SpringDataRedis、RedisTemplate)

1. Redis客户端

  1. Jedis
    1. 以redis命令作为方法名称,学习成本低,但是Jedis实例是线程不安全的,多线程环境下需要基于连接池来使用(必须为每个线程分配独立的Jedis连接)
  2. lettuce
    1. 基于Netty实现,支持同步、异步和响应式编程方式,并且是线程安全的。支持Redis的哨兵模式、集群模式和管道模式
  3. Redisson
    1. 是一个基于Redis实现的分布式、可伸缩的Java数据结构集合。包含了诸如Map、Queue、Lock、Semaphore、AtomicLong等强大功能

1.1 Jedis

使用步骤:

  1. 引入依赖
  2. 建立连接
  3. 使用jedis
  4. 释放资源

1.2 Jedis连接池

jedis本身不是线程安全的,并且频繁的创建和销毁连接有性能损耗,因此推荐使用Jedis连接池代替Jedis的直连方式

2. SpringDataRedis

在Spring中可以通过注入RedisTemplate的方式(底层连接可以选择jedis、lettuce)来使用redis,需要在配置文件中配置redis信息

jedis所使用的方法名多数与redis调用保持一致,redisTemplate则是对redis调用进行了封装

redisTemplate方法名:

  1. opsForValue:操作String类型
  2. opsForHash:操作Hash类型
  3. opsForList:操作List类型
  4. opsForSet:操作Set类型
  5. opsForZSet:操作SortedSet类型

2.1 RedisTemplate序列化方案

RedisTemplate可以接受任意的Object作为键、值写入redis,但是会在写入前将Object序列化为字节形式,默认采用JDK序列化,可读性差且内存占用较大,可以通过设置redis序列化器的方式来避免使用JDK序列化

方案一:

  1. 自定义RedisTemplate
  2. 修改RedisTemplate的序列化器为GenericJackson2JsonRedisSerializer

方案二:

  1. 使用StringRedisTemplate
  2. 写入Redis时,手动将对象序列化为Json(ObjectMapper)
  3. 读取Redis时,手动将读取到的Json反序列化为对象
相关推荐
老虎06271 小时前
黑马点评学习笔记07(缓存工具封装)
笔记·学习·缓存
阿萨德528号2 小时前
Redis 分布式锁进阶:跨语言场景下的锁兼容性与一致性保障
数据库·redis·分布式
秋雨雁南飞4 小时前
c# 使用Memory实现Redis入队出队功能
redis·c#
星光一影5 小时前
悬赏任务平台/拉新地推系统源码
redis·mysql·小程序·php·uniapp·html5
-Xie-7 小时前
Redis(二)——数据类型二
数据库·redis·缓存
User_芊芊君子8 小时前
【LeetCode 经典题解】:队列与栈的双向模拟——从原理到代码详解
linux·redis·leetcode
似水流年QC11 小时前
深入 Pinia 工作原理:响应式核心、持久化机制与缓存策略
缓存·pinia·持久化·缓存策略
明月与玄武20 小时前
前端缓存战争:回车与刷新按钮的终极对决!
前端·缓存·回车 vs 点击刷新
JH307321 小时前
《Redis 经典应用场景(一):缓存、分布式锁与限流》
redis·分布式·缓存
苦学编程的谢21 小时前
Redis_4_常见命令(完)+认识数据类型和编码方式
数据库·redis·缓存