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作為在We
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之間的性能比較.

新聞熱點
疑難解答