Allowed memory size of 33554432 bytes exhausted (tried to allocate 16 bytes)
意味着你的程序跑步動了。。。。。。
如果你直接到網上去搜這句話,很快,就能找到解決的辦法——加大mem_limit~
我剛開始也是這麼幹的
後來我就擔心就算我加到1024M ,等我的數據庫更加龐大的時候,難道我要加內存條嗎?
就好象患了鼻炎,爲了快速解決問題而去吃西藥,還是從根本找問題,中藥調養,讓自己性能優化?
本文的兩個解決方法是前者。
如果想要尋求後者的解決方法,參看另一篇文章
PHP程序優化,讓PHP程序吃得內存最少
<?php
$file = '333.txt';
$lines = file_get_contents($file);
ini_set('memory_limit', '-1');//解決方法2
$line=explode("\n",$lines);//問題出在這裏
有時候用PHPMyAdmin執行import操作時,時間也會不夠用,可以設置max_execution_time
;;;;;;;;;;;;;;;;;;;
; Resource Limits ;
;;;;;;;;;;;;;;;;;;;
max_execution_time = 3000 ; Maximum execution time of each script, in seconds
max_input_time = 600 ; Maximum amount of time each script may spend parsing request data
memory_limit = 1024M ; Maximum amount of memory a script may consume (8MB)//解決方法1
方法1、memory_limit = 1024M
(在php.ini配置文件中,將此項的默認8M調整爲更大的數字,直到問題解決爲止,或者直接設置一個大的數字,比如512M、1024M)注意:php.ini文件修改後,一定要重啓apache服務器設置才能生效。
方法2、ini_set('memory_limit', '-1'); 即沒有最大內存限制
查看一些PHP變量
<?php
echo "max_execution_time =".ini_get("max_execution_time");
echo "</br>";
echo "memory_limit =".ini_get("memory_limit");
echo "</br>";
echo "post_max_size =".ini_get("post_max_size");
echo "</br>";
echo "upload_max_filesize =".ini_get("upload_max_filesize");
echo "</br>";
?>
輸出結果:
max_execution_time =3000
memory_limit =1024M
post_max_size =80M
upload_max_filesize =200M
注意: post_max_size,upload_max_filesize用下面的方法是修改不了的.
ini_set('post_max_size','1024M');ini_set('upload_max_filesize','1024M');
正確做法是用.htaccess文件:
php_value upload_max_filesize 50Mphp_value post_max_size 100M
前提是該站點在httpd.conf中配置了:
AllowOverride All
補充:
其實在php文檔裏有說明upload_max_filesize的可修改範圍是PHP_INI_PERDIR。
PHP_INI_PERDIR的意思是域 內指令可以在php.ini、httpd.conf或.htaccess文件中修改。
PHP_INI_SYSTEM 域內指令可以在php.ini和httpd.conf文件中修改所以upload_max_filesize用int_set是無法修改的。
只有可修改範 圍是PHP_INI_ALL的纔可以用int_set修改。