首頁 > 後端開發 > PHP問題 > 如何解決PHP記憶體溢位問題?

如何解決PHP記憶體溢位問題?

coldplay.xixi
發布: 2023-03-01 20:12:01
原創
5043 人瀏覽過

解決PHP記憶體溢出問題方法:1、要增加PHP可用記憶體大小;2、對陣列進行分批處理,將用過的變數及時銷毀;3、盡可能減少靜態變數的使用;4 、資料庫操作完成後,要馬上關閉連線。

如何解決PHP記憶體溢位問題?

解決PHP記憶體溢位問題方法:

一.記憶體溢出解決方案

在做資料統計分析時,經常會遇到大數組,可能會發生記憶體溢出,這裡分享我的解決方案。還是用範例來說明這個問題,如下:

假定日誌中存放的記錄數為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(&#39;1&#39;,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(&#39;1&#39;,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程式設計從入門到精通

#

以上是如何解決PHP記憶體溢位問題?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板