婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 關于Yii2框架跑腳本時內存泄漏問題的分析與解決

關于Yii2框架跑腳本時內存泄漏問題的分析與解決

熱門標簽:杭州語音電銷機器人 江門回撥外呼系統 高德地圖標注位置怎么標注 電銷機器人沒有效果怎么樣 天潤融通外呼系統好嗎 泊頭在哪里辦理400電話 江西電銷機器人收費 欣思維地圖標注 高德地圖標注店鋪收費嗎

現象

在跑 edu_ocr_img 表的歸檔時,每跑幾萬個數據,都會報一次內存耗盡

PHP Fatal error:  Allowed memory size of 134217728 bytesexhausted (tried toallocate 135168 bytes)

跟蹤代碼發現,是在插入時以下代碼造成的:

EduOCRTaskBackup::getDb()->createCommand()->batchInsert(EduOCRTaskBackup::tableName(), $fields, $data)->execute();

execute 之后會造成使用內存漲上去,并且在之后 unset 所有變量內存也會有一部分不會刪除,直到內存耗盡。

于是跟蹤到 Yii2中execute的具體代碼塊發現在記錄 log 的時候會將使用很高的內存,分析代碼之后得出造成泄漏的代碼塊如下:

造成泄漏的代碼塊

/**
 * Logs a message with the given type and category.
 * If [[traceLevel]] is greater than 0, additional call stack information about
 * the application code will be logged as well.
 * @param string|array $message the message to be logged. This can be a simple string or a more
 * complex data structure that will be handled by a [[Target|log target]].
 * @param integer $level the level of the message. This must be one of the following:
 * `Logger::LEVEL_ERROR`, `Logger::LEVEL_WARNING`, `Logger::LEVEL_INFO`, `Logger::LEVEL_TRACE`,
 * `Logger::LEVEL_PROFILE_BEGIN`, `Logger::LEVEL_PROFILE_END`.
 * @param string $category the category of the message.
 */
public function log($message, $level, $category = 'application')
{
 $time = microtime(true);
 $traces = [];
 if ($this->traceLevel > 0) {
  $count = 0;
  $ts = debug_backtrace(DEBUG_BACKTRACE_IGNORE_ARGS);
  array_pop($ts); // remove the last trace since it would be the entry script, not very useful
  foreach ($ts as $trace) {
   if (isset($trace['file'], $trace['line'])  strpos($trace['file'], YII2_PATH) !== 0) {
    unset($trace['object'], $trace['args']);
    $traces[] = $trace;
    if (++$count >= $this->traceLevel) {
     break;
    }
   }
  }
 }
 
 // 這里是造成內存的罪魁禍首
 $this->messages[] = [$message, $level, $category, $time, $traces];
 if ($this->flushInterval > 0  count($this->messages) >= $this->flushInterval) {
  $this->flush();
 }
}

造成內存泄漏的原因分析

在 Yii2框架中的 vendor/yiisoft/yii2/log/Logger.php:156 log函數的156行之后會判斷 count($this->messages) >= $this->flushInterval

即:內存中存儲的 message 的條數要大于等于預設的 $this->flushInterval 才會將內存中的message 刷到磁盤上去。

如果在刷新到磁盤之前就已經將 php.ini 設置的 128M 內存打滿的話,會直接報錯申請內存耗盡。

很多關于 YII2其他原因的內存泄漏的討論
https://github.com/yiisoft/yii2/issues/13256

解決方案

在程序開始時,設置 flushInterval 為一個比較小的值

\Yii::getLogger()->flushInterval = 100; // 設置成一個較小的值

在程序執行過程中,每次 execute 之后對內存中的 message 進行 flush

\Yii::getLogger()->flush(true); // 參數傳 true 表示每次都會將 message 清理到磁盤中

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對腳本之家的支持。

您可能感興趣的文章:
  • 從零開始學YII2框架(一)通過Composer安裝Yii2框架
  • 從零開始學YII2框架(五)快速生成代碼工具 Gii 的使用
  • 從零開始學YII2框架(六)高級應用程序模板
  • 從零開始學YII2框架(三)擴展插件yii2-gird
  • 從零開始學YII2框架(二)通過 Composer 安裝擴展插件
  • 從零開始學YII2框架(四)擴展插件yii2-kartikgii
  • Yii2框架數據庫簡單的增刪改查語法小結
  • Yii2框架使用計劃任務的方法

標簽:大同 深圳 雙鴨山 平涼 江門 駐馬店 石嘴山 內江

巨人網絡通訊聲明:本文標題《關于Yii2框架跑腳本時內存泄漏問題的分析與解決》,本文關鍵詞  關于,Yii2,框架,跑,腳本,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《關于Yii2框架跑腳本時內存泄漏問題的分析與解決》相關的同類信息!
  • 本頁收集關于關于Yii2框架跑腳本時內存泄漏問題的分析與解決的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    91年精品国产| 亚洲色图都市小说| 麻豆精品视频在线观看免费| 色天使久久综合网天天| 亚洲国产精品传媒在线观看| 捆绑变态av一区二区三区| 欧美日韩dvd在线观看| 亚洲成av人片| 日韩视频不卡中文| 久久黄色级2电影| 久久影院电视剧免费观看| 在线一区二区观看| 亚洲一区二区三区三| 在线播放/欧美激情| 久久国产夜色精品鲁鲁99| 久久久精品免费观看| 粉嫩av一区二区三区| 亚洲日本在线天堂| 51精品秘密在线观看| 久草在线在线精品观看| 欧美精品一区二区三区高清aⅴ| 亚洲丶国产丶欧美一区二区三区| 精品视频一区二区三区免费| 亚洲va天堂va国产va久| 日韩欧美123| 成人av免费在线| 午夜天堂影视香蕉久久| 久久精品人人做人人爽人人| 91麻豆精品在线观看| 美女视频一区二区三区| 国产精品久久久久久久午夜片| 欧美性生活影院| 国产高清不卡二三区| 亚洲综合成人在线视频| 久久影院午夜论| 色噜噜夜夜夜综合网| 午夜精品久久久久久久 | 日韩精品色哟哟| 欧美国产国产综合| 日韩一区二区三区观看| 99riav久久精品riav| 韩国欧美国产一区| 日韩成人午夜电影| 亚洲精品欧美专区| 久久久久成人黄色影片| 亚洲va天堂va国产va久| 中文字幕中文字幕一区二区| 欧美色图在线观看| 不卡视频一二三四| 国产精品一卡二| 国产又粗又猛又爽又黄91精品| 亚洲图片欧美色图| 中文字幕一区在线观看视频| 精品久久国产老人久久综合| 91首页免费视频| 99久久精品免费| 91亚洲精品一区二区乱码| 成人午夜短视频| 日韩av一区二| 日韩高清不卡一区二区| 亚洲高清久久久| 国产精品久久久久影院色老大| 国产日产欧美一区二区三区 | 亚洲一区二区在线播放相泽| 亚洲视频 欧洲视频| 中文字幕一区在线| 中文字幕在线观看不卡| 亚洲伦理在线精品| 亚洲国产视频网站| 麻豆极品一区二区三区| 老司机免费视频一区二区| 欧美aⅴ一区二区三区视频| 麻豆一区二区99久久久久| 亚洲最色的网站| 天堂成人国产精品一区| 蜜桃久久久久久久| 日韩精品久久久久久| 国产在线看一区| 国产精品麻豆视频| 成人免费在线观看入口| 亚洲国产一二三| 蜜臀91精品一区二区三区 | 欧美精品自拍偷拍动漫精品| 91精品久久久久久久91蜜桃| 91久久国产综合久久| 这里只有精品免费| 欧美国产日本韩| 亚洲人成精品久久久久| 青青青爽久久午夜综合久久午夜| 大陆成人av片| 99久久伊人精品| 91精品黄色片免费大全| 在线观看一区二区精品视频| 国产视频不卡一区| 国产精品亚洲а∨天堂免在线| 欧美日韩大陆在线| 99国产精品一区| 2024国产精品| 国产毛片精品视频| 欧美高清性hdvideosex| 亚洲在线视频一区| 色偷偷88欧美精品久久久| 久久久天堂av| 国产一区二区三区香蕉| 国产亚洲婷婷免费| 国产99久久久国产精品免费看| 国产视频一区二区三区在线观看| 老司机精品视频导航| 日韩视频免费观看高清完整版在线观看| 亚洲人成在线观看一区二区| 国产大陆亚洲精品国产| 精品久久五月天| 精品一区二区三区日韩| 精品国产乱码久久| 蓝色福利精品导航| 日韩欧美国产午夜精品| 亚洲成人精品一区| 日韩精品最新网址| 国产精品一区二区久激情瑜伽| 51午夜精品国产| 日韩电影在线免费观看| 91精品国产色综合久久| 亚洲与欧洲av电影| 欧美精品久久久久久久久老牛影院| 亚洲午夜久久久久久久久久久| 777午夜精品免费视频| 日韩高清一区在线| 日韩精品在线一区二区| 久久国产视频网| 中文字幕二三区不卡| 91在线观看污| 亚洲一区二三区| 久久久国产午夜精品| 91看片淫黄大片一级在线观看| 国产精品久久久久影院| 日本高清不卡一区| 精品一区二区在线播放| 国产精品久久久久久久久动漫| 欧美三级在线播放| 国内精品视频一区二区三区八戒 | 国内精品国产成人国产三级粉色| 久久亚洲精华国产精华液 | 日韩高清在线电影| 久久精品一区八戒影视| 91丨porny丨最新| 欧美a一区二区| 国产三区在线成人av| 欧美日韩综合不卡| 成人综合在线视频| 日韩精品成人一区二区在线| 亚洲国产高清aⅴ视频| 欧美群妇大交群中文字幕| 久久99精品国产麻豆婷婷| 亚洲人成网站精品片在线观看| 欧美成人激情免费网| 91视频一区二区三区| 成人综合婷婷国产精品久久| 美女视频一区在线观看| 亚洲午夜在线电影| 国产91在线观看| 日本午夜精品一区二区三区电影| 国产日韩欧美精品综合| 精品乱人伦小说| 欧美美女一区二区三区| 欧日韩精品视频| 色94色欧美sute亚洲线路二| 91视频在线观看免费| 国产精品羞羞答答xxdd| 国产成人免费在线视频| 不卡一区二区中文字幕| 色哟哟一区二区三区| 91麻豆精品国产91久久久久久久久 | 亚洲视频精选在线| 精品影视av免费| 精品在线视频一区| 99免费精品在线| 欧美视频一区在线观看| 日韩一区二区电影网| 国产日韩视频一区二区三区| 国产精品久久久久9999吃药| 一个色妞综合视频在线观看| 日韩精品一级中文字幕精品视频免费观看 | 久久精品夜夜夜夜久久| 国产精品乱人伦| 亚洲国产成人av网| 国产精品白丝jk黑袜喷水| a亚洲天堂av| 这里是久久伊人| 中文字幕中文字幕在线一区| 婷婷成人激情在线网| 国产成人精品综合在线观看| 色猫猫国产区一区二在线视频| 宅男噜噜噜66一区二区66| 国产欧美一区二区三区鸳鸯浴 | 国产成人精品一区二区三区四区 | 蜜臀av一区二区在线免费观看| 亚洲一区二区中文在线| 国产美女主播视频一区| 欧美精选午夜久久久乱码6080| 亚洲天堂a在线|