spring boot集成reids的 RedisTemplate 序列化器详细对比(官方及非官方)

RedisTemplate 序列化器详细对比(官方及非官方)


1. 官方序列化器
(1) JdkSerializationRedisSerializer
  • 特点
    • 基于 Java 原生序列化(Serializable)。
    • 支持复杂对象(需实现 Serializable 接口)。
    • 缺点:体积大、反序列化需类文件、跨语言支持差、性能较低。
  • 适用场景:简单对象且对性能要求不高。
(2) StringRedisSerializer
  • 特点
    • 仅支持 String 类型,直接转换 byte[]
    • 无额外开销,性能最优。
  • 适用场景:键值均为字符串的场景。
(3) GenericJackson2JsonRedisSerializer
  • 特点
    • 基于 Jackson,自动添加 @class 字段保留类型信息。
    • 支持复杂对象,无需显式指定类型。
  • 适用场景:需要自动处理类型信息的复杂对象。
(4) Jackson2JsonRedisSerializer
  • 特点
    • 基于 Jackson,需显式指定对象类型(如 User.class)。
    • 性能高于 GenericJackson2Json
  • 适用场景:已知对象类型或单类型场景。
(5) OxmSerializer(如 Jaxb2/XStream)
  • 特点
    • 支持 XML 序列化(如 JAXB、XStream)。
    • 需配置 XML 驱动(如 Jaxb2CollectionSerializer)。
    • 适用场景:需 XML 格式存储或与 XML 系统交互。
(6) RedisObjectSerializer(自定义二进制)
  • 特点
    • Redis 原生二进制序列化(如 RedisSerializer 接口实现)。
    • 通常用于特定场景(如与 Redis 协议直接交互)。
    • 需自定义实现,灵活性高但复杂。

2. 非官方序列化器
(1) FastjsonRedisSerializer
  • 特点
    • 基于阿里巴巴 Fastjson,性能优于 Jackson。
    • 支持复杂对象,需显式指定类型。
    • 依赖 Fastjson 库
  • 适用场景:追求高性能 JSON 序列化。
(2) GsonRedisSerializer(需自定义)
  • 特点
    • 基于 Google Gson 库,轻量级 JSON 序列化。
    • 需手动实现 RedisSerializer 接口。
    • 灵活性高,适合熟悉 Gson 的项目。
  • 适用场景:已有 Gson 依赖或偏好轻量级 JSON。
(3) KryoSerializer(需第三方库)
  • 特点
    • 基于 Kryo 库,二进制序列化,性能极高。
    • 不保留类型信息,需手动处理类型。
    • 跨语言支持差,但体积小、速度快。
  • 适用场景:对性能要求极高且类型固定。
(4) ProtobufSerializer(需自定义)
  • 特点
    • 基于 Protocol Buffers(Protobuf),二进制序列化。
    • 高性能、体积小,跨语言兼容性好。
    • 需定义 .proto 文件,配置复杂度较高。
  • 适用场景:跨语言系统或对性能要求极高的场景。
(5) SnakeYAMLSerializer(需自定义)
  • 特点
    • 基于 SnakeYAML 库,支持 YAML 格式序列化。
    • 适合需要人类可读配置文件的场景。
    • 依赖 SnakeYAML 库
  • 适用场景:需 YAML 格式存储(如配置类)。

对比表格

序列化器类型支持对象类型保留类型信息性能依赖适用场景
JdkSerialization原生序列化复杂对象简单对象,对性能要求不高
StringRedisSerializer字符串序列化String键值均为字符串
GenericJackson2JsonJSON(泛型)复杂对象Jackson需自动处理类型信息的复杂对象
Jackson2JsonJSON(单类型)固定对象类型Jackson已知对象类型或单类型场景
OxmSerializer(Jaxb2)XML 序列化支持 XML 对象需配置JAXB/XStream需 XML 格式存储
RedisObjectSerializer自定义二进制任意自定义实现特定协议交互或高性能需求
FastjsonRedisSerializerJSON(Fastjson)复杂对象需显式指定Fastjson高性能 JSON 需求
GsonRedisSerializerJSON(Gson)复杂对象需显式指定Gson轻量级 JSON 需求
KryoSerializer二进制(Kryo)复杂对象极高Kryo性能优先且类型固定
ProtobufSerializer二进制(Protobuf)复杂对象是(需定义)极高Protobuf跨语言系统或高性能需求
SnakeYAMLSerializerYAML复杂对象是(YAML格式)SnakeYAML需人类可读配置文件

总结与建议

  1. 简单键值对:首选 StringRedisSerializer(性能最优)。
  2. 复杂对象
    • 自动类型处理GenericJackson2Json
    • 固定类型Jackson2JsonFastjson
    • 高性能KryoProtobuf
    • 跨语言兼容Protobuf 或 JSON 序列化器。
  3. XML/YAML 需求
    • XML → OxmSerializer(需配置驱动)。
    • YAML → SnakeYAMLSerializer
  4. 自定义需求
    • 特定协议 → 实现 RedisSerializer
    • 极端性能 → ProtobufKryo

配置示例

JSON 序列化(Jackson)
@Bean
public RedisTemplate<String, Object> redisTemplate(RedisConnectionFactory factory) {RedisTemplate<String, Object> template = new RedisTemplate<>();template.setConnectionFactory(factory);template.setKeySerializer(new StringRedisSerializer());template.setValueSerializer(new GenericJackson2JsonRedisSerializer());return template;
}
高性能二进制(Kryo)
// 需自定义实现
public class KryoRedisSerializer implements RedisSerializer<Object> {private final Kryo kryo = new Kryo();@Overridepublic byte[] serialize(Object object) {Output output = new Output(new ByteArrayOutputStream());kryo.writeClassAndObject(output, object);return output.toBytes();}@Overridepublic Object deserialize(byte[] bytes) {Input input = new Input(bytes);return kryo.readClassAndObject(input);}
}
Protobuf 配置
// 需定义.proto文件并生成Java类
template.setValueSerializer(new ProtobufSerializer());

根据项目需求选择序列化器,平衡性能、兼容性和开发成本!

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

ssh私钥文件登录问题:Load key invalid format

问题 在mac上面使用私钥文件登录时候&#xff0c;出现了如下错误&#xff1a; Load key “xxx.pem”: invalid format 但是&#xff0c;这个私钥文件在win上面能够正常使用ssh进行远程登录。在mac上面不能。而且&#xff0c;分别在win和mac上面分别查看了这两个私钥文件的md5…

AI战略群与星际之门:软银AI投资版图计划深度解析

一、星际之门:万亿美元级 AI 基础设施革命 1.1 项目背景与战略定位 在 AI 技术迅猛发展的今天,算力已成为推动其前进的核心动力。软银联合 OpenAI、甲骨文、英伟达、微软、arm推出的 “星际之门”(Stargate)计划,无疑是 AI 领域的一颗重磅炸弹。作为 AI 领域史上最大单笔…

教务系统ER图

实体 1. 学生&#xff1a;具有姓名、学号、性别、系编号、电话、出生年月等属性。学号通常是学生的唯一标识。 2. 课程&#xff1a;包含课程编号、课程名称、课程学分、课程学时等属性。课程编号一般用于唯一标识一门课程。 3. 教师&#xff1a;属性有教师编号、教师名字、性别…

大数据(4.4)Hive多表JOIN终极指南:7大关联类型与性能优化实战解析

目录 背景一、Hive JOIN类型与语法详解1. 基础JOIN类型2. 高级JOIN类型 二、JOIN实战案例与调优案例1&#xff1a;两表内连接&#xff08;订单与用户关联&#xff09;案例2&#xff1a;多表链式JOIN&#xff08;用户-订单-商品&#xff09;案例3&#xff1a;处理数据倾斜&#…

【28BYJ-48】STM32同时驱动4个步进电机,支持调速与正反转

资料下载&#xff1a;待更新。。。。 先驱动起来再说&#xff0c;干中学&#xff01;&#xff01;&#xff01; 1、实现功能 STM32同时驱动4个步进电机&#xff0c;支持单独调速与正反转控制 需要资源&#xff1a;16个任意IO口1ms定时器中断 目录 资料下载&#xff1a;待更…

[Lc6_记忆化搜索] 不同路径 | 解决智力问题 | 有序三元组中的最大值

目录 1.不同路径 题解 2140. 解决智力问题 题解 2873. 有序三元组中的最大值 题解 1.不同路径 链接&#xff1a;62. 不同路径 一个机器人位于一个 m x n 网格的左上角 &#xff08;起始点在下图中标记为 “Start” &#xff09;。 机器人每次只能向下或者向右移动一步…

软件重构与项目进度的矛盾如何解决

软件重构与项目进度之间的矛盾可以通过明确重构目标与范围、采用渐进式重构策略、优化项目管理流程、提高团队沟通效率、建立重构意识文化等方式解决。其中&#xff0c;采用渐进式重构策略尤为关键。渐进式重构是指在日常开发过程中&#xff0c;以小步骤持续进行重构&#xff0…

多台服务器上docker部署 Redis 集群

规划集群节点 确保你的服务器有固定 IP&#xff0c;比如&#xff1a; 172.16.17.100 172.16.17.101 172.16.17.102 每台服务器运行 2 个 Redis 节点&#xff0c;总共 6 个节点&#xff0c;满足 Redis Cluster 最小节点数要求。 2. 在每台服务器上运行 Redis 在每台服务器上执行…

【Pandas】pandas DataFrame dtypes

Pandas2.2 DataFrame Attributes and underlying data 方法描述DataFrame.index用于获取 DataFrame 的行索引DataFrame.columns用于获取 DataFrame 的列标签DataFrame.dtypes用于获取 DataFrame 中每一列的数据类型 pandas.DataFrame.dtypes pandas.DataFrame.dtypes 属性用…

如何实现局域网内无痛访问Jupyter Notebook?

Jupyter Notebook是数据科学和机器学习领域非常常用的交互式开发环境。默认情况下&#xff0c;Jupyter Notebook启动后只能本地访问&#xff0c;并且会自动生成一个token用于身份验证。当需要从其他电脑远程访问时&#xff0c;往往需要对配置进行修改。 本文将详细介绍如何通过…

[Windows] eDiary 4.3.6 日记软件

[Windows] eDiary 链接&#xff1a;https://pan.xunlei.com/s/VOMq6xmKTbEJtNaW-BXZ7KKSA1?pwdcrvu# 【应用功能】 加密 无论本地还是云端&#xff0c;都可以选择高强度加密。系统以用户密码为种子&#xff0c;对数据进行…

掌握 Flexbox 布局:为容器添加竖向滚动条的完美方案

掌握 Flexbox 布局&#xff1a;为容器添加竖向滚动条的完美方案 前言 在现代网页设计中&#xff0c;Flexbox 布局因其灵活性和强大的对齐功能而备受欢迎。然而&#xff0c;在实际开发过程中&#xff0c;我们有时会遇到需要在一个具有最小高度的 Flex 容器中实现内容溢出时显示…

Node.js v22.14.0 多平台安装指南:Windows、Linux 和 macOS 详细教程

Node.js作为现代Web开发的基石&#xff0c;持续为开发者带来性能提升和新特性支持。本文将详细介绍在Windows、macOS和Linux系统上安装最新Node.js的多种方法&#xff0c;助您快速搭建高效的JavaScript开发环境。 &#x1f4e6; 当前最新版本 截至2025年4月&#xff0c;Node.…

动态规划学习——回文子串系列问题【C++】

一&#xff0c;回文子串 题目链接&#xff1a;LCR 020. 回文子串 - 力扣&#xff08;LeetCode&#xff09; 【问题描述】 求一个字符串中有多少个回文子串&#xff0c;其中一个字符也算是一个回文子串。 【解法】 动态规划 求一个字符串中回文子串的个数&#xff0c;我么可…

My first day in QT programming

My first QT code this->setWindowTitle("HelloWorld"); //设置窗口名称 this->resize(400, 300); //设置窗口大小 QPushButton* btn new QPushButton; //新建按钮组件 btn->setParent(this); //为按钮指定父对象 …

基于python开发的邮箱合并群发工具

智能邮件群发系统 一个基于Python和PyQt5开发的智能邮件群发工具&#xff0c;支持Word模板和Excel数据源的自动匹配&#xff0c;具有现代化UI界面和友好的用户体验。 Github项目地址&#xff1a;https://github.com/liugang926/Auto-mail-sent.git dist目录有编译好的exe程序&…

大模型-提示词(Prompt)技巧

1、什么是提示词&#xff1f; 提示词&#xff08;Prompt&#xff09;是用户发送给大语言模型的问题、指令或请求&#xff0c;用来明确地告诉模型用户想要解决的问题或完成的任务&#xff0c;是大语言模型理解用户需求并据此生成相关、准确回答或内容的基础。对于大语言模型来说…

Android开发:support.v4包与AndroidX

Android中的support.v4包与AndroidX support.v4包概述 Android Support Library中的android.support.v4包是Google为保持Android应用向后兼容而提供的重要支持库集合。它主要解决以下问题&#xff1a; API版本兼容&#xff1a;让新版API能在旧版Android系统上使用功能增强&a…

TCP-IP模型

书接上回&#xff08;OSI通信模型&#xff09; TCP-IP协议结构 &#xff08;略讲&#xff09; ARP&#xff1a;IP-->MAC RARP&#xff1a;MAC-->IP ICMP&#xff1a;控制报文信息协议&#xff0c;主要是涉及到主机就去连接路由器时控制传输报文&#xff08…

雪花算法生成的主键存在哪些问题,为什么不能使用自增ID或者UUID做MySQL的主键

MySQL 分布式架构中的主键选择&#xff1a;自增ID、UUID与雪花算法 为什么MySQL分布式架构中不能使用自增主键&#xff1f; 在分布式架构中&#xff0c;自增主键存在以下问题&#xff1a; 主键冲突风险&#xff1a;多个数据库实例同时生成自增主键会导致ID重复分片不均匀&am…