本帖最后由 qidizi 于 2013-2-19 13:46 编辑
今天在打开线上forum.php时发现页页500了,
查看出错日记,发现是此方法导致内存占用完了无法分配而出错,只是以为内存过小,于是设置成128m变成512m,好像解决了此问题.
接着本地测试代码放在移动硬盘中,前面更改了盘符了,打开此首页还是照样的500挂了,再查看日记,还是dmkdir挂掉了,还是内存分配问题.
也把本地的128调成512m的,还是有问题,且512的都光了,觉得奇怪,
于是跟踪此方法是否有死环,
function dmkdir($dir, $mode = 0777, $makeindex = TRUE){
file_put_contents('Y:/web/www/dx/1.txt', file_get_contents('Y:/web/www/dx/1.txt') . "\n{$dir}");
if(!is_dir($dir)) {
dmkdir(dirname($dir), $mode, $makeindex);
@mkdir($dir, $mode);
if(!empty($makeindex)) {
@touch($dir.'/index.html'); @chmod($dir.'/index.html', 0777);
}
}
return true;
}
打开1.txt发现
F:/web/www/dx/./data/attachment/./block/45
F:/web/www/dx/./data/attachment/./block
F:/web/www/dx/./data/attachment/.
F:/web/www/dx/./data/attachment
F:/web/www/dx/./data
F:/web/www/dx/.
F:/web/www/dx
F:/web/www
F:/web
F:\
F:\
F:\
F:\
F:\
F:\
F:\
F:\
F:\
F:\
然后一直 f:\到页面挂掉,看了一眼电脑,没有f:\盘存在,这就是之前的Y盘的盘符,
暂不管这个代码那来调用,为什么会出现写死的盘符,
于是测试 一下此方法. dmkdir 根本没有理会是否永远不能创建成功情况,最终只会直到死掉为止.

简单的处理可以如下,这只是针对window下的,因为linux总是以/开始,不存在根目录不存在总是
if(!is_dir($dir)) {
if ($dir == dirname($dir) ) { echo "<!-- dmkdir()方法出现死循环-->"; return false; }
|