Fatal error: Allowed memory size of 134217728 bytes exhausted (tried to allocate 2611816 bytes)
今天要用php代碼來處理一個580M的日志文件,總共有219萬多行記錄,因?yàn)槭?log的文件,在windows下面很難將文件按照條數(shù)來分割,于是在linux下用split -l 10000 filename 前綴名 將整個文件按10000行一個分割成了200多個小文件,之后用php來循環(huán)處理這200多個文件,可是執(zhí)行到后來就出現(xiàn)了題目上面的錯誤:
Fatal error: Allowed memory size of 134217728 bytes exhausted (tried to allocate 2611816 bytes)
去百度了一下,原來是php.ini中的內(nèi)存分配的問題,默認(rèn)php代碼能夠申請到的最大內(nèi)存字節(jié)數(shù)就是134217728 bytes,如果代碼執(zhí)行的時候再需要更多的內(nèi)存,就會報錯了,于是就將php.ini文件中的配置改了一下:
memory_limit = 128M;//將128M改成了256M
但是之后一想,一個php腳本一次請求的內(nèi)存空間就要超過128M,那不管你以后將memory_limit設(shè)置成多大,以后肯定有出問題的時候。
究其原因,是我在在編碼時,僅僅對變量賦值,卻從來沒有 unset ($var) 過。導(dǎo)致了內(nèi)存占用越來越多,所以以后一個變量不再使用之后,一定要記得unset掉它。
下面附上我今天處理這個日志文件的代碼:
<?php
set_time_limit(1800) ;
/**
* 獲取日志中發(fā)送失敗的郵箱地址
* @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文件中發(fā)送失敗郵箱提取出來
foreach($logs as $v){
$row=file("$v");
echo "讀取".$v."文件<br />";
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 "獲取發(fā)送失敗的郵箱地址".$matches[0]."<br />";
}else{
echo "無法獲取日志中發(fā)送失敗的郵箱,請檢查";
}
}
}
unset($row);
}
//將提取出來的發(fā)送失敗郵箱寫入到mail.txt文件中
$mailurl=fopen("$name","a");
foreach($mail as $line)
{
fwrite($mailurl,$line."\r\n");
}
echo "將所有發(fā)送失敗的郵箱地址寫入".$name."<br />";
fclose($mailurl);
}
getmail(".","mail.txt");
?>
- 解決fatal:remote error:You can''t push to git://github.com/username/*.git問題的辦法
- 解決PHP程序運(yùn)行時:Fatal error: Maximum execution time of 30 seconds exceeded in的錯誤提示
- PHP中使用register_shutdown_function函數(shù)截獲fatal error示例
- ThinkPHP提示錯誤Fatal error: Allowed memory size的解決方法
- php運(yùn)行提示:Fatal error Allowed memory size內(nèi)存不足的解決方法
- php使用ZipArchive提示Fatal error: Class ZipArchive not found in的解決方法
- Windows平臺的 PHP 報錯 Fatal error: Class COM not found in 的解決方法
- PHP中Fatal error session_start()錯誤解決步驟
- PHP捕獲Fatal error錯誤的方法
- Fatal: the Postfix mail system is already running 解決辦法
相關(guān)文章
PHP內(nèi)核介紹及擴(kuò)展開發(fā)指南—基礎(chǔ)知識
本章簡要介紹一些Zend引擎的內(nèi)部機(jī)制,這些知識和Extensions密切相關(guān),同時也可以幫助我們寫出更加高效的PHP代碼。2011-09-09
php setcookie(name, value, expires, path, domain, secure) 參數(shù)
本篇文章是對php setcookie(name, value, expires, path, domain, secure) 參數(shù)進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-06-06
原生JS實(shí)現(xiàn)Ajax通過GET方式與PHP進(jìn)行交互操作示例
這篇文章主要介紹了原生JS實(shí)現(xiàn)Ajax通過GET方式與PHP進(jìn)行交互操作,涉及javascript ajax交互及php數(shù)據(jù)接收、處理與數(shù)據(jù)庫查詢相關(guān)操作技巧,需要的朋友可以參考下2018-05-05
PHP+MySQL統(tǒng)計該庫中每個表的記錄數(shù)并按遞減順序排列的方法
這篇文章主要介紹了PHP+MySQL統(tǒng)計該庫中每個表的記錄數(shù)并按遞減順序排列的方法,涉及PHP基于PDO操作MySQL數(shù)據(jù)庫的相關(guān)技巧,具有一定參考借鑒價值,需要的朋友可以參考下2016-02-02

