SpringBoot 中的 Redis 序列化

embedded/2025/3/1 11:50:36/

SpringBoot 中的 Redis 序列化


在 Spring Boot 中,Redis 的序列化是指将 Java 对象转换为字节流(序列化)以便存储到 Redis 中,以及从 Redis 中读取字节流并将其转换回 Java 对象(反序列化)。

这是因为在 Redis 中存储的数据是以键值对的形式存在的,而键和值都是二进制安全的字符串。为了能够在 Redis 中存储复杂的 Java 对象,必须先将这些对象序列化为字节流。

1. 为什么需要序列化?

  1. 数据存储格式:Redis 本身并不直接支持 Java 对象,它只能存储字符串、数字或字节数组等形式的数据。因此,Java 对象需要被转换为 Redis 能够理解的格式。
  2. 跨语言兼容性:Redis 是一个通用的缓存和存储系统,可能被多种编程语言使用。序列化可以确保数据在不同语言之间传递时保持一致性。
  3. 性能优化:通过序列化,可以减少数据在网络中的传输量,提高效率。

2. Spring Boot 中 Redis 的序列化机制

2.1 默认序列化方式

Spring Boot提供了一些默认的序列化方式,如 JdkSerializationRedisSerializerStringRedisSerializer 等。其中

  1. JdkSerializationRedisSerializer 是使用 Java 自带的序列化机制将对象转换为字节数组
  2. StringRedisSerializer 则是将字符串按照字节数组的方式进行存储

2.2 自定义序列化方式

除了默认的序列化方式,开发者还可以根据具体需求自定义序列化方式。例如,可以使用 JSON 格式将 Java 对象转换为字符串,然后再将字符串转换为字节数组进行存储和传输。这种方式可以提高数据的可读性和跨平台性。

例子:

public RedisTemplate<Object, Object> redisTemplate(RedisConnectionFactory connectionFactory) {RedisTemplate<Object, Object> template = new RedisTemplate<>();template.setConnectionFactory(connectionFactory);FastJson2JsonRedisSerializer serializer = new FastJson2JsonRedisSerializer(Object.class);// 使用 StringRedisSerializer 来序列化和反序列化 redis 的 key 值template.setKeySerializer(new StringRedisSerializer());template.setValueSerializer(serializer);// Hash 的 key 也采用 StringRedisSerializer 的序列化方式template.setHashKeySerializer(new StringRedisSerializer());template.setHashValueSerializer(serializer);template.afterPropertiesSet();return template;
}

2.3 为什么自定义序列化器?

  1. 节省内存空间

    由于 Redis 存储在内存中,而内存资源又很重要,通过自定义序列化器,可以为当前数据选择最合适的序列化方式,从而减少内存空间的占用。

  2. 提高序列化效率

    默认的 JdkSerializationRedisSerializer 使用 Java 自带的序列化机制,生成的字节流较大且性能较低。

  3. 支持复杂的数据结构

    默认的序列化器可能无法很好地处理复杂的 Java 对象或嵌套结构。通过自定义序列化器,可以针对特定的业务对象设计序列化逻辑,确保数据能够正确存储和恢复。

  4. 兼容性与迁移需求

    在某些场景下,Redis 中的数据可能由不同的系统或版本生成,导致序列化格式不一致。通过自定义序列化器,可以实现对旧数据的兼容性处理,或者在不同版本之间进行平滑迁移。

  5. 数据压缩

    为了减少 Redis 中存储的数据量,可以通过自定义序列化器对数据进行压缩后再存储。

  6. 数据加密

    对于敏感数据,可以在序列化时对其进行加密处理,确保数据在 Redis 中存储时的安全性。

3. 序列化与反序列化的流程

  1. 序列化过程
    • Java对象 → 序列化器 → 字节数组 → 存储到Redis。
  2. 反序列化过程
    • 从Redis读取字节数组 → 反序列化器 → 还原为Java对象。

4. 注意事项

  1. 序列化性能:不同的序列化器性能差异较大,推荐根据实际需求选择高效的序列化器(如 JSON 序列化器)。
  2. 版本兼容性:如果使用自定义序列化器或复杂的对象结构,请确保序列化和反序列化的环境一致,否则可能导致数据无法正确解析。
  3. 数据安全性:对于敏感数据,建议在序列化前进行加密处理。

综上所述,在 Spring Boot 中,Redis 的序列化是一个将 Java 对象转换为可以存储和传输的形式的过程。开发者可以根据具体需求选择默认的序列化方式或自定义序列化方式,并通过配置文件或代码进行配置。


http://www.ppmy.cn/embedded/169045.html

相关文章

突破网络壁垒:实现 Mac SSH 访问 Windows WSL Ubuntu 的最佳实践20250301

突破网络壁垒&#xff1a;实现 Mac SSH 访问 Windows WSL Ubuntu 的最佳实践 背景与痛点 在现代开发环境中&#xff0c;开发者通常会面临不同操作系统之间的协同工作。例如&#xff1a; 主要开发环境位于 Windows 的 WSL Ubuntu 子系统需要从局域网内的 Mac 设备进行远程访问…

贪心算法精品题

1.找钱问题 本题的贪心策略在于我们希望就可能的保留作用大的5元 class Solution { public:bool lemonadeChange(vector<int>& bills) {std::map<int ,int> _map;for(auto ch:bills){if(ch 5) _map[ch];else if(ch 10){if(_map[5] 0) return false;else{_m…

SOME/IP-SD -- 协议英文原文讲解7

前言 SOME/IP协议越来越多的用于汽车电子行业中&#xff0c;关于协议详细完全的中文资料却没有&#xff0c;所以我将结合工作经验并对照英文原版协议做一系列的文章。基本分三大块&#xff1a; 1. SOME/IP协议讲解 2. SOME/IP-SD协议讲解 3. python/C举例调试讲解 5.1.4 Ser…

Qt关于平滑滚动的使用QScroller及QScrollerProperties类说明

一、触控时代的滚动工具&#xff1a;QScroller类设计介绍 1.1 从机械滚轮到数字惯性 在触控设备普及前&#xff0c;滚动操作如同老式打字机的滚轴&#xff0c;只能通过鼠标滚轮或滚动条进行离散式控制。QScroller的出现如同给数字界面装上了"惯性飞轮"&#xff0c;…

软件高级架构师 - 设计模式

六大原则 1. 单一职责原则 一个类只负责一项职责。 案例 餐厅中的厨师和服务员&#xff1a; 厨师的职责是做饭&#xff0c;服务员的职责是上菜。 如果让厨师同时负责做饭和上菜&#xff0c;会导致职责混乱&#xff0c;效率降低。 2. 开放-封闭原则&#xff08;OCP&#xff09…

配置Spring Boot中的Jackson序列化

配置Spring Boot中的Jackson序列化 在开发基于Spring Boot的应用程序时&#xff0c;Jackson是默认的JSON序列化和反序列化工具。它提供了强大的功能&#xff0c;可以灵活地处理JSON数据。然而&#xff0c;Jackson的默认行为可能无法完全满足我们的需求。例如&#xff0c;日期格…

React antd的datePicker自定义,封装成组件

一、antd的datePicker自定义 需求&#xff1a;用户需要为日期选择器的每个日期单元格添加一个Tooltip&#xff0c;当鼠标悬停时显示日期、可兑换流量余额和本公会可兑流量。这些数据需要从接口获取。我需要结合之前的代码&#xff0c;确保Tooltip正确显示&#xff0c;并且数据…

【Prometheus】prometheus服务发现与relabel原理解析与应用实战

✨✨ 欢迎大家来到景天科技苑✨✨ 🎈🎈 养成好习惯,先赞后看哦~🎈🎈 🏆 作者简介:景天科技苑 🏆《头衔》:大厂架构师,华为云开发者社区专家博主,阿里云开发者社区专家博主,CSDN全栈领域优质创作者,掘金优秀博主,51CTO博客专家等。 🏆《博客》:Python全…