贯穿设计模式-组合模式+访问者模式

109 阅读1分钟

引言

样例所有代码可以github.com/WeiXiao-Hyy…获取,欢迎Star!

组合模式+访问者模式

需求

商品类目多,变化快,并且要求2个小时内生效

现状

前端有自己的缓存2小时,后端依赖redis,先查redis,后查mysql

技术方案讨论

先更新mysql,再删除缓存

更新完mysql,删除缓存之后,有大量的请求来之后会引起缓存击穿

前端目前是pull的逻辑,本地缓存失效之后,会主动pull,改成后端push会不会好点?

2小时不需要,push的实时性很高,如果改成消息推送,前,后端都需要改,改动比较大,测试量大,风险比较高

解决缓存击穿问题

选择在凌晨进行操作?不可取,业务要求随时更新

先更新数据库,后更新缓存

更新完数据库后,STW GC后,会获取到不一致的数据

先更新缓存,再更新数据库

有数据持久化的风险

最后方案选型

通常做法是延迟双删,binlog订阅删除,由于需求的特殊性采用先更新数据库,后更新缓存的策略,前端的缓存时间修改为1小时50分钟

组合模式

一般来说用于比较复杂的树形结构数据

组合模式.png

访问者模式

访问者模式一般会和组合模式一起使用

访问者模式.png

参考资料