解决内存溢出问题

1.经过php.ini进行设置php

  eg:ini_set('memory_limit,'128M');  //若是safe_mode开启的话是没有用的html

2.若是代码块中出现了大量的循环语句,使用事后的没有用的数据,应当及时unset掉数组

  eg:服务器

  foreach ($ask_lists as $k_1 => $list)
  {
    $ask_img_set = array();
    foreach ($student_info as $k_2 => $info)
    {
      if($list->student_id == $info->student_id)
      {
        $ask_lists[$k_1] -> student_name = $info->student_name;
        $ask_lists[$k_1] -> student_nickname = $info->student_nickname;
      }
      unset($student_info[$k_2]);
    }
   //将提问的图片放置数组
    if(strlen($list->ask_img_1)>0): array_push($ask_img_set,$list->ask_img_1);
    if(strlen($list->ask_img_2)>0): array_push($ask_img_set,$list->ask_img_2);
    unset($ask_lists[$k_1]->ask_img_1);
    unset($ask_lists[$k_1]->ask_img_2);
  }
session

3.大文件进行分片读写函数

  eg:性能

  public function testFilePutContent(Request $request)
  {
    header("content-type:text/html;charset=utf-8");
    $mp3_url = 'http://oflmvdj34.bkt.clouddn.com/20180325_9x2wesr2.mp3';
    $src_data = fopen("$mp3_url","r");
    $des_data = fopen("test.mp3","w");
    while($str = fread($src_data,4096)){
      fwrite($des_data,$str);
    }
    fclose($des_data);
    fclose($src_data);
    echo "写入完毕";
  }
url

 

3.__destruct
spa

__destruct() 析构函数,是在垃圾对象被回收时执行。 线程

4.Session 与PHP垃圾回收机制

因为PHP的工做机制,它并无一个daemon线程来按期的扫描Session信息并判断其是否失效,当一个有效的请求发生时,PHP 会根据全局变量 session.gc_probability和session.gc_divisor的值,来决定是否启用一个GC, 在默认状况下,session.gc_probability=1, session.gc_divisor =100也就是说有1%的可能性启动GC(也就是说100个请求中只有一个gc会伴随100个中的某个请求而启动).

PHP垃圾回收机制的工做就是扫描全部的Session信息,用当前时间减去session最后修改的时间,同session.gc_maxlifetime参数进行比较,若是生存时间超过gc_maxlifetime(默认24分钟),就将该session删除。 
可是,若是你Web服务器有多个站点,多个站点时,GC处理session可能会出现意想不到的结果,缘由就是:GC在工做时,并不会区分不一样站点的session.

那么这个时候怎么解决呢?

  1). 修改session.save_path,或使用session_save_path()让每一个站点的session保存到一个专用目录,    2). 提供GC的启动率,天然,PHP垃圾回收机制的启动率提升,系统的性能也会相应减低,不推荐。    3). 在代码中判断当前session的生存时间,利用session_destroy()删除.

相关文章
相关标签/搜索