日韩天天综合网_野战两个奶头被亲到高潮_亚洲日韩欧美精品综合_av女人天堂污污污_视频一区**字幕无弹窗_国产亚洲欧美小视频_国内性爱精品在线免费视频_国产一级电影在线播放_日韩欧美内地福利_亚洲一二三不卡片区

8 種提升 ASP.NET Web API 性能的方法_ASP教程

編輯Tag賺U幣
教程Tag:暫無(wú)Tag,歡迎添加,賺取U幣!

推薦:asp.net計(jì)算每個(gè)頁(yè)面執(zhí)行時(shí)間的方法
這篇文章主要介紹了asp.net計(jì)算每個(gè)頁(yè)面執(zhí)行時(shí)間的方法,涉及asp.net操作時(shí)間的相關(guān)技巧,非常具有實(shí)用價(jià)值,需要的朋友可以參考下 本文實(shí)例講述了asp.net計(jì)算每個(gè)頁(yè)面執(zhí)行時(shí)間的方法。分享給大家供大家參考。具體分析如下: 這里的asp.net代碼可實(shí)現(xiàn)計(jì)算每個(gè)頁(yè)面的執(zhí)行時(shí)

   ASP.NET Web API 是非常棒的技術(shù)。編寫 Web API 十分容易,以致于很多開發(fā)者沒有在應(yīng)用程序結(jié)構(gòu)設(shè)計(jì)上花時(shí)間來(lái)獲得很好的執(zhí)行性能。

  在本文中,我將介紹8項(xiàng)提高 ASP.NET Web API 性能的技術(shù)。

  1) 使用最快的 JSON 序列化工具

  JSON 的序列化對(duì)整個(gè) ASP.NET Web API 的性能有著關(guān)鍵性的影響。 在我的一個(gè)項(xiàng)目里,我從 JSON.NET 序列化工具轉(zhuǎn)到了 ServiceStack.Text 有一年半了。

  我測(cè)量過,Web API 的性能提升了20%左右。 我強(qiáng)烈建議你去嘗試一下這個(gè)序列化工具。這里有一些最近的流行序列化工具性能的比較數(shù)據(jù)。

SerializerPerformanceGraf

  更新: 似乎It seams that StackOverflow 使用了他們號(hào)稱迄今為止最快的 JSON 序列化工具 Jil 。 一測(cè)試數(shù)據(jù)可參見他們的GitHub page Jil serializer.

  2)從DataReader中手動(dòng)串行化JSON

  我已經(jīng)在我的項(xiàng)目中使用過這種方法,并獲得了在性能上的福利。

  你可以手動(dòng)地從DataReader創(chuàng)建JSON字符串并避免不必要的對(duì)象創(chuàng)建,這樣你就不用從DataReader中取值并寫入對(duì)象,再?gòu)倪@些對(duì)象中取值并使用JSON Serializer產(chǎn)生JSON.

  使用StringBuilder產(chǎn)生JSON,并在結(jié)尾處返回StringContent作為在WebAPI中響應(yīng)的內(nèi)容。

  var response = Request.CreateResponse(HttpStatusCode.OK); response.Content = new StringContent(jsonResult, Encoding.UTF8, "application/json"); return response;

  你可以在 Rick Strahl’s blog查看更多方法

  3)盡可能使用其它協(xié)議格式 (protocol buffer, message pack)

  如果你能給在你的工程中使用其它消息格式,如 Protocol Buffers 或MessagePack 而不是使用JSON這種協(xié)議格式。

  你將能給獲取到巨大的性能優(yōu)勢(shì),不僅是因?yàn)镻rotocol Buffers 的序列化是非�?�,而且比JSON在返回的結(jié)果格式化要更快。

  4) 實(shí)現(xiàn)壓縮

  在你的ASP.NET Web API中使用GZIP 或 Deflate 。

  對(duì)于減少響應(yīng)包的大小和響應(yīng)速度,壓縮是一種簡(jiǎn)單而有效的方式。

  這是一個(gè)非常有必要使用的功能,你可以查看更多關(guān)于壓縮的文章在我的博客 ASP.NET Web API GZip compression ActionFilter with 8 lines of code.

  5) 使用caching

  在Web API方法中使用output caching意義深遠(yuǎn).舉例來(lái)說(shuō),如果大量用戶訪問同一個(gè)一天只改變一次的響應(yīng)(response)內(nèi)容。

  如果你想實(shí)現(xiàn)手動(dòng)緩存,例如把用戶口令緩存到內(nèi)存,請(qǐng)參看我的博文 Simple way to implement caching in ASP.NET Web API.

  6) 盡可能地使用典型的 ADO.NET

  手動(dòng)編寫的ADO.NET仍然是從數(shù)據(jù)庫(kù)中取值的最快捷的方式。如果Web API的性能對(duì)你來(lái)說(shuō)真的很重要,那么就不要使用ORMs.

  你可以看到最流行的ORM之間的性能比較.

ORMMapper

  Dapper 和hand-written fetch code 很快,果不其然,所有的ORM都比這三種慢.

  帶有resultset緩存的LLBLGen 很快,但它要重新遍歷一遍resultset并重新再內(nèi)存中實(shí)例化對(duì)象。

  7)在 Web API 中實(shí)現(xiàn)異步方法

  使用異步的 Web API 服務(wù)大幅增加 Web API 對(duì)于Http 請(qǐng)求的處理數(shù)量。

  實(shí)現(xiàn)是簡(jiǎn)單的,只需使用 async 的關(guān)鍵字和 將你方法的返回值類型改為 Task 即可。

  [HttpGet] public async Task OperationAsync() { await Task.Delay(2000); }

  8) 返回多個(gè)結(jié)果集和集合的組合

  減少傳輸?shù)拇螖?shù)不僅多數(shù)據(jù)庫(kù)有好處,對(duì)于 Web API同樣 ,你才有可能使用結(jié)果集的功能。

  也就是說(shuō)你可以從DataReader 去提取多個(gè)結(jié)果集 參見以下演示代碼

  // read the first resultset var reader = command.ExecuteReader(); // read the data from that resultset while (reader.Read()) { suppliers.Add(PopulateSupplierFromIDataReader( reader )); } // read the next resultset reader.NextResult(); // read the data from that second resultset while (reader.Read()) { products.Add(PopulateProductFromIDataReader( reader )); }

  你可以在一個(gè) Web API 的一次響應(yīng)中返回多個(gè)對(duì)象,試著將你的返回的多個(gè)對(duì)象進(jìn)行組合后返回 如下:

  public class AggregateResult { public long MaxId { get; set; } public List Folders{ get; set; } public List Users{ get; set; } }

  這種方式將減少對(duì)你的WEB API的HTTP請(qǐng)求。

  感謝你讀讀這篇文章。

分享:asp實(shí)現(xiàn)獲取MSSQL數(shù)據(jù)庫(kù)表指定條件行數(shù)的函數(shù)
這篇文章主要介紹了asp實(shí)現(xiàn)獲取MSSQL數(shù)據(jù)庫(kù)表指定條件行數(shù)的函數(shù)的的相關(guān)資料,需要的朋友可以參考下 代碼如下: '數(shù)據(jù)庫(kù)表行數(shù)函數(shù),這是取表的行數(shù) Function GetTblRows(TblName) '如果TblName表名值為空,則 if TblName= Then GetTblRows=未知TblName exit Function E

來(lái)源:模板無(wú)憂//所屬分類:ASP教程/更新時(shí)間:2015-05-08
相關(guān)ASP教程