目前就我而言,php使用memache或者redis缓存数据,当数据有更新数据时,根据标签清除掉数据,那么有没有一套自动更新的策略呢?
阿神2017-04-10 14:52:21
删除比更新好,如果你的请求里面包含了多次数据更新,由此会触发多次缓存更新,但实际上只有最后一次更新的缓存才是有效的。如果更新缓存的执行成本较高的话可能在偶发的高频更新下会引发执行效率的问题。
相对来说,删除缓存的代价更低,且没有请求就不会生成新的缓存,中间无论怎么更新数据都不会浪费。
这种删除策略对于高负荷网站很可能是不适用的,对于这种类型的应用,宁愿牺牲一致性也不会让大量请求直接穿透到数据库上,但对于大多数网站,这种做法应该问题都不大。
PHPz2017-04-10 14:52:21
这和我前几天解决的问题类似,卖个萌!
其实这类问题,我个人认为属于框架问题,或再大一点说是架构问题也不为过~所以如果只是盯着业务来思考这个问题,可能会很无力~
之所以我最后采取“爬虫”方案,是因为开发之初就没有意识到缓存已经成为现在网站的标配,属于非功能性但必要需求!
迷茫2017-04-10 14:52:21
对于楼主的疑问,我也仔细思考过。本质上就是在缓存读取的时候加一个条件。IF(缓存失效)THEN(重建)ELSE(返回缓存数据)。这样的机制对开发来说的确很诱人,不用担心更新数据忘记清缓存。但是。。。IF条件当中的判断缓存失效的数据从哪里来呢?我想要么数据库,要么缓存,要么队列。所以个人觉得为了实现这么一个自动的功能代价有点高。
PHP的YII框架中有一个缓存依赖的模块可以看看,大致思路如上所述。其中的“缓存依赖”就相当于上面说的判断“缓存失效”的条件;在YII中,缓存依赖有很多种,例如数据库,缓存,文件更新时间等