php 创建文件名为 test.html 的文件,使用 filectime 获取创建时间 t1
php 删除文件名为 test.html 的文件
php 重新创建文件名为 test.html 的文件,使用 filectime 获取创建时间 t2
为什么 t1 = t2 ?? 就是创建时间为什么没更新?? 我使用了 clearstatcache 函数清除文件状态缓存也没点用,这个怎么解决??(由于在判断是否重新生成缓存文件的时候,需要知道缓存文件的创建时间,所以很重要..,求解决~)
下面是出现这种情况的问题的代码(有点密,请耐心看下哈):
// 页面缓存
if ((defined('DEBUG_MODE') && !DEBUG_MODE) && (defined('CACHE_CONTROL') && CACHE_CONTROL)) {
$opr = $GLOBALS['module'] . '/' . $GLOBALS['platform'] . '/' . $GLOBALS['controller'] . '/' . $GLOBALS['act'];
$cache_name = md5($opr) . TEMPLATE_SUFFIX;
$cache_file = APP_DIR . '/' . $GLOBALS['module'] . '/' . $GLOBALS['platform'] . '/Cache/' . $cache_name;
// 清除文件状态缓存(就我使用的情况来看,压根没毛用...,这什么情况??)
clearstatcache();
// 缓存文件不存在 创建
if (!$GLOBALS['FOpr']->checkFile($cache_file)) {
require_once $view_file;
$GLOBALS['FOpr']->cFile($cache_file);
$GLOBALS['FOpr']->wData($cache_file , ob_get_contents());
} else {
// 超时重新缓存
if (time() > filectime($cache_file) + CACHE_LIFE_TIME) {
require_once $view_file;
// 缓存文件超时时,先删除原缓存文件
$GLOBALS['FOpr']->dFile($cache_file);
// 新建同名缓存文件
//(新建文件时,filectime 获取文件创建时间一直没更新!这个怎么破??
// 这导致我没法重新生成缓存文件了!)
$GLOBALS['FOpr']->cFile($cache_file);
// 写入缓存
$GLOBALS['FOpr']->wData($cache_file , ob_get_contents() , 'w');
} else {
// 加载缓存文件
require_once $cache_file;
}
}
} else {
// 显示动态文件(非缓存)
require_once $view_file;
}
ringa_lee2017-04-11 10:41:33
filemtime 能更好的完成Cache的超时判断逻辑;
文件是可以不删除的,因为重新写入后,filemtime会变;
你删除文件肯定有原因,但是请看答案下的「题外」
笔者用如下代码做了个试验
$path = __DIR__.'/test.txt';
file_put_contents($path, 'content1');
echo filectime($path),PHP_EOL;
unlink($path);
sleep(2);
file_put_contents($path, 'content2');
echo filectime($path),PHP_EOL;
返回时间的确一样,当我第二次执行时,时间仍然同第一次的一样。
但是我的确看到了这个txt消失了2秒后,再被生成。这也许在windows下有这样的逻辑存在(未深究),如图是我第二次执行后得到的文件属性:
返回的时间,会变
在我写的或者我看到的一些file cache引擎中,read cache操作,即使检测到超时,也并未删除Cache文件。
这里并不是偷懒,毕竟unlink很容易
而是减少必要的i/o请求,以及并发带来的unlink的风险(自己想一下为什么?)
再说,按照惯性思维,既然你在访问此cache,那么此cache肯定会被复写的,所以删除后重建的意义不太大
唯一的问题是磁盘空间占用问题,比如一些很久没人访问的cache仍然占用空间,对于这种情况,我们一般选择容忍,或者自己实现代码用定时任务去删除
smarty编译文件和你的场景类似,他的做法是:不删