这个报错在php报错司空见惯,就是memory_limti值超出了限制导致的报错,简单粗暴不负责任就是改php.ini设置,或者稍微好点就是init_set("memory_limit","2048M"),但是这两种都是治标不治本,没有从根本上解决这个报错,如果数据20万通过改memory_limit可以稍微控制,但是50万,100万咧这样就是无限的扩大这个值导致服务器随时出现问题。
成都创新互联公司主要从事成都网站建设、网站建设、网页设计、企业做网站、公司建网站等业务。立足成都服务肥西,10年网站建设经验,价格优惠、服务专业,欢迎来电咨询建站服务:18982081108
redis能不能有效要看程序能否优化
确实需要占用大量内存的话 建议不常用的数据使用硬盘存储
使用mysql_unbuffered_query(), 可以避免内存的立即占用, 如果返回的结果存放到array中也是完全没有问题的, 也不会出现php查询mysql数据量过大时导致内存溢出问题.
这种情况一般会在单表数据表数据库比较大的时候出现,建议在使用的过程中限制单次读取数据条数,或者对数据表进行分表
后台脚本占用的内存是有个上限的,不是你想用多少就有多少的。
你把文件数据用追加的方式写入文件,而不是把所有数据拼接为字符串再一次性写入文件,就不会造成内存溢出了:
file_put_contents('文件路径', '要写入的数据', FILE_APPEND);
当查询类容过多时会导致php内存溢出,建议加limit分段查询,或着修改php.ini文件的
memory_limit 字段,默认是128M,改成你需要的大小
你看看你的程序里面有没有用到递归,或者有没有死循环。
另外解决此类问题的主要思想就是分而治之
我觉得是foreach的机制的问题
foreach($arr as $key=$value){}这里面的$value是每次循环是把数组中元素的值赋值给$value
而foreach($arr as $key=$value){}这里的$value是引用赋值。
两者有什么区别呢?带引用的$value可以$value='aaa';直接改变元素的值;还有一个重要的,就是最后一次循环之后$value的值还会保留;
你这里是foreach($obj as $value){}对象默认是引用传值;所以循环过后要unset($obj);
php里还有一个函数clearstatcache(true)清楚文件状态缓存,虽然受影响的函数没有simplexml_load_file(),不过还是可以试试;
还有mysql系列的函数很多也不是很稳定,有时候不知道会出什么问题;建议用PDO;
深感php里面的坑太多了,稍不注意就跳进去了。