您好,登錄后才能下訂單哦!
PHP內存溢出該如何解決?針對這個問題,這篇文章詳細介紹了相對應的分析和解答,希望可以幫助更多想解決這個問題的小伙伴找到更簡單易行的方法。
內存溢出的原因:
內存溢出是指應用系統中存在無法回收的內存或使用的內存過多,最終使得程序運行要用到的內存大于虛擬機能提供的最大內存。
1.內存中加載的數據量過于龐大,如一次從數據庫取出過多數據;
2.集合類中有對對象的引用,使用完后未清空,使得JVM不能回收;
3.代碼中存在死循環或循環產生過多重復的對象實體;
4.使用的第三方軟件中的BUG;
5.啟動參數內存值設定的過小;
內存溢出解決方案
在做數據統計分析時,經常會遇到大數組,可能會發生內存溢出,這里分享一下我的解決方案。還是用例子來說明這個問題,如下:
假定日志中存放的記錄數為500000條,那么解決方案如下:
ini_set(‘memory_limit’,’64M’);
//重置php可以使用的內存大小為64M,一般在遠程主機上是不能修改php.ini文件的,只能通過程序設置。
注:在safe_mode
(安全模式)下,ini_set
失效。
set_time_limit(600);//設置超時限制為6分鐘 $farr = $Uarr = $Marr = $IParr = $data = $_sub = array(); $spt = ”$@#!$”; $root = ”/Data/webapps/VisitLog”; $path = $dpath = $fpath = NULL; $path = $root.”/”.date(“Y-m”,$timestamp); $dpath = $path.”/”.date(“m-d”,$timestamp); for($j=0;$j<24;$j++){ $v = ($j < 10) ? ”0″.$j : $j; $gpath = $dpath.”/”.$v.”.php”; if(!file_exists($gpath)){ continue; } else { $arr = file($gpath);////將文件讀入數組中 array_shift($arr);//移出第一個單元-》<?php exit;?> $farr = array_merge($farr,$arr); unset($arr); } } if(empty($this->farr)){ echo ”<p><center>沒有相關記錄!</center></p>”; exit; } while(!empty($farr)){ $_sub = array_splice($farr, 0, 10000); //每次取出$farr中1000個 for($i=0,$scount=count($_sub);$i<$scount;$i++){ $arr = explode($spt,$_sub[$i]); $Uarr[] = $arr[1]; //vurl $Marr[] = $arr[2]; //vmark $IParr[] = $arr[3].” |$nbsp;”.$arr[1]; //IP } unset($_sub);//用完及時銷毀 } unset($farr);
這里,不難看出:
1、一方面,我們要增加PHP可用內存大小,另一方面,只要我們想辦法對數組進行分批處理,分而治之,將用過的變量及時銷毀(unset
),一般是不會出現溢出問題的。
2、另外,為了節省PHP程序內存損耗,我們應當盡可能減少靜態變量的使用,在需要數據重用時,可以考慮使用引用(&)。
3、再一點就是:數據庫操作完成后,要馬上關閉連接;一個對象使用完,要及時調用析構函數(__destruct()
)。
unset銷毀變量并釋放內存問題
PHP的unset()
函數用來清除、銷毀變量,不用的變量,我們可以用unset()
將它銷毀。但是某些時候,用unset()卻無法達到銷毀變 量占用的內存!我們先看一個例子:
<?php $s=str_repeat('1',255); //產生由255個1組成的字符串 $m=memory_get_usage(); //獲取當前占用內存 unset($s); $mm=memory_get_usage(); //unset()后再查看當前占用內存 echo $m-$mm; ?>
最后輸出unset()
之前占用內存減去unset()
之后占用內存,如果是正數,那么說明unset($s)
已經將$s從內存中銷毀(或者說,unset()之后內存占用減少了),可是我在PHP5和windows平臺下,得到的結果是:0。這是否可以說明,unset($s)
并沒有起 到銷毀變量$s所占用內存的作用呢?我們再作下面的例子:
<?php $s=str_repeat('1',256); //產生由256個1組成的字符串 $m=memory_get_usage(); //獲取當前占用內存 unset($s); $mm=memory_get_usage(); //unset()后再查看當前占用內存 echo $m-$mm; ?>
這個例子,和上面的例子幾乎相同,唯一的不同是,$s
由256個1組成,即比第一個例子多了一個1,得到結果是:272。這是否可以說 明,unset($s)
已經將$s
所占用的內存銷毀了?
通過上面例子,我們可以得出以下結論:
結論一、unset()
函數只能在變量值占用內存空間超過256字節時才會釋放內存空間。
結論二、只有當指向該變量的所有變量(如引用變量)都被銷毀后,才會釋放內存。
關于PHP內存溢出該如何解決問題的解答就分享到這里了,希望以上內容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關注億速云行業資訊頻道了解更多相關知識。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。