在工作的專案中,我的主要開發語言是php,因需求或為彌補php的缺陷,需要為php做各種各樣的擴展,例如php本身不支援線程,沒有佇列,進程也不無法用於生產環境, 可以說php沒有任何“程”,因而網上有較多的文章闡述如何實現php隊列,多線程等等,在我的理解,與其用php本身實現這種無法保證健壯的特性,不如去發掘運用一些本身集成,且表現優異的語言。
微博中了解到了golang語言,golang的語法類似C和python, 有這兩種語言經驗的同學入門會比較順利! golang語言的優點在這裡就不一一闡述了! !
學習了一段時間之後,維護的業務正好遇到瓶頸,另因我維護的業務屬於接口層,邏輯比較簡單,只輸出json數據,所以開始著手利用golang重構現有系統,改造中,因部分同事對golang比較懷疑,另外網上的性能對比,大部分只是hello word輸出,參考意義很小,所以利用線上兩台內網機器,做了一次php和golang的正式業務性能對比
伺服器設定: 16核心E5620 @ 2.40GHz 11G記憶體
業務包含:DB(oracle)和redis查詢, 當有快取之後,DB不再查詢,直接讀取redis, 批次查詢兩個主鍵
使用apache的ab測試並發200,20000個請求
golang 並發測試
golang的qps 大約在9675/s, 最高10200/s 左右,cpu利用率高峰在10.6% 上下golang開啟了多核, 並且維護了40個redis連接池
上面php的連結是golang的url重寫,為了兼容php的項目,不要誤解!
PHP並發測試
php的QPS大約是1726/s, 最高2100/s 左右, cpu 高峰在50.1% 比較恐怖
#另外也測試了更多主鍵的批次查詢, golang的處理能力降到4700/s, php到1078/s, 將ab並發加到400時, php開始出現請求失敗的情況,
golang的並發加到2500後,驚訝其表現依然出色, 有懷疑的可以自行測試
上面的測試結果得出的結論: 因多核利用,golang的”多線程”, 還有redis連接池, 使得go在和php並發對比中遙遙領先,處理能力大約是php的4倍
所以建議維護著請求量較大,遇到瓶頸專案的同學可以嘗試使用golang改善!
以上是go 為什麼比php效能高的詳細內容。更多資訊請關注PHP中文網其他相關文章!