Golang標(biāo)準(zhǔn)庫和外部庫的性能比較
前言:
我已經(jīng)在生產(chǎn)中使用 Go 一段時(shí)間了,因?yàn)樗臉?gòu)建規(guī)模較小,并且由 goroutines 提供的并發(fā)性能以及直接在機(jī)器上運(yùn)行構(gòu)建的能力,所以我非常喜歡它的快速和可靠。
由于標(biāo)準(zhǔn)包的速度非???,您可以在不使用任何第三方庫或框架的情況下構(gòu)建生產(chǎn)就緒的微服務(wù)。這并不是說 Go 中沒有提供更多靈活性或速度的框架,只是它們不那么受歡迎。
官方通常告訴你堅(jiān)持使用標(biāo)準(zhǔn)庫。具有諷刺意味的是, golang 框架 的頂級 Google 搜索結(jié)果一般都是關(guān)于為什么不應(yīng)該使用標(biāo)準(zhǔn)庫。
我對標(biāo)準(zhǔn)庫的替代品進(jìn)行了一些研究和基準(zhǔn)測試,以了解它們的表現(xiàn)。我將它們分為我認(rèn)為是關(guān)鍵的微服務(wù)組件。
所有基準(zhǔn)測試都在下面列出的配置上運(yùn)行。雖然正常的基準(zhǔn)測試時(shí)間只有 1 秒,但我將所有測試運(yùn)行了 10 秒,以確保每個測試周期都是一致的。
- 處理器 —
2.7 GHz Intel Core i7 RAM — 16GB — 16 GB 2133 MHz LPDDR3Bench Time 10s而不是標(biāo)準(zhǔn)的1sgo test -bench=. -benchtime=10s
1、路由
標(biāo)準(zhǔn)的 http Go 服務(wù)器帶有一個不錯的路由器,可以讀取查詢參數(shù)但不能讀取命名參數(shù),例如,
/students/:studentID/grades/:gradeID
任何具有上述嵌套資源的 REST 服務(wù)都必須使用外部路由庫來解析它們。Gin、Echo、Beego、Gorilla Mux 和 Goji 只是其中幾個知名框架(根據(jù) Github 關(guān)注量)。
其中一些是具有路由功能的成熟中間件框架,而另一些則僅僅只是路由庫。
這些庫針對單個命名參數(shù)進(jìn)行了測試,結(jié)果如下所示,Gin 擁有最快的路由器,Echo 排在第二位。

2、JSON 序列化和反序列化
一旦 API 請求通過路由器并傳遞到控制器或處理程序,下一步就是在返回響應(yīng)時(shí)對請求 JSON 或 Encode 進(jìn)行解碼。
Go 有一個非常好的encoding包,它支持多種格式,比如json, XML, csv,但是快速瀏覽一下替代品會向你展示大量的庫。我針對標(biāo)準(zhǔn)encoding/json包對 Jsoniter、EasyJson 進(jìn)行了基準(zhǔn)測試,結(jié)果如下。
下面是編碼的結(jié)果,結(jié)果表明性能差異并不顯著

但是對于解碼 JSON,jsoniter執(zhí)行速度比標(biāo)準(zhǔn)編碼包快 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)系映射器)有時(shí)有助于更好地處理事務(wù)、表之間的關(guān)系,并有助于避免為簡單連接編寫復(fù)雜的 SQL。
但是 Go 再次擁有一個非常好的database標(biāo)準(zhǔn)庫,它使連接到關(guān)系數(shù)據(jù)庫變得非常容易,而且速度也非???。但是,一個痛點(diǎn)是查詢。當(dāng)您查詢某些行時(shí),您必須手動映射行中的每個字段,然后將它們分配給struct. 這有效,但很快就會變得混亂并讓您編寫大量代碼。sqlx是一個庫,它允許您將整行掃描到您的結(jié)構(gòu)變量中。
雖然sqlx減少了為構(gòu)建 CRUD 而編寫的典型行數(shù),但最終仍會多次編寫重復(fù)代碼。使用 ORM 可以幫助減少它并專注于您的業(yè)務(wù)邏輯。
database, database + sqlx, gorm , go-pg 對查詢進(jìn)行了基準(zhǔn)測試,下面是結(jié)果。令人驚訝的是,go-pgORM 的執(zhí)行速度比標(biāo)準(zhǔn)包甚至sqlx還要快. GORM雖然在生態(tài)系統(tǒng)中非常有名,但速度相對較慢。

在 API 調(diào)用的每個步驟中,都有更好的框架或外部庫,它們將使您的響應(yīng)更快并提供一定的靈活性。
4、總結(jié)
雖然一些外部庫的性能改進(jìn)非常明顯,但這不應(yīng)該成為遠(yuǎn)離標(biāo)準(zhǔn)庫的原因。諸如測試代碼的難易程度、開源庫的長期維護(hù)、團(tuán)隊(duì)的學(xué)習(xí)曲線等都應(yīng)該考慮在內(nèi)。盡管如此,我認(rèn)為像 echo + jsoniter + go-pgGo 等標(biāo)準(zhǔn)庫功能的所有令人敬畏的東西將是構(gòu)建微服務(wù)并避免冗余代碼的最快方法。
到此這篇關(guān)于Golang標(biāo)準(zhǔn)庫和外部庫的性能比較的文章就介紹到這了,更多相關(guān)Golang標(biāo)準(zhǔn)庫和外部庫的性能內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
go語言實(shí)現(xiàn)通過FTP庫自動上傳web日志
這篇文章主要介紹了go語言實(shí)現(xiàn)通過FTP庫自動上傳web日志,非常簡單實(shí)用,需要的小伙伴快來參考下吧。2015-03-03
golang如何用type-switch判斷interface變量的實(shí)際存儲類型
這篇文章主要介紹了golang如何用type-switch判斷interface變量的實(shí)際存儲類型,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-04-04

