狠狠爱成人网_日韩一级在线_国产综合自拍_亚洲精品韩国_亚洲视频导航_麻豆成人在线播放_欧美jjzz_一区在线视频观看_美脚丝袜一区二区三区在线观看_欧美91视频

當前位置:系統之家 > 技術開發教程 > 詳細頁面

提高ASP性能的最佳選擇(一)

提高ASP性能的最佳選擇(一)

更新時間:2024-04-10 文章作者:未知 信息來源:網絡 閱讀次數:

ASP開發人員為了在他們的設計項目中獲得更好的性能和可擴展性而不斷努力。幸運地是,有許多書籍和站點在這方面提供了很好的建議。但是這些建議的基礎都是從ASP平臺工作的結構上所得出的結論,對實際獲得的性能的提高沒有量的測量。由于這些建議需要更加復雜的編碼過程并降低了編碼的可讀性,開發人員就只能在看不到實際運行效果的情況下,獨自衡量為了提高他們ASP應用程序的性能是否值得付出這些代價。

  本文分為兩大部分,我將介紹一些性能測試結果,幫助開發人員來確定某一特定舉措是否不僅對將來的項目來說是值得的,并且能夠對原來的項目進行更新。在第一部分我將回顧一些ASP開發的基礎性問題。在第二部分,將涉及一些最優化ADO函數,并將它們的結果與調用VB COM對象執行相同ADO函數的ASP頁面進行比較。這些結果很讓人開眼界,甚至有些時候是很令人吃驚的。

  在本文中,我們將回答以下問題:

  * 將ASP生成的內容寫入響應流中最有效的方法是什么?

  * 是否應該開啟緩沖器?

  * 是否應該考慮向ASP代碼中增加注釋?

  * 是否應該為頁面明確地設置默認語言?

  * 如果不需要,是否應該關閉Session 狀態?

  * 是否應該把腳本邏輯放在子程序和函數區中?

  * 使用包含文件有什么影響?

  * 執行錯誤處理時會施加什么樣的負載?

  * 設置一個上下文處理是否對性能有影響?

所有測試都是用Microsoft的Web應用程序重點工具(WAST)來進行的,這是一個免費的工具,可以在這里找到。我用WAST創建了一個簡單的test 腳本,反復調用下面所描述的ASP頁面測試(每個超過70,000次)。反應的時間基于平均最后字節總時間(TTLB), 也就是從最初請求的時間到工具從服務器接收最后一位數據的時間。我們的測試服務器是一個Pentium 166,內存為196MB,客戶機為Pentium 450,內存為256MB。你也許會想這些機器的性能并不算很高級,但是不要忘了,我們并不是要測試服務器的容量,我們只是要測試服務器每次處理一個頁面所用的時間。測試期間這些機器不做其它工作。WAST 測試腳本、測試報告以及所有的ASP測試頁面都包含在ZIP文件中,你可以自己進行回顧和測試。
將ASP生成的內容寫入響應流中最有效的方法是什么?
  使用ASP的一個最主要原因是在服務器上生成動態內容。所以很明顯,我們測試的起點是確定將動態內容發送到響應流中的最適合的方式。在多種選擇中,有兩個是最基本的:一是使用內聯ASP標記,另一個是使用Response.Write 語句。

  為測試這些選擇,我們創建了一個簡單的ASP頁面,其中定義了一些變量,然后將它們的值插入表格中。雖然這個頁面很簡單也不是很實用,但它允許我們分離并測試一些單獨的問題。

  使用ASP內聯標記

  第一個測試包括使用內聯ASP標記< %= x % >,其中x是一個已賦值的變量。到目前為止,這個方法是最容易執行的,并且它使頁面的HTML部分保持一種易于閱讀和維護的格式。

  < % OPTION EXPLICIT

  Dim FirstName

  Dim LastName

  Dim MiddleInitial

  Dim Address

  Dim City

  Dim State

  Dim PhoneNumber

  Dim FaxNumber

  Dim EMail

  Dim BirthDate

  FirstName = "John"

  MiddleInitial = "Q"

  LastName = "Public"

  Address = "100 Main Street"

  City = "New York"

  State = "NY"

  PhoneNumber = "1-212-555-1234"

  FaxNumber = "1-212-555-1234"

  EMail = "john@public.com"

  BirthDate = "1/1/1950"

  % >

  < HTML >

  < HEAD >

  < TITLE >Response Test< / TITLE >

  < /HEAD >

  < BODY >

  < H1 >Response Test< /H1 >

  < TABLE >

  < tr >< td >< b >First Name:< /b >< /td >< td >< %= FirstName % >< /td >< /tr >

  < tr >< td >< b >Middle Initial:< /b >< /td >< td >< %= MiddleInitial % >< /td >< /tr >

  < tr >< td >< b >Last Name:< /b >< /td >< td >< %= LastName % >< /td >< /tr >

  < tr >< td >< b >Address:< /b >< /td >< td >< %= Address % >< /td >< /tr >

  < tr >< td >< b >City:< /b >< /td >< td >< %= City % >< /td >< /tr >

  < tr >< td >< b >State:< /b >< /td >< td >< %= State % >< /td >< /tr >

  < tr >< td >< b >Phone Number:< /b >< /td >< td >< %= PhoneNumber % >< /td >< /tr >

  < tr >< td >< b >Fax Number:< /b >< /td >< td >< %= FaxNumber % >< /td >< /tr >

  < tr >< td >< b >EMail:< /b >< /td >< td >< %= EMail % >< /td >< /tr >

  < tr >< td >< b >Birth Date:< /b >< /td >< td >< %= BirthDate % >< /td >< /tr >

  < /TABLE >

  < /BODY >

  < /HTML >

  /app1/response1.asp的完整代碼

  以前的最佳(反應速度) = 8.28 msec/page

  在HTML的每一行使用Response.Write 語句

  許多比較好的學習文檔建議避免使用前面的那種方法。其主要理由是,在輸出頁面和處理頁面施加反應時間的過程中,如果web 服務器不得不在發送純HTML和處理腳本之間進行轉換,就會發生一種被稱為上下文轉換的問題。大部分程序員一聽到這里,他們的第一反應就是將原始的HTML的每一行都包裝在Response.Write函數中。

  …

  Response.Write("< html >")

  Response.Write("< head >")

  Response.Write(" < title >Response Test< /title >")

  Response.Write("< /head >")

  Response.Write("< body >")

  Response.Write("< h1 >Response Test< /h1 >")

  Response.Write("< table >")

  Response.Write("< tr >< td >< b >First Name:< /b >< /td >< td >" & FirstName & "< /td >< /tr >")

  Response.Write("< tr >< td >< b >Middle Initial:< /b >< /td >< td >" & MiddleInitial & "< /td >< /tr >")

  …

  /app1/response2.asp的片段

  以前的最佳(反應速度) = 8.28 msec/page

  反應時間 = 8.08 msec/page

  差= -0.20 msec (減少 2.4%)

  我們可以看到,使用這種方法與使用內聯標記的方法相比在性能上獲得的收益非常小,這也許是因為頁面給服務器裝載了一大堆小的函數調用。這種方法最大的缺點是,由于現在HTML都嵌入腳本中,所以腳本代碼變得更加冗長,更加難以閱讀和維護。

  使用包裝函數

  當我們試圖使用Response.Write 語句這種方法時,最令人灰心的發現可能就是Response.Write 函數不能在每行的結尾處放置一個CRLF 。因此,當你從瀏覽器中閱讀源代碼時,本來布置得非常好的HTML,現在成了沒有結束的一行。我想,你的下一個發現可能會更令你恐怖:在Response 對象中沒有其姊妹函數Writeln 。所以,一個很明顯的反應就是為Response.Write 函數創建一個包裝函數,以便給每一行都附加一個CRLF 。

  …

  writeCR("< tr >< td >< b >First Name:< /b >< /td >< td >" & FirstName & "< /td >< /tr >")

  …

  SUB writeCR(str)

  Response.Write(str & vbCRLF)

  END SUB

  /app1/response4.asp的片段

  以前的最佳(反應速度)= 8.08 msec/page

  反應時間= 10.11 msec/page

  差 = +2.03 msec (增加 25.1%)

  當然,由于這種方法有效地使函數調用次數加倍,其對性能的影響也很明顯,因此要不惜一切代價避免。具有諷刺意味的是CRLF也向反應流中為每行增加了2個字節,而這是瀏覽器不需要呈現到頁面上的。格式化良好的HTML所做的一切就是讓你的競爭者更容易閱讀你的HTML源代碼并理解你的設計。

  將連續的Response.Write 連接到一個單獨語句中

  不考慮我們前面用包裝函數進行的測試,下一個合乎邏輯的步驟就是從單獨的Response.Write 語句中提取出所有的字符串,將它們連接到一個單獨語句中,這樣就減少了函數調用的次數,極大地提高了頁面的性能。

  …

  Response.Write("< html >" & _

  "< head >" & _

  "< title >Response Test< /title >" & _

  "< /head >" & _

  "< body >" & _

  "< h1 >Response Test< /h1 >" & _

  "< table >" & _

  "< tr >< td >< b >First Name:< /b >< /td >< td >" & FirstName & "< /td >< /tr >" & _

  …

  "< tr >< td >< b >Birth Date:< /b >< /td >< td >" & BirthDate & "< /td >< /tr >" & _

  "< /table >" & _

  "< /body >" & _

  "< /html >")

  /app1/response3.asp的片段

  以前的最佳(反應速度)= 8.08 msec/page

  反應時間 = 7.05 msec/page

  差 = -1.03 msec (減少12.7%)

  目前,這是最優化的配置。

  將連續的Response.Write 連接到一個單獨語句中,在每行結尾處增加一個CRLF

  考慮到那些要求他們的源代碼從瀏覽器中看要很純粹的人,我用vbCRLF 常量在前面測試中每行的結尾處插入了一些回車,然后重新運行。  

  …

  Response.Write("< html >" & vbCRLF & _

  "< head >" & vbCRLF & _

  " < title >Response Test< /title >" & vbCRLF & _

  "< /head >" & vbCRLF & _

  …

  /app1/response5.asp的片段

  前面的最佳(反應速度)= 7.05 msec/page

  反應時間= 7.63 msec/page

  差 = +0.58 msec (增加 8.5%)

  運行的結果在性能上有一點降低,這也許是由于額外的串聯和增加的字符量。

  回顧和觀測

  從前面有關ASP輸出的測試中可以得出一些規則:

  * 避免內聯ASP的過多使用。

  * 總是將連續Response.Write 語句連接進一個單獨語句內。

  * 永遠不要在Response.Write 周圍使用包裝函數來附加CRLF。

  * 如果必須格式化HTML輸出,直接在Response.Write 語句內附加CRLF。

溫馨提示:喜歡本站的話,請收藏一下本站!

本類教程下載

系統下載排行

狠狠爱成人网_日韩一级在线_国产综合自拍_亚洲精品韩国_亚洲视频导航_麻豆成人在线播放_欧美jjzz_一区在线视频观看_美脚丝袜一区二区三区在线观看_欧美91视频
欧美精品国产精品| 亚洲柠檬福利资源导航| 色婷婷久久久综合中文字幕| 鲁大师成人一区二区三区| 91久久精品一区二区二区| 麻豆一区二区在线| 日韩欧美一区二区久久婷婷| 一本色道久久综合狠狠躁的推荐| 国产精品hd| 99久久精品久久久久久清纯| 日本91福利区| 国产精品无遮挡| 日韩欧美成人午夜| 91精品国产欧美一区二区 | av电影天堂一区二区在线 | 亚洲欧美网站| 最新日韩在线| 国产一区日韩一区| 欧美一区三区二区在线观看| 亚洲手机视频| 国产亚洲一区二区三区在线观看| 日韩av午夜在线观看| 亚洲一区在线观看免费观看电影高清| 久久精品国产精品亚洲精品 | 国产在线欧美日韩| 色乱码一区二区三区88| 欧美变态tickling挠脚心| 亚洲欧美偷拍另类a∨色屁股| 日韩中文字幕av电影| 成人av免费在线| 欧美一区二区三区在线播放 | 日韩av午夜在线观看| 91在线观看美女| 一区在线视频| 久久久久中文| 国产欧美日韩视频一区二区| 日韩精品久久理论片| 99视频精品全部免费在线| 亚洲欧美清纯在线制服| 日韩欧美另类在线| 亚洲国产综合在线| av中文字幕亚洲| 亚洲欧美久久久| 91精品在线一区二区| 国产偷国产偷精品高清尤物| 丝瓜av网站精品一区二区 | 精品成人一区二区三区| 亚洲精品视频一区| 国产91丝袜在线播放九色| 一区二区欧美日韩| 久久噜噜亚洲综合| 国产一区二区三区四| 一区二区国产在线观看| 精品乱码亚洲一区二区不卡| 久久精品国产亚洲aⅴ| 亚洲国产精品第一区二区三区| 欧美一区二区免费观在线| 亚洲成人福利片| 99久久国产综合色|国产精品| 久久亚洲一区| 亚洲欧美日韩国产一区二区三区| 懂色av一区二区在线播放| 日本精品一级二级| 亚洲自拍都市欧美小说| 国产中文一区| 欧美精品久久一区二区三区| 国产精品卡一卡二卡三| 成人黄页在线观看| 欧美精品高清视频| 欧美日韩日日夜夜| 欧美国产禁国产网站cc| 欧美一区二区女人| 亚洲综合男人的天堂| 欧美日韩国产影片| 国产精品色在线| 久久久久久久久久久久久久久99| 中文字幕日本乱码精品影院| 蜜臀精品一区二区三区在线观看| 成人久久久精品乱码一区二区三区 | 久久激情综合| 久久日韩粉嫩一区二区三区| 亚洲高清免费视频| 免费日韩一区二区| 亚洲精品一区二区三区影院| 午夜伊人狠狠久久| 成人综合在线网站| 色哟哟一区二区三区| 久久综合成人精品亚洲另类欧美 | 一区国产精品| 欧美一级生活片| 亚洲国产精品视频| 女女同性精品视频| 制服丝袜中文字幕一区| 亚洲一区免费在线观看| 国产乱人伦偷精品视频不卡| 亚洲国产二区| 久久久久久电影| 卡一卡二国产精品 | 亚洲视屏一区| 日韩视频一区在线观看| 午夜天堂影视香蕉久久| 欧美精品成人| 欧美一区二区女人| 美女网站视频久久| 国产日韩欧美一区二区| 国产精品无码永久免费888| 日韩中文字幕一区二区三区| 一区二区在线不卡| 久久精品在这里| 国产精品亚洲成人| 欧美三级在线视频| 日韩va欧美va亚洲va久久| 亚洲欧洲在线一区| 国产精品乱码一区二区三区软件| 午夜激情一区二区三区| 亚洲三级影院| 国产精品久久久久影院亚瑟 | 欧美精品一区二区三区蜜桃视频 | 成人爱爱电影网址| 日韩视频123| 精品在线免费观看| 国产日韩精品久久| 亚洲伦理在线精品| 亚洲黄色精品| 亚洲欧美日韩电影| 一区二区三区偷拍| 亚洲美女在线国产| 国产精品久久久亚洲一区| 2023国产精品| 99久久免费视频.com| 精品成人在线观看| 欧美在线三区| 国产精品国产三级国产a| 欧美日韩成人在线| 国产在线精品一区二区三区不卡 | 久久综合国产精品| 99香蕉国产精品偷在线观看| 日韩在线卡一卡二| 欧美α欧美αv大片| 亚洲精品视频啊美女在线直播| 午夜久久福利影院| 欧美电影免费观看高清完整版| 狠狠色狠狠色综合人人| 青青国产91久久久久久| 亚洲精品在线网站| 亚洲欧美99| 成人性生交大片免费看中文网站| 国产精品女人毛片| 欧洲一区在线电影| 欧美久久综合| 久草热8精品视频在线观看| 欧美激情一区二区| 在线精品视频一区二区三四 | 欧美一区二区三区视频在线| 怡红院精品视频在线观看极品| 日本不卡一区二区| 亚洲国产成人自拍| 欧美精品一二三| 99亚洲精品| www.亚洲色图.com| 另类小说图片综合网| 国产精品毛片久久久久久久| 欧美久久久一区| 99re热精品| 不卡一卡二卡三乱码免费网站| 亚洲成av人综合在线观看| 久久―日本道色综合久久| 91久久精品一区二区三区| 亚洲国产片色| 暴力调教一区二区三区| 美女mm1313爽爽久久久蜜臀| 亚洲欧洲性图库| 精品久久久久久最新网址| 在线一区二区视频| 在线免费高清一区二区三区| 高清国产午夜精品久久久久久| 午夜精品免费在线观看| 中文字幕一区二区三区在线不卡| 9191精品国产综合久久久久久 | 国产精品狼人久久影院观看方式| 欧美一区二区美女| 欧美中文一区二区三区| 在线一区日本视频| 激情久久久久| 色综合色综合色综合色综合色综合| 久久99在线观看| 日韩激情在线观看| 亚洲妇熟xx妇色黄| 亚洲人xxxx| 亚洲欧洲精品天堂一级 | 国产乱淫av一区二区三区| 琪琪一区二区三区| 亚洲成人av一区二区三区| 一区二区三区免费在线观看| 欧美激情一二三区| 中文字幕乱码日本亚洲一区二区| 精品日韩一区二区三区免费视频| 91精品国产综合久久蜜臀| 欧美精品第1页| 欧美日韩国产123区|