天天看點

PHP能創造成功:舊代碼不一定是遺留代碼

全文共2401字,預計學習時長7分鐘
PHP能創造成功:舊代碼不一定是遺留代碼

圖源:Google

過去的一年裡,Vimeo開發人員用多種程式設計語言編寫了後端代碼——PHP、Go、Ruby、Python、NodeJS、Java、C語言、C++和Rust。

2004年,Vimeo開始使用PHP。對于像Vimeo這樣的初創公司來說,PHP無疑是一種理想程式設計語言。PHP的解釋器使企業家可以快速開發原型,它附帶一個大型标準庫,可以省去一些常見任務步驟,如發送電子郵件、通路資料庫等。

大多數初創公司都中道崩殂,但一些基于PHP的創業公司在十年後依然屹立不倒,有些甚至增長飛速、躍居前列。其中有的公司(最著名的當屬Facebook)認為PHP是阻礙公司發展的瓶頸,開始從PHP遷移出去。這種小規模遷移的主要原因有兩個:一是PHP的性能不佳,二是維護大型PHP代碼庫困難較大。

2014年開始,PHP的性能發展漸漸跟不上所需,數組記憶體的消耗超出必要。由于缺少可以大規模檢測錯誤的靜态分析工具,維護大型PHP代碼庫變得愈發困難。

自2004年以來的十年中,Vimeo的規模已經擴大了很多倍,PHP代碼庫也随之擴充,但是還沒有大到妨礙自身發展的程度。但當Facebook公開放棄PHP時,一些開發人員就認為PHP即将成為網際網路時代的FORTRAN。新一波後端工程師計劃如何将50萬行PHP分解成一系列設計更好、速度更快、可測試性更高的Go服務。

一時間,此事似乎迫在眉睫,但實際上我們從未放棄PHP。原因顯而易見——重寫整個代碼庫會占用大量資源并且容易出錯;但也有一個不太明顯的原因,那就是PHP變得更好了。

PHP能創造成功:舊代碼不一定是遺留代碼

在過去的六年裡,PHP執行時間減少了一半以上,社群發展迅速,現在有一種流行的驅動程式可以利用靜态分析獲得的見解來改進PHP代碼庫(舊的和新的)。

PHP的改進花了一段時間才在Vimeo應用。首先,我們必須棄用舊版本PHP5.4,該版本在過期多年後仍在生産。遷移到PHP 7可以使後端響應速度更快,除此以外,PHP 7改進後的文法使開發人員編寫代碼更簡潔,并對傳回和參數類型提供全面的語言級支援。

PHP一直在創新——不久前釋出的8版本在語言級别方面做了諸多改進,使開發人員可以更簡潔地表達業務邏輯。我們期待明年年初的更新。

PHP入門非常容易,但是“好上手”并不能保證無反噬。多年來,無數開發者嘗試過速成PHP,不小心就搬起石頭砸了腳,然後就放棄了。我也偶爾被PHP折磨的痛不欲生,但我沒有放棄,而是決定建構一個可以提高準頭的工具。就這樣,Psalm(PHP的靜态分析類型檢查器)誕生了。

Psalm的核心功能與TypeScript檢查器大緻相似,借鑒了Facebook Hack語言(源自PHP的)的一些想法。當PHP代碼在生産中導緻類型錯誤以及語言邏輯不通時,PHP會發送通知。Psalm增加了一些額外功能,如未使用的類和方法檢測,同時可以自動修複檢測到的許多問題。

過去幾年,我們将Psalm用作CI管道的一部分,這對我們在Vimeo編寫PHP的方式産生了變革性的影響:Psalm使我們有信心進行大規模更改,而不用擔心會破壞所有内容。這些更改(将現代PHP編碼标準引入了我們的代碼庫)有助于消除舊代碼的痕迹:當可以安全地更改代碼時,它就不再是真正的遺留代碼了。

我建立Psalm是為了解決我自己的問題,但現在Psalm已經開源,它也幫助解決了許多其他人的問題。Psalm最近還幫助我們識别了代碼庫中大量的安全漏洞,以免被惡意利用。

順便說一下,如果你害怕對一個大型遺留PHP項目進行較大更改,那麼我強烈建議使用靜态分析類型檢查工具。Psalm(及其他類似工具)可以解決代碼庫中的現有問題,幫你慢慢提高代碼品質。

在20世紀中期,還沒有完善的PHP ORMs,是以我們建立了自己的PHP ORM。PHP提供了大量建構基塊,用于建立簡單的ActiveRecord風格的ORM,包括MySQL支援、查詢參數綁定以及神奇的擷取器和設定器,而這也有助于我們聚集一批優秀工程師來完成這項任務。

我們的ORM最後一次重大更新是在十年前。進行了一些小的改進——Bug修複、類型更新以及一些新特性——但基本結構沒有改變。多年來,我們也嘗試過使用不同類型的ORM,但這些嘗試提議都不是為了響應新的業務需求,而是出于對ActiveRecord模式的不滿。

PHP能創造成功:舊代碼不一定是遺留代碼

圖源:unsplash

最終,這些提議都沒有得到落實。事實證明,如果舊代碼能夠有以下優點,那它們比新代碼更好:

· 工作高效

· 靜态分析簡潔

· 測試運作良好

· 是常用代碼

謝天謝地,我們現有的ORM滿足上述四個要求。

保留可靠的舊代碼也讓我們有機會将精力集中在為業務帶來實質利益的事情上。而且我負責任地說,Vimeo近來一直不斷發展,有大量像Vimeo Record這樣很棒的新産品。

十年前,許多開發人員編寫了一部分PHP後就轉向了其他更受歡迎的語言。他們經常熱切地告訴别人不要再編寫PHP。我想告訴大家,PHP可以成功。Vimeo在PHP上的持續成功證明了它是2020年公司快速發展的一大利器。

PHP的崛起至少讓一個反對者改變了看法。我的一位同僚,之前一直批評PHP,有一天他把我拉到一邊,非常真誠地感謝我告訴了他“用PHP工作并不一定很糟糕”。

PHP能創造成功:舊代碼不一定是遺留代碼

繼續閱讀