擷取php頁面執行時間,資料庫讀寫次數,函數調用次數等(THINKphp)_PHP教程

來源:互聯網
上載者:User
THINKphp裡面有調試運行狀態的效果:

Process:0.2463s (Load:0.0003s Init:0.0010s Exec:0.1095s Template:0.1355s )|DB:13 queries 0 writes| Cache:2 gets,0 writes|UseMem:415 kb|LoadFile:20|CallFun:63,1370

代表的含義:

運行資訊: 整體執行時間0.2463s ( 載入:0.0003s 初始化:0.0010s 執行:0.1095s 模板:0.1355s ) | 資料庫 :13次讀操作 0次寫操作 | 緩衝:2次讀取,0次寫入 | 使用記憶體:415 kb | 負載檔案:20 | 函數調用:63(自訂),1370(內建)

下面來分析一下這些資料是怎麼擷取到的?

PHP擷取頁面執行時間:
複製代碼 代碼如下:
/**
* 得到目前時間
*/
function getMicrotime() {

list ($usec, $sec) = explode(" ", microtime());
return ((float) $usec + (float) $sec);
}


使用:上面的方法可以擷取目前時間,計算頁面執行時間可以在程式開頭和結尾出分別執行該方法,最後時間差就是頁面執行的時間,原理很簡單。

擷取資料庫讀寫次數

在資料庫插入和讀取的時候設定一個全域變數,每次執行成功一次$i++一次, ,這是tp裡面db類的方法,而N的方法是:自動累計的一個方法。

同理緩衝也是這樣計算出來的

記憶體的開銷
memory_get_usage可以擷取當前記憶體的消耗量,可以在程式開始和結尾分別調用,差值就是記憶體的開銷

負載檔案的數量
get_included_files:Gets the names of all files that have been included using include, include_once, require or require_once.

也就是可以擷取到所有的include,require的檔案數,返回引入檔案的數組:

官網例子":

複製代碼 代碼如下:
// This file is abc.php

include 'test1.php';
include_once 'test2.php';
require 'test3.php';
require_once 'test4.php';

$included_files = get_included_files();

foreach ($included_files as $filename) {
echo "$filenamen";
}
?>


返回的結果是:

abc.php
test1.php
test2.php
test3.php
test4.php

函數調用方法
第一個看這個,感覺是在每個方法裡面調用時自動+1.但是感覺不大可能,貌似這個每個方法裡寫不靠譜,這群裡討論半天,最後發現php的一個函數:

get_defined_functions返回引入PHP檔案的所有方法的array格式,包括自訂的,內建的。

引入官網的一個例子:

複製代碼 代碼如下:
function myrow($id, $data)
{
return "$id$datan";
}
$arr = get_defined_functions();
print_r($arr);
?>


結果是:

複製代碼 代碼如下:
Array
(
[internal] => Array
(
[0] => zend_version
[1] => func_num_args
[2] => func_get_arg
[3] => func_get_args
[4] => strlen
[5] => strcmp
[6] => strncmp
...
[750] => bcscale
[751] => bccomp
)

[user] => Array
(
[0] => myrow
)
)


user為自訂方法,internal為內建方法數組。

引申:

get_defined_constants 擷取定義所有常量的數組
get_defined_functions 擷取定義所有函數的數組
get_defined_vars 擷取定義所有變數的數組
get_declared_classes 返回已經定義的類的數組

http://www.bkjia.com/PHPjc/327374.htmlwww.bkjia.comtruehttp://www.bkjia.com/PHPjc/327374.htmlTechArticleTHINKphp裡面有調試運行狀態的效果: Process:0.2463s (Load:0.0003s Init:0.0010s Exec:0.1095s Template:0.1355s )|DB:13 queries 0 writes| Cache:2 gets,0 writes|UseMem:415 k...

  • 聯繫我們

    該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

    如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

    A Free Trial That Lets You Build Big!

    Start building with 50+ products and up to 12 months usage for Elastic Compute Service

    • Sales Support

      1 on 1 presale consultation

    • After-Sales Support

      24/7 Technical Support 6 Free Tickets per Quarter Faster Response

    • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.