3、內(nèi)存使用信息
通過(guò)偵測(cè)腳本的內(nèi)存使用情況,有利于代碼的優(yōu)化。PHP 提供了一個(gè)垃圾收集器和一個(gè)非常復(fù)雜的內(nèi)存管理器。腳本執(zhí)行時(shí)所使用的內(nèi)存量,有升有跌。為了得到當(dāng)前的內(nèi)存使用情況,我們可以使用 memory_get_usage() 函數(shù)。如果需要獲得任意時(shí)間點(diǎn)的最高內(nèi)存使用量,則可以使用 memory_limit() 函數(shù)。
echo "Initial: ".memory_get_usage()." bytes \n"; /* prints Initial: 361400 bytes */
// let's use up some memory for ($i = 0; $i < 100000; $i++) { $array []= md5($i); }
// let's remove half of the array for ($i = 0; $i < 100000; $i++) { unset($array[$i]); }
echo "Final: ".memory_get_usage()." bytes \n"; /* prints Final: 885912 bytes */
echo "Peak: ".memory_get_peak_usage()." bytes \n"; /* prints Peak: 13687072 bytes */
4、CPU 使用信息
為此,我們要利用 getrusage() 函數(shù)。請(qǐng)記住這個(gè)函數(shù)不適用于 Windows 平臺(tái)。
print_r(getrusage()); /* prints Array ( [ru_oublock] => 0 [ru_inblock] => 0 [ru_msgsnd] => 2 [ru_msgrcv] => 3 [ru_maxrss] => 12692 [ru_ixrss] => 764 [ru_idrss] => 3864 [ru_minflt] => 94 [ru_majflt] => 0 [ru_nsignals] => 1 [ru_nvcsw] => 67 [ru_nivcsw] => 4 [ru_nswap] => 0 [ru_utime.tv_usec] => 0 [ru_utime.tv_sec] => 0 [ru_stime.tv_usec] => 6269 [ru_stime.tv_sec] => 0 )
*/這可能看起來(lái)有點(diǎn)神秘,除非你已經(jīng)有系統(tǒng)管理員權(quán)限。以下是每個(gè)值的具體說(shuō)明(你不需要記住這些):
ru_oublock: block output operations ru_inblock: block input operations ru_msgsnd: messages sent ru_msgrcv: messages received ru_maxrss: maximum resident set size ru_ixrss: integral shared memory size ru_idrss: integral unshared data size ru_minflt: page reclaims ru_majflt: page faults ru_nsignals: signals received ru_nvcsw: voluntary context switches ru_nivcsw: involuntary context switches ru_nswap: swaps ru_utime.tv_usec: user time used (microseconds) ru_utime.tv_sec: user time used (seconds) ru_stime.tv_usec: system time used (microseconds) ru_stime.tv_sec: system time used (seconds)
要知道腳本消耗多少 CPU 功率,我們需要看看 ‘user time’ 和 ’system time’ 兩個(gè)參數(shù)的值。秒和微秒部分默認(rèn)是單獨(dú)提供的。你可以除以 100 萬(wàn)微秒,并加上秒的參數(shù)值,得到一個(gè)十進(jìn)制的總秒數(shù)。讓我們來(lái)看一個(gè)例子:
// sleep for 3 seconds (non-busy) sleep(3);
$data = getrusage(); echo "User time: ". ($data['ru_utime.tv_sec'] + $data['ru_utime.tv_usec'] / 1000000); echo "System time: ". ($data['ru_stime.tv_sec'] + $data['ru_stime.tv_usec'] / 1000000);
/* prints User time: 0.011552 System time: 0 */
盡管腳本運(yùn)行用了大約 3 秒鐘,CPU 使用率卻非常非常低。因?yàn)樵谒哌\(yùn)行的過(guò)程中,該腳本實(shí)際上不消耗 CPU 資源。還有許多其他的任務(wù),可能需要一段時(shí)間,但不占用類似等待磁盤操作等 CPU 時(shí)間。因此正如你所看到的,CPU 使用率和運(yùn)行時(shí)間的實(shí)際長(zhǎng)度并不總是相同的。下面是一個(gè)例子:
// loop 10 million times (busy) for($i=0;$i<10000000;$i++) {
}
$data = getrusage(); echo "User time: ". ($data['ru_utime.tv_sec'] + $data['ru_utime.tv_usec'] / 1000000); echo "System time: ". ($data['ru_stime.tv_sec'] + $data['ru_stime.tv_usec'] / 1000000);
/* prints User time: 1.424592 System time: 0.004204 */
這花了大約 1.4 秒的 CPU 時(shí)間,但幾乎都是用戶時(shí)間,因?yàn)闆](méi)有系統(tǒng)調(diào)用。系統(tǒng)時(shí)間是指花費(fèi)在執(zhí)行程序的系統(tǒng)調(diào)用時(shí)的 CPU 開(kāi)銷。下面是一個(gè)例子:
$start = microtime(true); // keep calling microtime for about 3 seconds while(microtime(true) - $start < 3) {
}
$data = getrusage(); echo "User time: ". ($data['ru_utime.tv_sec'] + $data['ru_utime.tv_usec'] / 1000000); echo "System time: ". ($data['ru_stime.tv_sec'] + $data['ru_stime.tv_usec'] / 1000000);
/* prints User time: 1.088171 System time: 1.675315 */
現(xiàn)在我們有相當(dāng)多的系統(tǒng)時(shí)間占用。這是因?yàn)槟_本多次調(diào)用 microtime() 函數(shù),該函數(shù)需要向操作系統(tǒng)發(fā)出請(qǐng)求,以獲取所需時(shí)間。你也可能會(huì)注意到運(yùn)行時(shí)間加起來(lái)不到 3 秒。這是因?yàn)橛锌赡茉诜⻊?wù)器上同時(shí)存在其他進(jìn)程,并且腳本沒(méi)有 100% 使用 CPU 的整個(gè) 3 秒持續(xù)時(shí)間。
出處:藍(lán)色理想
責(zé)任編輯:bluehearts
上一頁(yè) 9個(gè)必須知道的實(shí)用PHP函數(shù)和功能 [1] 下一頁(yè) 9個(gè)必須知道的實(shí)用PHP函數(shù)和功能 [3]
◎進(jìn)入論壇網(wǎng)絡(luò)編程版塊參加討論
|