0

0

JCache with Redisson:序列化/反序列化机制详解

霞舞

霞舞

发布时间:2025-12-26 11:55:08

|

959人浏览过

|

来源于php中文网

原创

JCache with Redisson:序列化/反序列化机制详解

redisson 默认使用 kryo 实现高效、无侵入的序列化,无需对象实现 `serializable`;java 原生序列化仅在显式配置时启用,可通过 `codec` 灵活替换为 json、avro 或自定义序列化器。

在基于 JCache(JSR-107)规范集成 Redisson 作为缓存提供者时,序列化行为是核心关注点之一——它直接影响性能、兼容性与可维护性。值得注意的是,Redisson 并不依赖 Java 原生序列化(java.io.Serializable)作为默认机制,而是采用更轻量、更快、且无需强制实现 Serializable 接口的 Kryo 序列化器。

✅ 默认行为:Kryo 序列化(零配置即生效)

当你通过 RedissonConfiguration 或 RedissonClient 创建 CacheManager 时(例如使用 RedissonCachingProvider),若未显式指定 Codec,Redisson 将自动启用 KryoCodec(自 3.17.0+ 版本起为默认)。Kryo 的优势包括:

  • ✅ 支持 java.time.* 类型(如 LocalDateTime、ZonedDateTime)开箱即用;
  • ✅ 支持标准集合(List、Map、Set)及常见 POJO,无需实现 Serializable;
  • ✅ 序列化体积小、速度快,显著优于 Java 原生序列化;
  • ✅ 自动注册常用 JDK 类型,避免手动注册开销。

示例:无需任何改动即可安全缓存时间对象和列表:

Cache> cache = cacheManager.getCache("events", String.class, List.class);
cache.put("today", Arrays.asList(LocalDateTime.now(), LocalDateTime.now().plusHours(1)));

⚠️ 注意:Redis 中的数据并非 Java 原生字节

你观察到 Redis 中存储的是二进制数据,但这不是 ObjectOutputStream 生成的 java.io.Serializable 字节流。Kryo 输出的是紧凑的二进制格式(非可读、不可跨语言直接解析),因此不能用 redis-cli 直接解读内容——这是正常现象,不代表使用了原生序列化。

剪映专业版
剪映专业版

一款全能易用的桌面端剪辑软件

下载

? 如何自定义序列化行为?

如需更强的可读性、跨语言兼容性或已有 JSON 生态,可轻松切换 Codec。例如,使用 JsonJacksonCodec(推荐用于调试或微服务间共享缓存):

Config config = new Config();
config.setCodec(new JsonJacksonCodec()); // 启用 Jackson JSON 序列化
config.useSingleServer().setAddress("redis://127.0.0.1:6379");

RedissonClient redisson = Redisson.create(config);
CacheManager cacheManager = Caching.getCachingProvider().getCacheManager(
    null, 
    redisson, 
    Collections.singletonMap(RedissonCachingProvider.REDISSON_CLIENT, redisson)
);
? 提示:JsonJacksonCodec 要求被缓存对象具备无参构造函数及标准 getter/setter;对 java.time.* 需额外注册 JavaTimeModule(Redisson 内置已支持,无需手动配置)。

❌ 不建议使用 Java 原生序列化

尽管可通过 SerializationCodec 强制启用,但应避免:

  • 性能差(反射开销大、字节流冗长);
  • 安全风险高(反序列化漏洞);
  • 版本兼容性脆弱(serialVersionUID 变更即失效);
  • 无法序列化 lambda、匿名内部类等现代 Java 特性。

✅ 最佳实践总结

场景 推荐方案
默认生产环境 保持 KryoCodec(高性能、低侵入)
调试/日志友好 切换 JsonJacksonCodec(人类可读)
跨语言系统集成 使用 AvroCodec 或自定义 Protobuf Codec
自定义类型支持 为 Kryo 注册 Serializer,或为 Jackson 添加 Module

总之,Redisson 的序列化设计以开发者体验和运行时效率为核心:无需 Serializable,不绑定 JDK 限制,且完全可插拔。合理选择 Codec,既能保障类型安全与兼容性,又能兼顾性能与可观测性。

相关专题

更多
java
java

Java是一个通用术语,用于表示Java软件及其组件,包括“Java运行时环境 (JRE)”、“Java虚拟机 (JVM)”以及“插件”。php中文网还为大家带了Java相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

651

2023.06.15

java流程控制语句有哪些
java流程控制语句有哪些

java流程控制语句:1、if语句;2、if-else语句;3、switch语句;4、while循环;5、do-while循环;6、for循环;7、foreach循环;8、break语句;9、continue语句;10、return语句。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

455

2024.02.23

java正则表达式语法
java正则表达式语法

java正则表达式语法是一种模式匹配工具,它非常有用,可以在处理文本和字符串时快速地查找、替换、验证和提取特定的模式和数据。本专题提供java正则表达式语法的相关文章、下载和专题,供大家免费下载体验。

722

2023.07.05

java自学难吗
java自学难吗

Java自学并不难。Java语言相对于其他一些编程语言而言,有着较为简洁和易读的语法,本专题为大家提供java自学难吗相关的文章,大家可以免费体验。

725

2023.07.31

java配置jdk环境变量
java配置jdk环境变量

Java是一种广泛使用的高级编程语言,用于开发各种类型的应用程序。为了能够在计算机上正确运行和编译Java代码,需要正确配置Java Development Kit(JDK)环境变量。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

394

2023.08.01

java保留两位小数
java保留两位小数

Java是一种广泛应用于编程领域的高级编程语言。在Java中,保留两位小数是指在进行数值计算或输出时,限制小数部分只有两位有效数字,并将多余的位数进行四舍五入或截取。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

398

2023.08.02

java基本数据类型
java基本数据类型

java基本数据类型有:1、byte;2、short;3、int;4、long;5、float;6、double;7、char;8、boolean。本专题为大家提供java基本数据类型的相关的文章、下载、课程内容,供大家免费下载体验。

441

2023.08.02

java有什么用
java有什么用

java可以开发应用程序、移动应用、Web应用、企业级应用、嵌入式系统等方面。本专题为大家提供java有什么用的相关的文章、下载、课程内容,供大家免费下载体验。

427

2023.08.02

虚拟号码教程汇总
虚拟号码教程汇总

本专题整合了虚拟号码接收验证码相关教程,阅读下面的文章了解更多详细操作。

25

2025.12.25

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Kotlin 教程
Kotlin 教程

共23课时 | 2万人学习

C# 教程
C# 教程

共94课时 | 5.3万人学习

Java 教程
Java 教程

共578课时 | 37.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号