故障現象
在運行PHP程式,通常會遇到“Fatal Error: Allowed memory size of xxxxxx bytes exhausted”的錯誤, 這個意味著PHP指令碼使用了過多的記憶體,並超出了系統對其設定的允許最大記憶體。
解決這個問題,首先需要查看你的程式是否分配了過多的記憶體,在程式沒有問題的情況下,你可以通過一下方法來增加PHP的記憶體限制(memory_limit)。
檢查php的記憶體限制值
為了查看這個值,你需要建立一個空的php檔案,比如view-php-info.php。然後將一下代碼貼到裡面。
將這個指令碼放到你的Web伺服器上,然後在瀏覽器中調用它。這時你可以看到你的PHP環境配置的資訊,其中有一部分是關於“memory_limit”的, 如:
註:你可以用這種方法來查看php的其他參數設定,不僅僅是memory_limit
memory_limit應該設為多少?
這個完全依賴於你的應用的要求。比如Wordpress,運行起核心代碼需要32MB。Drupal 6則要求這個值最小為16MB,並推薦設定為32MB。如果你又安裝不少的外掛程式(plugins),尤其是那些要進行影像處理的模組,那麼你可能需要128MB或更高的記憶體。
如何設定memory_limit
方法1: php.ini
最簡單或常用的方法是修改php.ini
1.首先找到對你的網站生效的php.ini檔案 由於有多個地方都可以設定php的參數,找到正確的設定檔,並變更是首先要做的一步。如果你上面的方法建立了php檔案來查看其配置參數,則你可以找到“Loaded Configuration File”這一項,以下是個例子:
對於Linux使用者,你可以通過執行“php -i | grep Loaded Configuration File”來找到對應的設定檔。而Windows使用者,你可以嘗試修改你的php安裝目錄下的php.ini。
2.編輯php.ini 在php.ini中,找到“memory_limit”這一項,如果沒有,你可以在檔案的尾部自己增加這個參數。以下是一些設定範例
memory_limit = 128M ; 可以將128M改為任何你想設定的值
儲存檔案
3.重啟網頁伺服器 如果是web伺服器使用Apache, 則執行:
httpd restart
有些情況下,你可能不被允許私修改php.ini。比如如果你購買了虛擬機器主機服務,但是你的服務商確禁止你修改這個檔案。那麼,你可以需要考慮用其他方法來增加memory_limit的值。
方法2: .htaccess
說明: 這種方法只有在php以Apache模組來執行時才生效。 在你的網站的根目錄下找到“.htaccess”檔案,如果沒有,可以自己建立一個。然後把以下配置放入其中
php_value memory_limit 128M ; 可以將128M改為任何你想設定的值
方法3: 運行時修改php的記憶體設定
在你的php代碼中增加以下命令列即可。
ini_set('memory_limit','128M');
memory_limit修改失敗
如果你使用虛擬機器主機,有可能會出現memory_limit的值修改失敗。這個需要聯絡你的服務商看怎麼處理,通常他們限制了可以設定的最大值或者根本就不允許你修改。如果他們的環境真的無法滿足你的要求,那麼你可能要考慮換一個主機服務商。
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
生產環境下故障處理一例
現象說明:
生產環境下,storage伺服器上 沒有安裝任何服務(如apache,nginx,IIS等) 現在是純命令列執行PHP 跑PHP指令碼,在指令碼的執行過程中發現(指令碼內容含每次取5000個檔案然後執行其它操作)速度奇慢,在本地測試時分分鐘內搞定的事,線上上要執行2個多小時,經過排查排除掉伺服器負載問題、資料庫問題、伺服器網路問題後,認為可能是php.ini設定檔中的資源限制所引起,於是修改了一下memory_limit將預設值128M修改為1024M後再次執行原指令碼,速度得到大幅度提升,現把此參數的含義說明一下。
修改後需不需要重啟?
因為PHP沒有守護進程一說,理論上你只要修改過以後,就會立即使用新的設定檔。
此值設定多大為好?
建議根據應用需求來設定。物理伺服器,如果記憶體夠大的話建議限制記憶體較大一些如512M,1024M都可,如果是VPS之類的可能限制在128(預設)64M或者以下是比較合適的,特別是有web伺服器的時候,一旦開啟多個php的fast-cgi,估計伺服器都卡的不動了。
參數文法
memory_limit integer
本指令設定了一個指令碼所能夠申請到的最大記憶體位元組數。
指令作用
這有助於防止寫得不好的指令碼消耗光伺服器上的可用記憶體。
在phpchina的論壇上,有人這樣說:
memory_limit是設定PHP使用記憶體時空間,一般設定為記憶體的四分之一,應該就差不多了。如512M記憶體設定128M,1G記憶體設定256M。
設定太大會影響系統速度,因為系統和資料庫及其他程式同樣需要記憶體空間,一般系統和資料庫記憶體空間是自己分配的。
附三種修改方法
可能是分詞程式的問題。只要搜尋的欄位達到十個漢字以上,就會出現諸如以下的錯誤
Fatal error: Allowed memory size of 2345643 bytes exhausted
上網找了方法。有3種辦法。
1.直接修改PHP.INI
memory_limit = 16M ;
但是我修改了沒有用。據說是要重啟伺服器的。但是很顯然。我的 是虛擬機器主機。所以有外掛式主控件的可以這樣修改。
2.修改.htaccess
php_value memory_limit 16M
修改後直接出現500錯誤。可能是主機商限制
3.直接在程式頁面上修改。
ini_set(’memory_limit’, ‘16M‘);