摘要:而是說,程序的外部資源,往往是影響性能的重要因素,尤其是當(dāng)外部資源的連接和數(shù)據(jù)獲取本身速度達(dá)不到理想的結(jié)果時(shí)。
暫且不討論「PHP 是不是最好的編程語(yǔ)言」,本文我們將分別分析一下在 PHP 程序的后端外圍資源和前端外圍資源,它們對(duì)整個(gè) PHP Web 應(yīng)用體驗(yàn)的影響,這往往比語(yǔ)言本身大得多。
首先,后端外圍資源,是指跟 PHP 運(yùn)行過程中與語(yǔ)言本身無關(guān)的網(wǎng)絡(luò)與 IO 操作、存儲(chǔ)服務(wù)、中間件代理、緩存和數(shù)據(jù)庫(kù)訪問等,在本文中,我們先分析 IO 操作和中間件服務(wù)。
為什么外圍資源的性能分析,要以以上三者分析為主?我們可以看如下國(guó)內(nèi)專業(yè)的性能監(jiān)控工具 OneAPM 的 PHP Web 應(yīng)用后臺(tái)截取下來的總覽圖,通過這個(gè)圖可以看到,數(shù)據(jù)庫(kù)所花費(fèi)的時(shí)間在總 PHP 響應(yīng)時(shí)間中,占據(jù)著 60% 甚至更大的比重,而 Memcached 緩存服務(wù),在這張圖里所占的響應(yīng)時(shí)間,幾乎看不見。
下面正式開始。
一、IO 操作PHP 語(yǔ)言本身盡管有性能的差異,但是從對(duì) PHP 的性能微觀分析也可以看出,如果只執(zhí)行單次操作,實(shí)際中這種差別是非常小的,前面的實(shí)驗(yàn)中,十萬次以上操作,才有百 ms 級(jí)的差別,因?yàn)?PHP 語(yǔ)言本身操作的是內(nèi)存,一次內(nèi)存訪問,大約在 50ns 左右。而 IO 操作,則是磁盤訪問,一次磁盤訪問所費(fèi)時(shí)間在 5ms 以上。僅從這個(gè)數(shù)量級(jí)看是 10 萬倍的差距,實(shí)際上,根據(jù)實(shí)驗(yàn),也有百倍級(jí)的差距(順序訪問和隨機(jī)訪問差距巨大,實(shí)際中兩者同時(shí)進(jìn)行,還會(huì)有磁盤緩存等)。
所以對(duì)比語(yǔ)言本身,IO 成為瓶頸的可能性更大。首先看一下,IO 操作帶來的性能差別。
一個(gè) PHP 腳本,通過 PHP 命令方式運(yùn)行,正常時(shí),消耗時(shí)間如下:
當(dāng)使用如下命令清空磁盤緩存后:
echo 3 | sudo tee /proc/sys/vm/drop_caches
得到的第一次運(yùn)行時(shí)間下如下圖所示:
代碼一模一樣,但是運(yùn)行時(shí)間卻是正常運(yùn)行時(shí)間的 6 倍。當(dāng)然這個(gè)時(shí)間的慢,并不僅僅是由于程序本身的 IO 操作導(dǎo)致,而更大的慢的因素是在 CGI 模式下,PHP 腳本的每一次運(yùn)行都需要加載所有模塊,這個(gè)加載,也伴隨著大量的 IO 操作。
再做一個(gè)實(shí)驗(yàn),完全同樣功能的兩個(gè)頁(yè)面,一個(gè)采用了 MVC 的方式,把頭部,尾部拆開成獨(dú)立的模板(并未使用模板引擎),中間邏輯也使用獨(dú)立的 Model 類來處理。另一個(gè)只 require 了宏定義和數(shù)據(jù)庫(kù)操作兩個(gè)文件。
使用命令ab -c 40 -n 1000 http://xxxxx/0929/zuche/carlist.php
進(jìn)行壓力測(cè)試, 這兩個(gè)頁(yè)面運(yùn)行穩(wěn)定后壓測(cè)結(jié)果數(shù)據(jù)如圖所示。
在這個(gè)頁(yè)面中,MVC 版本所費(fèi)時(shí)間要多 6-8ms 左右。雖然只是多增加了幾個(gè)文件包含,但是明顯增加了請(qǐng)求延時(shí),如果文件操作本身更加復(fù)雜,比如文件上傳、檢測(cè)、轉(zhuǎn)換,則延時(shí)會(huì)增加一個(gè)數(shù)量級(jí)以上。在實(shí)際的生產(chǎn)使用中,也不是說有了文件操作,就一定會(huì)產(chǎn)生大的延時(shí),因?yàn)榫拖癖纠?require 而言,由于磁盤緩存等的存在,延時(shí)的影響已降低很多。
二、中間件代理在正式使用中間件之前,我們先對(duì)比一下,使用數(shù)據(jù)庫(kù)與不使用數(shù)據(jù)庫(kù)的差別,同樣是上面的這個(gè)例子,我們把數(shù)據(jù)結(jié)果集,從數(shù)據(jù)庫(kù)獲取轉(zhuǎn)換成為直接的結(jié)果數(shù)組設(shè)置,為了結(jié)構(gòu)化清楚,采用 MVC 這一版。同時(shí)為了更顯著對(duì)比上一輪測(cè)試結(jié)果,同時(shí)也消除語(yǔ)言本身的一些慢的因素,在本輪實(shí)驗(yàn)中,我們采用 PHP7,得到結(jié)果是令人吃驚的。
如下圖是帶有數(shù)據(jù)庫(kù)連接和數(shù)據(jù)讀取的版本,PHP 擴(kuò)展使用的是 mysqli。
由于本頁(yè)面,只有一次數(shù)據(jù)庫(kù)操作,頁(yè)面結(jié)構(gòu)也比較簡(jiǎn)單,語(yǔ)言本身的影響因素非常大,PHP7 下速度有兩倍以上提升,原來平均響應(yīng)時(shí)長(zhǎng)為 37-40ms,現(xiàn)在則為 14ms。
即使如此,不讀取數(shù)據(jù)庫(kù)時(shí),有 4ms 的差距,盡管數(shù)目上不大,但是對(duì)于一個(gè)總響應(yīng)時(shí)長(zhǎng)只有 14ms 的應(yīng)用,這 4ms 已經(jīng)很顯著了,而這只是一個(gè)數(shù)據(jù)庫(kù)查詢操作。
接下來看一下,當(dāng)增加一層數(shù)據(jù)庫(kù)中間件時(shí),效率又有怎么樣的變化呢?由于筆者所使用的中間件,目前并不支持 PHP7,所以我們還在老版 PHP 的基礎(chǔ)上來比對(duì)。在同樣的服務(wù)器壓力下,使用了中間件的版本慢了一倍以上。如下圖所示。
從這個(gè)例子可以看出來,原本 PHP 直接連數(shù)據(jù)庫(kù),取得數(shù)據(jù)的操作,增加了中間件之后,變了先到中間件,中間件再到數(shù)據(jù)庫(kù),返回亦如是,導(dǎo)致了速度的大幅度下降(這里已經(jīng)剔除了中間件本身占用資源的因素,在原來直連的版本是 37-40ms 左右)。
這里也請(qǐng)讀者不要誤解,演示中間件使用速度下降的例子,并不是說為了說明中間件不好,在分布式環(huán)境下,使用中間件是非常必要的。而是說,程序的外部資源,往往是影響性能的重要因素,尤其是當(dāng)外部資源的連接和數(shù)據(jù)獲取本身速度達(dá)不到理想的結(jié)果時(shí)。
對(duì)于 IO 操作和中間件服務(wù)的分析就到這里,下篇將分析數(shù)據(jù)庫(kù)給整個(gè)應(yīng)用性能帶來的影響。
OneAPM for PHP 能夠深入到所有 PHP 應(yīng)用內(nèi)部完成應(yīng)用性能管理和監(jiān)控,包括代碼級(jí)別性能問題的可見性、性能瓶頸的快速識(shí)別與追溯、真實(shí)用戶體驗(yàn)監(jiān)控、服務(wù)器監(jiān)控和端到端的應(yīng)用性能管理。
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://m.specialneedsforspecialkids.com/yun/21143.html
摘要:本文作為針對(duì)外圍資源性的能分析,比較簡(jiǎn)單地設(shè)計(jì)了一些實(shí)驗(yàn)場(chǎng)景,看到了外部資源,包括中間件和數(shù)據(jù)庫(kù)資源給程序性能帶來的影響。有關(guān)影響程序性能的后端外圍資源就到這里,在下一篇中,我們將分析前端或者前后端結(jié)合給頁(yè)面延時(shí)帶來的影響。 暫且不討論「PHP 是不是最好的編程語(yǔ)言」,本文我們將分別分析一下在 PHP 程序的后端外圍資源和前端外圍資源,它們對(duì)整個(gè) PHP Web 應(yīng)用體驗(yàn)的影響,這往往...
摘要:的工作原理和生命周期是一門適用于開發(fā)的動(dòng)態(tài)語(yǔ)言,它可以說是一個(gè)用語(yǔ)言實(shí)現(xiàn)的包含大量組件的軟件框架。無論是哪種公眾模式,的工作原理都是一樣的,都是作為一種運(yùn)行。 PHP的工作原理和生命周期 php是一門適用于web開發(fā)的動(dòng)態(tài)語(yǔ)言,它可以說是一個(gè)用C語(yǔ)言實(shí)現(xiàn)的包含大量組件的軟件框架。那么,php是如何工作的呢?它的生命周期是怎么樣的呢? 表層分析 php是以請(qǐng)求/響應(yīng)為周期運(yùn)行服務(wù)端應(yīng)用...
摘要:和事務(wù)的關(guān)系關(guān)系型數(shù)據(jù)庫(kù)某些消息隊(duì)列等產(chǎn)品或中間件稱為事務(wù)性資源,因?yàn)樗鼈儽旧碇С质聞?wù),也能夠處理事務(wù)。事務(wù)的傳播特性,,,,,,強(qiáng)制要求要有一個(gè)物理事務(wù)。外圍事務(wù)不會(huì)被內(nèi)部事務(wù)的回滾狀態(tài)影響。不支持當(dāng)前事務(wù)。 Spring和事務(wù)的關(guān)系 關(guān)系型數(shù)據(jù)庫(kù)、某些消息隊(duì)列等產(chǎn)品或中間件稱為事務(wù)性資源,因?yàn)樗鼈儽旧碇С质聞?wù),也能夠處理事務(wù)。 Spring很顯然不是事務(wù)性資源,但是它可...
摘要:因此,我們需要性能優(yōu)異的引擎合適的車輪正確的跑道三架構(gòu)從下往上四層屬于操作系統(tǒng)的底層服務(wù)器,屬于次服務(wù)器,溝通和屬于服務(wù)端編程語(yǔ)言,通過模塊和關(guān)聯(lián)和其他服務(wù)屬于應(yīng)用服務(wù),通過的外掛模塊和關(guān)聯(lián)參考文檔底層工作原理 一、簡(jiǎn)介 PHP總共有三個(gè)模塊:內(nèi)核、Zend引擎、以及擴(kuò)展層 PHP內(nèi)核用來處理請(qǐng)求、文件流、錯(cuò)誤處理等相關(guān)操作 Zend引擎(ZE)用以將源文件轉(zhuǎn)換成機(jī)器語(yǔ)言,然后在虛擬...
摘要:在華為全聯(lián)接大會(huì)上,新一代關(guān)鍵業(yè)務(wù)云存儲(chǔ)的重大升級(jí),被推上前臺(tái)。華為存儲(chǔ)產(chǎn)品線總裁孟廣斌華為稱,該產(chǎn)品在云存儲(chǔ)領(lǐng)域首個(gè)具備支撐企業(yè)關(guān)鍵業(yè)務(wù)的能力。華為存儲(chǔ)產(chǎn)品線總裁孟廣斌說。對(duì)于分布式存儲(chǔ)這條企業(yè)級(jí)產(chǎn)品,華為早已篤定了一個(gè)方向,它應(yīng)該具備承載關(guān)鍵業(yè)務(wù)的一切能力并臻于極致、高可靠、易運(yùn)維、高性能,甚至低TCO和完善的生態(tài)兼容。10月10日,華為繼續(xù)用行動(dòng)來重申對(duì)這一方向的堅(jiān)持。在華為全聯(lián)接大會(huì)...
閱讀 1793·2023-04-26 01:44
閱讀 1219·2021-11-12 10:34
閱讀 1603·2021-09-09 09:33
閱讀 1738·2019-08-30 15:44
閱讀 2899·2019-08-30 13:49
閱讀 2196·2019-08-29 15:26
閱讀 951·2019-08-26 13:30
閱讀 1417·2019-08-23 18:15