样例所有代码可以https://github.com/WeiXiao-Hyy/Design-Patterns获取
组合模式+访问者模式
需求
商品类目多,变化快,并且要求2个小时内生效
现状
前端有自己的缓存2小时,后端依赖redis,先查redis,后查mysql
技术方案讨论
先更新mysql,再删除缓存
更新完mysql,删除缓存之后,有大量的请求来之后会引起缓存击穿
前端目前是pull的逻辑,本地缓存失效之后,会主动pull,改成后端push会不会好点?
2小时不需要,push的实时性很高,如果改成消息推送,前,后端都需要改,改动比较大,测试量大,风险比较高
解决缓存击穿问题
选择在凌晨进行操作?不可取,业务要求随时更新
先更新数据库,后更新缓存
更新完数据库后,STW GC后,会获取到不一致的数据
先更新缓存,再更新数据库
有数据持久化的风险
最后方案选型
通常做法是延迟双删,binlog订阅删除,由于需求的特殊性采用先更新数据库,后更新缓存的策略,前端的缓存时间修改为1小时50分钟
组合模式
一般来说用于比较复杂的树形结构数据
访问者模式
访问者模式一般会和组合模式一起使用
参考资料
lombok注解@Data使用在继承类上时出现警告_add ‘@equalsandhashcode(callsuper=false)’ to your -CSDN博客