实录:我被缓存TP的缓存文件坑了一夜!

实录:我被缓存TP的缓存文件坑了一夜!
2018年3月21日晚上9点左右。本身开发的项目,为了优化系统性能,我尽可能在数据查询时添加缓存,如:
M(‘tbale_name’) -> cache(‘cache_name’) -> select();
为了让缓存数据与最新数据无缝链接,我在每次更新数据库操做后都添加了删除缓存的语句,如:
S(‘cache_name’,null);
可是,就在其中一个页面,我惊奇地发现,提交表单后,竟然产生了一系列的相似空文件的缓存文件,其内容大概是这样的:
实录:我被缓存TP的缓存文件坑了一夜!
因为这个页面的数据库操做比较我,每操做一个SQL都会执行一次不一样的缓存删除,刚开始,我一直觉得是由于删除缓存的数据不存在,反而建立了这个空缓存文件,因而,我立刻在TP技术QQ群里发问了:
实录:我被缓存TP的缓存文件坑了一夜!
然而,并无人回应我。无奈,只好百度搜索啦,但貌似度娘上面也找不到相似答案。(其实根本就不存在我这样的问题),由于执行S方法删除缓存时,若是缓存不存在,并不会产生空文件。还好,我在相关页面看到了这样一个办法:在删除缓存的语句前添加一个判断:
If(S(‘cache_name’)) S(‘cache_name’,null);
可是,并无达到我指望的效果,照样的产生一堆“垃圾缓存”!php

原本我是为了优化系统而使用的缓存,但如今看到系统莫名其妙地产生了这么多“垃圾文件”,反而形成了磁盘的多余的写入操做,因此,我以为必需要解决掉这些垃圾!数据库

为了处理这些“垃圾缓存”文件,我开始“地爬式”地检查代码,在此以前,已经思考和查找了将近一个小时了!缓存

首先,我把每【一条执行了数据库缓存操做的语句】都一一注释掉,但依然产生了“垃圾缓存”。ide

而后,我从这个页面的整个代码——从上往下的分段注释,依然没有找到缘由。性能

时间又一刻一刻地过去了,快到12点了,老婆催我快睡觉了,今天由于其余事情,心情就很很差了,而敲代码又遇到这个纠结的问题,很不爽,因此决定必定要解决了才睡觉。优化

这时,我也有点烦躁了,又一次地把【全部执行了数据库操做的语句】一一注释掉,终于没有产生垃圾文件了!——请注意个人【】里面文字的差异哈!code

最终,终于肯定这些“垃圾缓存”并非来自于cache方法,也不是来自于S方法,而是来自于Thinkphp的数据库模型方法里面的setInc方法!blog

setInc方法的功能是让某个字段自增必定的值,默认是当即执行,但在我深刻研究TP后,发现它能够设置延迟更新,以减轻数据库写入压力,因而就设置了1分钟延迟更新:
M(‘table_name’)->where($map)->setInc(‘field’,1,60);
之前我也怀疑它是如何作到延迟更新的,今天遇到这些“垃圾文件”终于知道它的原理了,原来就是靠缓存文件来记录将要更新的数据!开发

虽然,取消延迟更新就消除了这些垃圾缓存文件,但相应的问题又回来了:当大量用于访问这个页面的时候,数据库的写入压力就很大,而使用延迟更新,又会产生垃圾的“垃圾缓存文件”,对磁盘读写也是一种消耗,真不知道该如何选择了!在此,请教读者朋友帮忙指点指点吧!it