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

news/2024/4/30 9:35:36

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反序列化为对象

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.cpky.cn/p/11442.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈,一经查实,立即删除!

相关文章

【Qt 学习笔记】Qt 背景介绍

博客主页:Duck Bro 博客主页系列专栏:Qt 专栏关注博主,后期持续更新系列文章如果有错误感谢请大家批评指出,及时修改感谢大家点赞👍收藏⭐评论✍ Qt 背景介绍 文章编号:Qt 学习笔记 / 01 文章目录 Qt 背景…

四川古力未来科技抖音小店:把握电商新风口,前景无限广阔

在数字化浪潮席卷全球的今天,电商行业以其独特的魅力和无限潜力,成为了众多创业者和投资者关注的焦点。四川古力未来科技抖音小店,正是站在这一风口浪尖上的新兴力量,其前景之广阔,令人瞩目。 抖音,作为一款…

全局UI方法-弹窗四-日期滑动选择器弹窗(DatePickerDialog)

1、描述 根据指定的日期范围创建日期滑动选择器,展示在弹窗上。 2、接口 DatePickerDialog.show(options?: DatePickerDialogOptions) 3、DatePickerDialogOptions 参数名称 参数类型 必填 默认值 参数描述 start Date 否 Date("1970-1-1") 设置选择…

基于JSPM的美食推荐管理系统

背景 互联网的迅猛扩张彻底转变了全球各类组织的运营模式。自20世纪90年代起,中国各级政府和企事业单位便开始探索运用网络系统来处理管理事务。然而,早期的网络覆盖不广、用户接受度不高、相关网络法规不健全以及技术发展不成熟等因素,都曾…

关于Ansible的模块②

转载说明:如果您喜欢这篇文章并打算转载它,请私信作者取得授权。感谢您喜爱本文,请文明转载,谢谢。 接《关于Ansible的模块 ①-CSDN博客》,继续学习和梳理Ansible的常用文件类模块 1. copy模块 从当前机器上复制文件到…

【攻防世界】file_include (PHP伪协议+过滤器)

打开题目环境: 进行PHP代码审计,发现这是一个文件包含漏洞。 我们尝试利用PHP伪协议中的 php://filter来读取 check.php 中的内容。 构造payload 并提交: 发现payload被过滤掉了,我们就需要尝试使用不同的转换器。 PHP各类转换…