> 我的最終目標是PHP中沒有任何一行是我所撰寫的程式,而開發者應該也以此為目標。
──PHP之父Rasmus Lerdorf
在Facebook推出HHVM后,引出許多重視PHP效能表現的使用者,讓PHP之父Rasmus Lerdorf意識到許多使用者有效能表現的需求,他開始思考如何將HHVM的JIT架構與PHP融合。
20歲老牌網頁程序語言PHP,最快將在10月底釋出PHP 7新版,這是十年來的首次大改版,最大特色是在性能上的大突破,能比前一版PHP 5快上一倍,PHP之父Rasmus Lerdorf表示,甚至能比HHVM虛擬機下的PHP程序性能更快。
HHVM是臉書為自家網站特性而量身客制的PHP優化機制,不見得適用任何網站。但RasmusLerdorf表示,新版目標之一就是要讓任何網站開發者,就連使用開發框架Drupal、開源電子商務系統Opencart時,都能有不輸使用HHVM 技術的性能。在新版發表前夕,他也趁來臺參加PHPConf Taiwan年會時,分享PHP 7性能大突破的關鍵。
一個20年來歷經了多次改版和無數次優化的成熟語言,還能有性能提高一倍的突破絕非易事,Rasmus Lerdorf坦言,不像一般新項目多半容易找出許多改進空間,新版PHP并非修改部分程序就達到了如此的成果。反而是,透過大量細節優化和性能累加后,PHP 7才具備了不輸HHVM的執行性能。
Rasmus Lerdorf與PHP核心貢獻團隊花了許多心力減少程序運作時搬動的內存位數,由此加速執行的性能。例如,PHP中儲存變量的數據架構zval從24位縮減至16位、Hashtable從72位減少至56位,并檢視PHP中的函式,思考有無任何改進性能的空間。
除了從減少內存的使用著手外,Rasmus Lerdorf更檢視CPU的Cache line的運作原理,了解程序代碼如何與CPU互動、編譯程序如何在新CPU架構下編譯程序代碼等細節,確保PHP7的程序代碼符合現代CPU的架構。雖然每個項目的優化對性能貢獻都低于0.5%,但由于優化的項目很多,或是某項改善的功能會被應用程序反復呼叫,整體修正的綜效結果就能有如此大的進展。
受HHVM刺激,決定打造兼具性能與功能的PHP。Facebook為了優化PHP運作,搭配 JIT編譯而打造出虛擬機HHVM。而HHVM雖然擁有快速的執行性能,其為特定用途優化的設計,只能滿足小部分的開發者。反之,Rasmus Lerdorf除了想提升PHP的性能表現外,也想要同時滿足高端使用者以及業余使用者的需求,讓PHP 7成為兼備性能表現及通用功能的程序語言。
然而,開發符合市場上少部分人使用的程序語言并不是難事,但是PHP項目瞄準許多對象,必須同時符合業余使用者及專業開發者需求的原則下,開發難以面面俱到,因為總是會有部分族群的需求無法被滿足,「這就像拿水管大范圍的噴灑,而每個人衣服都會被水沾濕一點,但是不會有人的衣服完全濕透。」Rasmus Lerdorf比喻。
不使用外掛框架的PHP的運算性能表現都很優異,但是受到外加框架的影響,原本可以在數秒內處理上千個網頁要求的 PHP,性能大幅下降,變為只能處理數十個要求。Rasmus Lerdorf表示,在HHVM出現之前,相較于對PHP性能表現的要求,使用者比較在意PHP能否降低網頁開發的難度,而這些框架能讓開發者的工作變得比較簡單。但是在Facebook推出HHVM后,引出許多重視PHP性能表現的使用者,讓Rasmus Lerdorf意識到許多使用者有性能表現的需求。他開始思考如何將HHVM的JIT架構與PHP融合。
但Rasmus Lerdorf表示,PHP與HHVM兩者在架構設計上相當不同,例如,HHVM的多線程架構并不是很穩固。此外,HHVM的可移植性并不佳,離可以在 Windows平臺上運作還有很大一段路,而PHP有很多開發者在Windows環境開發,而HHVM無法照顧到那些使用者。
Rasmus Lerdorf表示,他不能放棄PHP的主要架構,雖然他們曾經考慮過融合兩者,但是,HHVM在使用上有很多的限制。雖然HHVM對Facebook及許多開發者是非常好的工具,但對于PHP項目來說,HHVM的使用范疇還不夠寬廣,只能符合Facebook或是Wikipedia等特定項目的需求。
非 強型別語言的PHP,導入JIT是難上加難。然而,在PHP中加入JIT編譯是件非常困難的事情。Rasmus Lerdorf表示,JIT必須學會辨認程序的運作模(Patterns),例如了解哪些部份為重要的程序代碼,并且在程序運作前,預測程序被呼叫的時 機,或是哪些部分的程序會呼叫。
Rasmus Lerdorf比喻,在許多汽車中,JIT必須能預測哪部分的車子會右轉、哪部分的車子會左轉或是某些顏色汽車會直行,「而JIT必須要全部預測正確,否則性能會大大的降低。」但是,如果預測正確,程序執行性能則會大大提升。
在一般的程序語言的編譯中加入JIT已屬不易,Rasmus Lerdorf表示,由于PHP的動態屬性(dynamic)讓加入JIT是難上加難。他舉例,開發者宣告參數$a值為1,但不代表程序所有的$ a的值都為1,由于PHP中參數值可以很輕易地重新定義。在C語言中,當開發者宣告參數a為整數,則a永遠為整數。如果程序中有任何地方宣告a是整數以外 的類型,連編譯都無法執行。而因為C語言此種強型別的程序語言,「JIT可以預測變量a為整數,但是在PHP中,我們沒有這種奢侈。」他解釋,HHVM的 做法為當JIT得知a是整數型別后,則假設a永遠為整數。
而HHVM為了在使用JIT編譯,某種程度上受限了PHP的發展。HHVM的 用戶必須清楚宣告變量的性質,但是使用PHP的開發者,可以先宣告沒有性質的類別(Class),后續再指定類別的變量屬性。「在沒有任何限制下,將JIT加 入PHP是我們要做的事。」他表示,PHP必須顧及Wordpress、Drupal等框架的開發者,不能任意停止對此些框架的支持。故與HHVM相 比,PHP在打造JIT的條件限制更多。
但是,「這不代表我們不能做JIT。此外,我們也要控制PHP的發展走向。」Rasmus Lerdorf表示。
目前,PHP核心貢獻者之一的Dmitry Stogov開發一個原型JIT,并且使用某些實驗性的應用程序去測試運作。Rasmus Lerdorf表示,如果將此JIT用于執行某些重復性的運算或是循環程序,得以讓PHP 7性能又再快上10倍。
不過他也坦承,當此實驗性的JIT用于Wordpress時,并未得到任何加速效果,「我們想要打造的JIT不是要在大學課本上學到的東西,而是能在真實世 界中運作的JIT。」他表示。因為PHP一直都抱持如此的理想,試圖解決人們生活中的問題,并且能真實世界中在線環境中運作,而不只是存在課本中的理論。
Rasmus Lerdorf表示,在PHP剛問世時,他每天至少花16個小時開發PHP。但目前他已經逐漸減少投入開發,轉而投注心力在世界各地宣傳及演講。他打趣地 表示:「與其自己開發,不如激勵遠比我聰明,又愿意一天花十八小時寫程序的人去開發PHP。」他表示,他的最終目標是PHP中沒有任何一行由他所撰寫的程 序代碼,「任何在成長中的項目都不應該由一個開發者主導,老舊的程序代碼應該被新的程序代碼替換。」而他認為,其他開發者應該以此為目標。
來源:http://www.ithome.com.tw/news/99374
- PHP技術文章
- PHP中session和cookie的區別
- php設計模式(一):簡介及創建型模式
- php設計模式結構型模式
- Php設計模式(三):行為型模式
- 十款最出色的 PHP 安全開發庫中文詳細介紹
- 12個提問頻率最高的PHP面試題
- PHP 語言需要避免的 10 大誤區
- PHP 死鎖問題分析
- 致PHP路上的“年輕人”
- PHP網站常見安全漏洞,及相應防范措施總結
- 各開源框架使用與設計總結(一)
- 數據庫的本質、概念及其應用實踐(二)
- PHP導出MySQL數據到Excel文件(fputcsv)
- PHP中14種排序算法評測
- 深入理解PHP原理之--echo的實現
- PHP性能分析相關的函數
- PHP 性能分析10則
- 10 位頂級 PHP 大師的開發原則
- 30條爆笑的程序員梗 PHP是最好的語言
- PHP底層的運行機制與原理
- PHP 性能分析與實驗——性能的宏觀分析
- PHP7 性能翻倍關鍵大揭露
- 鳥哥:寫在PHP7發布之際一些話
- PHP與MySQL通訊那點事
- Php session內部執行流程的再次剖析
- 關于 PHP 中的 Class 的幾點個人看法
- PHP Socket 編程過程詳解
- PHP過往及現在及變革
- PHP吉祥物大象的由來
- PHP生成靜態頁面的方法
- 吊炸天的 PHP 7 ,你值得擁有!
- PHP開發中文件操作疑難問答
- MongoDB PHP Driver的連接處理解析
- PHP 雜談《重構-改善既有代碼的設計》之二 對象
- 在php中判斷一個請求是ajax請求還是普通請求的方法
- 使用HAProxy、PHP、Redis和MySQL支撐10億請求每周架構細節
- HTML、HTML5、XHTML、CSS、SQL、JavaScript、PHP、Web Services 是什么?
- 重構-改善既有代碼的設計
- PHP場景中getshell防御思路分享
- 移動互聯時代,你看看除了PHP你還會些什么
- 安卓系統上搭建本地php服務器環境
- PHP中常見的緩存技術!
- PHP里10個鮮為人知但卻非常有用的函數
- 成為一名PHP專家其實并不難
- PHP 命令行?是的,您可以!
- PHP開發提高效率技巧
- PHP八大安全函數解析
- PHP實現四種基本排序算法
- PHP開發中的中文編碼問題
- php.get.post
- php發送get、post請求的6種方法簡明總結
- 中高級PHP開發者應該掌握哪些技術?
- 前端開發
- web前端知識體系大全
- 前端工程與性能優化(下)
- 前端工程與性能優化(上)
- 2016 年技術發展方向
- Web應用檢查清單
- 如何成為一名優秀的web前端工程師
- 前端組件化開發實踐
- 移動端H5頁面高清多屏適配方案
- 2015前端框架何去何從
- 從前端看“百度遷徙”的技術實現(一)
- 從前端看“百度遷徙”的技術實現(二)
- 前端路上的旅行
- 大公司里怎樣開發和部署前端代碼?
- 5個經典的前端面試問題
- 前端工程師新手必讀
- 手機淘寶前端的圖片相關工作流程梳理
- 一個自動化的前端項目實現(附源碼)
- 前端代碼異常日志收集與監控
- 15年雙11手淘前端技術總結 - H5性能最佳實踐
- 深入理解javascript原型和閉包系列
- 一切都是對象
- 函數和對象的關系
- prototype原型
- 隱式原型
- instanceof
- 繼承
- 原型的靈活性
- 簡述【執行上下文】上
- 簡述【執行上下文】下
- this
- 執行上下文棧
- 簡介【作用域】
- 【作用域】和【上下文環境】
- 從【自由變量】到【作用域鏈】
- 閉包
- 完結
- 補充:上下文環境和作用域的關系
- Linux私房菜