缓存污染日常实践思考

简介: 缓存污染日常实践思考

缘起

  • 这篇文章的思考缘于今天的一个系统发布引起的缓存污染,所谓的缓存污染指的是缓存数据的字段内容因为新旧服务同时存在读写导致异常发生。
  • 缓存污染造成影响一般包含两方面,一是数据反序列化失败;二是新增字段为null导致逻辑处理异常。
  • 所谓反序列化失败是指新服务写入的缓存数据相对于旧服务而言增加了字段导致旧服务反序列化失败。
  • 所谓新增字段为null导致逻辑处理异常使指新服务依赖核心新增字段但是由于旧服务写入的缓存数据不包含该新增字段导致异常。
  • 当然常在河边走,这两种湿鞋的情况都遇到过,幸运未造成严重后果。


本质

  • 缓存污染的问题基本上可以参考上面两种场景图,左边是两系统共用同一缓存的key,右边是同一系统的多台机器共用同一缓存key。
  • 因为系统发布前后顺序的问题,会导致同时存在同一key两种类型value的写入和读取,如果不幸在序列化和反序列化当中没有做到向后兼容就会发生悲剧,同样如果有幸逃过序列化这个劫,还需要考虑针对新增字段为null的情况的兼容。
  • 本质上针对缓存数据新增字段得保持两个意识,一是缓存数据序列化兼容问题,二是新增字段为null业务兼容问题。
  • 缓存一旦被污染,要么期待缓存的数据TTL过期时间不长能够尽快恢复,要么有紧急开关能够一键关闭缓存直接访问DB,剩下的就是看天意了。


解决

  • 针对涉及缓存数据格式更改的场景,特别需要关注数据内容的序列化和反序列化兼容性问题,如jackson需要特殊配置才能兼容,fastjson就不需要,具体的不确定可以实际验证一把。
  • 针对序列化和反序列化部分建议增加try/catch进行兜底,保证序列化和反序列化失败当成缓存结果为空继续都DB访问,前期是DB能够扛住正常峰值流量。
  • 缓存数据TTL设置切记过大,设置合理的过期时间能够让影响面尽量变小。
  • 缓存污染是需要多台机器部署的场景才能出现的,但是测试环境和预发环境基本上都是单台机器,所以在测试过程中是很难发现的,这就是为什么上线总有意想不到的事情发生


衍生

  • 缓存和DB的数据一致性是业界难题,截止目前我了解到的组合解决方案就是 1、合理设置TTL保证数据过期;2、写完DB后删缓存由下次访问重新写入缓存;3、通过旁路的canal监听来实现兜底更新
目录
相关文章
|
5月前
|
缓存 Java Maven
Java本地高性能缓存实践问题之SpringBoot中引入Caffeine作为缓存库的问题如何解决
Java本地高性能缓存实践问题之SpringBoot中引入Caffeine作为缓存库的问题如何解决
128 1
|
5月前
|
缓存 Java Spring
Java本地高性能缓存实践问题之Caffeine中设置刷新机制的问题如何解决
Java本地高性能缓存实践问题之Caffeine中设置刷新机制的问题如何解决
155 1
|
5月前
|
存储 缓存 Java
Java本地高性能缓存实践问题之如何定义Caffeine的缓存
Java本地高性能缓存实践问题之如何定义Caffeine的缓存
|
5月前
|
缓存 Java
Java本地高性能缓存实践问题之Caffeine缓存库中基于时间设置驱逐策略的问题如何解决
Java本地高性能缓存实践问题之Caffeine缓存库中基于时间设置驱逐策略的问题如何解决
|
5月前
|
缓存 Java
Java本地高性能缓存实践问题之AsyncCache中移除一个缓存元素的问题如何解决
Java本地高性能缓存实践问题之AsyncCache中移除一个缓存元素的问题如何解决
|
5月前
|
缓存 Java
Java本地高性能缓存实践问题之使用Caffeine的Cache接口来查找一个缓存元素的问题如何解决
Java本地高性能缓存实践问题之使用Caffeine的Cache接口来查找一个缓存元素的问题如何解决
|
2月前
|
缓存 NoSQL Redis
Redis 缓存使用的实践
《Redis缓存最佳实践指南》涵盖缓存更新策略、缓存击穿防护、大key处理和性能优化。包括Cache Aside Pattern、Write Through、分布式锁、大key拆分和批量操作等技术,帮助你在项目中高效使用Redis缓存。
342 22
|
3月前
|
存储 缓存 NoSQL
保持HTTP会话状态:缓存策略与实践
保持HTTP会话状态:缓存策略与实践
|
3月前
|
存储 缓存 NoSQL
深入理解后端缓存机制的重要性与实践
本文将探讨在后端开发中缓存机制的应用及其重要性。缓存,作为提高系统性能和用户体验的关键技术,对于后端开发来说至关重要。通过减少数据库访问次数和缩短响应时间,缓存可以显著提升应用程序的性能。本文将从缓存的基本概念入手,介绍常见的缓存策略和实现方式,并通过实例展示如何在后端开发中有效应用缓存技术。最后,我们将讨论缓存带来的一些挑战及其解决方案,帮助您在实际项目中更好地利用缓存机制。
|
3月前
|
存储 缓存 监控
HTTP:强缓存优化实践
HTTP强缓存是提升网站性能的关键技术之一。通过精心设计缓存策略,不仅可以显著减少网络延迟,还能降低服务器负载,提升用户体验。实施上述最佳实践,结合持续的监控与调整,能够确保缓存机制高效且稳定地服务于网站性能优化目标。
59 3