[CodeIgniter] 記憶體的隱形殺手:Log all queries

更新於 發佈於 閱讀時間約 4 分鐘
此文章同步刊登於我的部落格

一、前言

在寫CI的時候是否曾經遇過out of memory的錯誤呢?

CodeIgniter作為輕量化的PHP框架

db物件一直是操作資料庫的好幫手

簡化了下達sql指令時的操作

加快了開發的速度

但其實看似好用的工具裡說不定有著隱藏的問題


二、正文

$this->db作為一個操作資料庫的物件

有兩個官方文檔中幾乎沒有提到的參數:

$this->db->queries 與 $this->db->query_times

這個功能其實是CodeIgniter提供給開發者查詢sql指令紀錄與執行時間的功能

可以看到每個sql語法花費的實際時間直接看Code:

$times = $this->db->query_times;
foreach ($this->db->queries as $key => $query)
{
$microsec = round($times[$key] * 1000, 4);
echo '[' . $microsec . ' microseconds] ' . $query . '<br>';
}

執行結果:

raw-image

從執行結果可以清楚的了解每個sql語法花費了多久的時間進行查詢

幫助開發人員進行效能優化

執行的所有語法都存在這個變數裡面,看似是很方便的功能


但是

這個功能在CodeIgniter裡是預設開啟的

所以當今天需要進行大量的sql查詢時這個功能就會默默地吃掉記憶體甚至導致out of memory錯誤


如果沒有特別需要的話

可以在資料庫設定加上 'save_queries' => FALSE

如下:

$db['default'] = array(
'dsn' => '',
'hostname' => '',
'username' => '',
'password' => '',
'database' => '',
'dbdriver' => 'mysqli',
'dbprefix' => '',
'pconnect' => FALSE,
'db_debug' => (ENVIRONMENT !== 'production'),
'cache_on' => FALSE,
'cachedir' => '',
'char_set' => 'utf8',
'dbcollat' => 'utf8_general_ci',
'swap_pre' => '',
'encrypt' => FALSE,
'compress' => FALSE,
'stricton' => FALSE,
'failover' => array(),
'save_queries' => FALSE,
'port' => 3306,
);

或是在執行大量查詢前先使用:

$this->db->save_queries = FALSE;PHP

來避免log紀錄吃掉大量記憶體導致記憶體溢出的狀況



三、結語

我們都知道使用框架非常方便


可以省去很多重複的動作

以CodeIgniter中的db物件來說

最大的幫助就是減少了每次都要防範SQL injection功夫

還有串接SQL語法的麻煩

但是框架最大的隱患就是使用它提供的「方便

但卻不知道框架到底在背後做了什麼事情


我們需要思考一個問題:

你在使用這些方便的工具生成SQL語法時

真的知道它實際上執行的SQL語句長什麼樣子嗎?

會不會程式效率很差的原因就出在框架?


這篇並不是鼓勵不要使用框架

而是想分享一個觀念:不要過度依賴任何工具

真的清楚自己做了甚麼事情才不會哪一天被自己給坑了


環境

  • CodeIgniter 3
avatar-img
7會員
21內容數
你可以在這裡看到後端工程師的技術文章 也可以看到一些投資相關的心得分享 歡迎交流~
留言
avatar-img
留言分享你的想法!
Hankz是名工程師 的其他內容
由於開發多個專案的時候,頻繁切換本地環境的PHP版本實在太麻煩,於是想要可以直接使用指令就完成切換的功能,於是有了這篇文章。
Simple Storage Service (S3) 是 AWS 最常應用到的服務,只要是需要將檔案上傳到雲端的狀況都可以使用S3,本篇文章將介紹如何設定與使用AWS S3。
在使用laravel中的Queue job的時候 如果希望job中斷還可以重新啟動這個時候就會需要用到Supervisor了 本篇文章為您帶來如何使用Supervisor執行Laravel的queue:work的教學
在PHP的團隊開發中,PHP CS Fixer可以確保每個開發人員的Coding Style相同,是相當重要的工具。本篇文章將會詳細說明PHP CS Fixer在Linux環境下的安裝方式。
Composer是PHP的軟體套件管理系統,它提供用於管理PHP軟體和依賴庫關係的標準格式。通常以專案為單位進行管理,會在專案根目錄底下(預設是vendor)安裝套件,除此外可以安裝全局套件。
本文將介紹在Windows環境中安裝SQL Server及相關PHP擴展,以進行與SQL Server的串接。透過本文所述步驟,您將能在Windows環境中順利進行PHP與SQL Server串接設定。
由於開發多個專案的時候,頻繁切換本地環境的PHP版本實在太麻煩,於是想要可以直接使用指令就完成切換的功能,於是有了這篇文章。
Simple Storage Service (S3) 是 AWS 最常應用到的服務,只要是需要將檔案上傳到雲端的狀況都可以使用S3,本篇文章將介紹如何設定與使用AWS S3。
在使用laravel中的Queue job的時候 如果希望job中斷還可以重新啟動這個時候就會需要用到Supervisor了 本篇文章為您帶來如何使用Supervisor執行Laravel的queue:work的教學
在PHP的團隊開發中,PHP CS Fixer可以確保每個開發人員的Coding Style相同,是相當重要的工具。本篇文章將會詳細說明PHP CS Fixer在Linux環境下的安裝方式。
Composer是PHP的軟體套件管理系統,它提供用於管理PHP軟體和依賴庫關係的標準格式。通常以專案為單位進行管理,會在專案根目錄底下(預設是vendor)安裝套件,除此外可以安裝全局套件。
本文將介紹在Windows環境中安裝SQL Server及相關PHP擴展,以進行與SQL Server的串接。透過本文所述步驟,您將能在Windows環境中順利進行PHP與SQL Server串接設定。
你可能也想看
Google News 追蹤
Thumbnail
全新 vocus 挑戰活動「方格人氣王」來啦~四大挑戰任你選,留言 / 愛心 / 瀏覽數大 PK,還有新手專屬挑戰!無論你是 vocus 上活躍創作者或剛加入的新手,都有機會被更多人看見,獲得站上版位曝光&豐富獎勵!🏆
去年最大看錯的產業應該就是 NAND Flash 的群聯和矽晶圓的環球晶。 目前群聯還有些套牢部位,仍對他 AI 推論端、企業級儲存有些期待;環球晶則從賺 27% 變成賠 28% 已全數停損,妥妥的天堂到地獄。 後續檢討,其實是我沒看清景氣循環的本質而凹單,並催眠自己是長期投資。
Thumbnail
假設我們當前所處的現實,是由一個高智慧的人工智能(AI)創造的虛擬世界,而生物性的人類則是它設計用來體驗七情六慾、獨特性與獨立性的載體。
Thumbnail
我跟老公工作長時間用電腦跟低頭族,常常覺得肩頸痠痛,除了定期去找師傅按摩外,我們也很愛買各種按摩產品在家幫自己按摩(神農試百草的概念🤣),希望能舒緩我們的症狀。 加上我是不容易入眠的體質,常常翻來翻去半小時以上才會睡著,所以只要看到有人推薦好入睡的方法我都會去嘗試看看,前陣子常被四花軟居4l
Thumbnail
這篇文章主要是介紹了SQL查詢效能調校的方法,針對索引最佳化做了整理和分享,並提供了一些注意事項和建議。
Thumbnail
介紹工作後幾個常見的小問題,包括寫 Log 的好習慣、本地印出錯誤或過程、PHPCS 工具、變數儲存於設定檔、避免魔術數字、程式碼靜態分析與動態分析。
Thumbnail
標示全部為已讀失效 最近發現留言系統中,"標示全部為已讀"的速度明顯變慢,甚至有時會失效。許多使用者都報告遇到了相同的問題。這實際上是程式設計中一個常見的漏洞。系統沒有充分考慮到整體容量問題與效能,才導致了這樣的情況。(實際原因待查,此處僅為一般解說),當系統開始顯示緩慢或出現其他問題時,通常
Thumbnail
在寫CI的時候是否曾經遇過out of memory的錯誤呢?CodeIgniter作為輕量化的PHP框架,db物件一直是操作資料庫的好幫手,簡化了下達sql指令時的操作,加快了開發的速度,但其實看似好用的工具裡說不定有著隱藏的問題。
Thumbnail
全新 vocus 挑戰活動「方格人氣王」來啦~四大挑戰任你選,留言 / 愛心 / 瀏覽數大 PK,還有新手專屬挑戰!無論你是 vocus 上活躍創作者或剛加入的新手,都有機會被更多人看見,獲得站上版位曝光&豐富獎勵!🏆
去年最大看錯的產業應該就是 NAND Flash 的群聯和矽晶圓的環球晶。 目前群聯還有些套牢部位,仍對他 AI 推論端、企業級儲存有些期待;環球晶則從賺 27% 變成賠 28% 已全數停損,妥妥的天堂到地獄。 後續檢討,其實是我沒看清景氣循環的本質而凹單,並催眠自己是長期投資。
Thumbnail
假設我們當前所處的現實,是由一個高智慧的人工智能(AI)創造的虛擬世界,而生物性的人類則是它設計用來體驗七情六慾、獨特性與獨立性的載體。
Thumbnail
我跟老公工作長時間用電腦跟低頭族,常常覺得肩頸痠痛,除了定期去找師傅按摩外,我們也很愛買各種按摩產品在家幫自己按摩(神農試百草的概念🤣),希望能舒緩我們的症狀。 加上我是不容易入眠的體質,常常翻來翻去半小時以上才會睡著,所以只要看到有人推薦好入睡的方法我都會去嘗試看看,前陣子常被四花軟居4l
Thumbnail
這篇文章主要是介紹了SQL查詢效能調校的方法,針對索引最佳化做了整理和分享,並提供了一些注意事項和建議。
Thumbnail
介紹工作後幾個常見的小問題,包括寫 Log 的好習慣、本地印出錯誤或過程、PHPCS 工具、變數儲存於設定檔、避免魔術數字、程式碼靜態分析與動態分析。
Thumbnail
標示全部為已讀失效 最近發現留言系統中,"標示全部為已讀"的速度明顯變慢,甚至有時會失效。許多使用者都報告遇到了相同的問題。這實際上是程式設計中一個常見的漏洞。系統沒有充分考慮到整體容量問題與效能,才導致了這樣的情況。(實際原因待查,此處僅為一般解說),當系統開始顯示緩慢或出現其他問題時,通常
Thumbnail
在寫CI的時候是否曾經遇過out of memory的錯誤呢?CodeIgniter作為輕量化的PHP框架,db物件一直是操作資料庫的好幫手,簡化了下達sql指令時的操作,加快了開發的速度,但其實看似好用的工具裡說不定有著隱藏的問題。