fasthttp是一個用于Go的快速HTTP包,針對高性能進行了調(diào)整,在熱路徑中實現(xiàn)零內(nèi)存分配,比net/http快10倍以上,目前,fasthttp被VertaMedia成功地用于生產(chǎn)中,為每臺物理服務(wù)器上超過150萬個并發(fā)的保持連接提供200K rps的服務(wù)。
常見問題
為什么要創(chuàng)建另一個http包而不是優(yōu)化net/http?
因為 net/http API 限制了許多優(yōu)化機會。比如說。
net/http 請求對象的壽命不受請求處理器執(zhí)行時間的限制。所以服務(wù)器必須為每個請求創(chuàng)建一個新的請求對象,而不是像 fasthttp 那樣重復(fù)使用現(xiàn)有的對象。
net/http 頭信息被存儲在 map[string][]string 中。所以服務(wù)器必須解析所有的頭信息,將它們從[]字節(jié)轉(zhuǎn)換成字符串,并在調(diào)用用戶提供的請求處理程序之前將它們放入map中。這一切都需要不必要的內(nèi)存分配,而fasthttp則可以避免。
net/http客戶端API需要為每個請求創(chuàng)建一個新的響應(yīng)對象。
為什么fasthttp API與net/http不兼容?
因為net/http API限制了許多優(yōu)化機會。更多細(xì)節(jié)見上面的答案。同時,某些net/http API的部分也是次優(yōu)的使用方式。
比較net/http的連接劫持和fasthttp的連接劫持。
比較net/http的Request.Body讀取和fasthttp的請求體讀取。
為什么fasthttp不支持HTTP/2.0和WebSockets?
HTTP/2.0的支持正在進行中。WebSockets已經(jīng)完成了。第三方也可以使用RequestCtx.Hijack來實現(xiàn)這些好東西。
與fasthttp相比,net/http是否有已知的優(yōu)勢?
是的。
net/http 從 go1.6 開始支持 HTTP/2.0。
net/http的API是穩(wěn)定的,而fasthttp的API是不斷發(fā)展的。
net/http 可以處理更多的 HTTP 角落情況。
net/http 應(yīng)該包含更少的 bug,因為它被更多的人使用和測試。
net/http可以在1.5以上的Go上工作。
為什么 fasthttp API 傾向于返回 []byte 而不是字符串?
因為[]字節(jié)到字符串的轉(zhuǎn)換不是免費的 - 它需要內(nèi)存分配和復(fù)制。如果你喜歡用字符串而不是字節(jié)片來工作,可以隨意將返回的[]byte結(jié)果包裝成string()。但請注意,這有非零的開銷。
fasthttp支持哪些GO版本?
Go1.5以上。舊的版本將不被支持,因為它們的標(biāo)準(zhǔn)包缺少有用的功能。
注意:Go 1.9.7是最老的測試版本。我們建議你盡快更新。從1.11.3開始,我們將放棄對1.9.x的支持。
請?zhí)峁┱鎸嵉幕鶞?zhǔn)數(shù)據(jù)和服務(wù)器信息
請看這個問題。
是否有計劃向fasthttp添加請求路由?
沒有計劃將請求路由添加到fasthttp中。使用第三方路由器和支持fasthttp的web框架。
fasthttp-routing
路由器
框架
lu
阿特雷戈
光纖
齒輪箱
更多信息請參見此問題。
我在fasthttp中檢測到了數(shù)據(jù)競賽!
酷! 歸檔一個錯誤。但是在這樣做之前,請在你的代碼中檢查以下內(nèi)容。
確保從RequestHandler返回后沒有對RequestCtx或其成員的引用。
確保在從RequestHandler返回之前調(diào)用TimeoutError,如果有對RequestCtx或其成員的引用,這可能會被其他goroutine訪問。
我在這里沒有找到我的問題的答案
試著探索一下這些問題。