標籤:
ASP.NET Web API 是非常棒的技術。編寫 Web API 十分容易,以致於很多開發人員沒有在應用程式結構設計上花時間來獲得很好的執行效能。
在本文中,我將介紹8項提高 ASP.NET Web API 效能的技術。
1) 使用最快的 JSON 序列化工具
JSON 的序列化對整個 ASP.NET Web API 的效能有著關鍵性的影響。 在我的一個項目裡,我從 JSON.NET 序列化工具轉到了 ServiceStack.Text 有一年半了。
我測量過,Web API 的效能提升了20%左右。 我強烈建議你去嘗試一下這個序列化工具。這裡有一些最近的流行序列化工具效能的比較資料。
更新: 似乎It seams that StackOverflow 使用了他們號稱迄今為止最快的 JSON 序列化工具 Jil。 一測試資料可參見他們的GitHub page Jil serializer.
2)從DataReader中手動序列化JSON
我已經在我的項目中使用過這種方法,並獲得了在效能上的福利。
你可以手動地從DataReader建立JSON字串並避免不必要的對象建立,這樣你就不用從DataReader中取值並寫入對象,再從這些對象中取值並使用JSON Serializer產生JSON.
使用StringBuilder產生JSON,並在結尾處返回StringContent作為在WebAPI中響應的內容。
var response = Request.CreateResponse(HttpStatusCode.OK);
response.Content = new StringContent(jsonResult, Encoding.UTF8, "application/json");
return response;
你可以在 Rick Strahl’s blog查看更多方法
3)儘可能使用其它協議格式 (protocol buffer, message pack)
如果你能給在你的工程中使用其它訊息格式,如 Protocol Buffers 或MessagePack 而不是使用JSON這種協議格式。
你將能給擷取到巨大的效能優勢,不僅是因為Protocol Buffers 的序列化是非常快,而且比JSON在返回的結果格式化要更快。
4) 實現壓縮
在你的ASP.NET Web API中使用GZIP 或 Deflate 。
對於減少響應包的大小和響應速度,壓縮是一種簡單而有效方式。
這是一個非常有必要使用的功能,你可以查看更多關於壓縮的文章在我的部落格 ASP.NET Web API GZip compression ActionFilter with 8 lines of code.
5) 使用caching
在Web API方法中使用output caching意義深遠.舉例來說,如果大量使用者訪問同一個一天只改變一次的響應(response)內容。
如果你想實現手動快取,例如把使用者口令緩衝到記憶體,請參看我的博文 Simple way to implement caching in ASP.NET Web API. 6) 儘可能地使用典型的 ADO.NET
手動編寫的ADO.NET仍然是從資料庫中取值的最快捷的方式。如果Web API的效能對你來說真的很重要,那麼就不要使用ORMs.
你可以看到最流行的ORM之間的效能比較.
Dapper 和hand-written fetch code 很快,果不其然,所有的ORM都比這三種慢.
帶有resultset緩衝的LLBLGen 很快,但它要重新遍曆一遍resultset並重新再記憶體中執行個體化對象。
六種簡單方法提升ASP.NET Web API效能