Golang標準庫和外部庫的性能比較
前言:
我已經(jīng)在生產(chǎn)中使用 Go
一段時間了,因為它的構(gòu)建規(guī)模較小,并且由 goroutines
提供的并發(fā)性能以及直接在機器上運行構(gòu)建的能力,所以我非常喜歡它的快速和可靠。
由于標準包的速度非??欤梢栽诓皇褂萌魏蔚谌綆旎蚩蚣艿那闆r下構(gòu)建生產(chǎn)就緒的微服務(wù)。這并不是說 Go
中沒有提供更多靈活性或速度的框架,只是它們不那么受歡迎。
官方通常告訴你堅持使用標準庫。具有諷刺意味的是, golang
框架 的頂級 Google
搜索結(jié)果一般都是關(guān)于為什么不應(yīng)該使用標準庫。
我對標準庫的替代品進行了一些研究和基準測試,以了解它們的表現(xiàn)。我將它們分為我認為是關(guān)鍵的微服務(wù)組件。
所有基準測試都在下面列出的配置上運行。雖然正常的基準測試時間只有 1 秒,但我將所有測試運行了 10 秒,以確保每個測試周期都是一致的。
- 處理器 —
2.7 GHz Intel Core i7
RAM — 16GB — 16 GB 2133 MHz LPDDR3
Bench Time 10s
而不是標準的1s
go test -bench=. -benchtime=10s
1、路由
標準的 http Go
服務(wù)器帶有一個不錯的路由器,可以讀取查詢參數(shù)但不能讀取命名參數(shù),例如,
/students/:studentID/grades/:gradeID
任何具有上述嵌套資源的 REST
服務(wù)都必須使用外部路由庫來解析它們。Gin
、Echo
、Beego
、Gorilla Mux
和 Goji
只是其中幾個知名框架(根據(jù) Github
關(guān)注量)。
其中一些是具有路由功能的成熟中間件框架,而另一些則僅僅只是路由庫。
這些庫針對單個命名參數(shù)進行了測試,結(jié)果如下所示,Gin 擁有最快的路由器,Echo 排在第二位。
2、JSON 序列化和反序列化
一旦 API
請求通過路由器并傳遞到控制器或處理程序,下一步就是在返回響應(yīng)時對請求 JSON
或 Encode
進行解碼。
Go 有一個非常好的encoding
包,它支持多種格式,比如json
, XML
, csv
,但是快速瀏覽一下替代品會向你展示大量的庫。我針對標準encoding/json
包對 Jsoniter
、EasyJson
進行了基準測試,結(jié)果如下。
下面是編碼的結(jié)果,結(jié)果表明性能差異并不顯著
但是對于解碼 JSON
,jsoniter
執(zhí)行速度比標準編碼包快 5 倍。
現(xiàn)在,如果您的請求已被解碼,下一步可能是應(yīng)用您的業(yè)務(wù)邏輯,并可能執(zhí)行一些數(shù)據(jù)庫操作。
3、是否使用ORM框架
大多數(shù)流行的語言都依賴于框架來構(gòu)建與數(shù)據(jù)庫交互的微服務(wù)。在 Java
世界中,Hibernate
、Active Record for Rails
和 Django ORM
非常流行。ORM
(對象關(guān)系映射器)有時有助于更好地處理事務(wù)、表之間的關(guān)系,并有助于避免為簡單連接編寫復雜的 SQL
。
但是 Go
再次擁有一個非常好的database
標準庫,它使連接到關(guān)系數(shù)據(jù)庫變得非常容易,而且速度也非常快。但是,一個痛點是查詢。當您查詢某些行時,您必須手動映射行中的每個字段,然后將它們分配給struct
. 這有效,但很快就會變得混亂并讓您編寫大量代碼。sqlx
是一個庫,它允許您將整行掃描到您的結(jié)構(gòu)變量中。
雖然sqlx減少了為構(gòu)建 CRUD
而編寫的典型行數(shù),但最終仍會多次編寫重復代碼。使用 ORM
可以幫助減少它并專注于您的業(yè)務(wù)邏輯。
database, database + sqlx, gorm , go-pg
對查詢進行了基準測試,下面是結(jié)果。令人驚訝的是,go-pgORM
的執(zhí)行速度比標準包甚至sqlx還要快. GORM雖然在生態(tài)系統(tǒng)中非常有名,但速度相對較慢。
在 API
調(diào)用的每個步驟中,都有更好的框架或外部庫,它們將使您的響應(yīng)更快并提供一定的靈活性。
4、總結(jié)
雖然一些外部庫的性能改進非常明顯,但這不應(yīng)該成為遠離標準庫的原因。諸如測試代碼的難易程度、開源庫的長期維護、團隊的學習曲線等都應(yīng)該考慮在內(nèi)。盡管如此,我認為像 echo + jsoniter + go-pgGo
等標準庫功能的所有令人敬畏的東西將是構(gòu)建微服務(wù)并避免冗余代碼的最快方法。
到此這篇關(guān)于Golang
標準庫和外部庫的性能比較的文章就介紹到這了,更多相關(guān)Golang
標準庫和外部庫的性能內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
golang如何用type-switch判斷interface變量的實際存儲類型
這篇文章主要介紹了golang如何用type-switch判斷interface變量的實際存儲類型,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-04-04