微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Fatal error: Allowed memory size of 134217728 bytes exhausted (tried to allocate 2611816 bytes)

今天要用PHP代码来处理一个580M的日志文件,总共有219万多行记录,因为是.log的文件,在windows下面很难将文件按照条数来分割,于是在linux下用split -l 10000 filename 前缀名 将整个文件按10000行一个分割成了200多个小文件,之后用PHP来循环处理这200多个文件,可是执行到后来就出现了题目上面的错误

代码如下:
Fatal error: Allowed memory size of 134217728 bytes exhausted (tried to allocate 2611816 bytes)

百度了一下,原来是PHP.ini中的内存分配的问题,PHP代码能够申请到的最大内存字节数就是134217728 bytes,如果代码执行的时候再需要更多的内存,就会报错了,于是就将PHP.ini文件中的配置改了一下:

代码如下:

但是之后一想,一个PHP脚本一次请求的内存空间就要超过128M,那不管你以后将memory_limit设置成多大,以后肯定有出问题的时候。

究其原因,是我在在编码时,仅仅对变量赋值,却从来没有 unset ($var) 过。导致了内存占用越来越多,所以以后一个变量不再使用之后,一定要记得unset掉它。

下面附上我今天处理这个日志文件代码

代码如下:
PHP set_time_limit(1800) ; /** * 获取日志中发送失败的邮箱地址 * @param $directory log日志的目录 * @param $name 失败邮箱保存的文件名 */ function getmail($directory,$name){ //遍历目录下的.log文件 $files=scandir("$directory"); foreach($files as $v){ if(preg_match_all("|mail\.log\D+|",$v,$log)){ $logs[]=$log[0][0]; } } //将所有.log文件中发送失败邮箱提取出来 foreach($logs as $v){ $row=file("$v"); echo "读取".$v."文件
"; foreach($row as $key => $value) { if(eregi("host name lookup failure|Connection timed out with|Connection refused by|cannot find your reverse hostname",$value)){ if(preg_match("|\w+([-+.]\w+)*@\w+([-.]\w+)*.\w+([-.]\w+)*|",$row[$key],$matches)){ $mail[] = trim($matches[0]); echo "获取发送失败的邮箱地址".$matches[0]."
"; }else{ echo "无法获取日志中发送失败的邮箱,请检查"; } } } unset($row); } //将提取出来的发送失败邮箱写入到mail.txt文件中 $mailurl=fopen("$name","a"); foreach($mail as $line) { fwrite($mailurl,$line."\r\n"); } echo "将所有发送失败的邮箱地址写入".$name."
"; fclose($mailurl); }

getmail(".","mail.txt"); ?>

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐