亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

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

2019-11-18 20:28:38
字體:
來源:轉載
供稿:網友
  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。


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产精品久久久av久久久| 国产精品久久久久秋霞鲁丝| 亚洲免费av电影| 黄色一区二区在线观看| 热久久这里只有| 亚洲午夜女主播在线直播| 久久激情视频久久| 日韩高清有码在线| 国产精品十八以下禁看| 亚洲午夜色婷婷在线| 最近2019中文字幕第三页视频| 久久噜噜噜精品国产亚洲综合| 国产成人涩涩涩视频在线观看| 久久久在线观看| 欧美疯狂性受xxxxx另类| 91av网站在线播放| 亚洲色图美腿丝袜| 亚洲第五色综合网| 欧美一区三区三区高中清蜜桃| 国产日本欧美一区二区三区| 国产成人激情小视频| 日产精品99久久久久久| 久久久女人电视剧免费播放下载| 国产精品视频免费在线观看| 国产精品稀缺呦系列在线| 国产视频欧美视频| 红桃视频成人在线观看| 亚洲欧洲偷拍精品| 91人成网站www| 欧美在线亚洲在线| 一本色道久久综合亚洲精品小说| 国产成人精品视| 久久久久久有精品国产| 午夜精品久久久久久久久久久久| 日韩在线欧美在线国产在线| 91欧美视频网站| 精品久久久91| 在线观看亚洲区| 亚洲男女自偷自拍图片另类| 欧美激情在线狂野欧美精品| 成人写真福利网| 麻豆精品精华液| 亚洲最新av网址| 久久99精品久久久久久青青91| 91在线视频一区| 亚洲aa在线观看| 国产精品91一区| 精品国产精品自拍| 中文字幕亚洲欧美日韩高清| 亚洲精品第一页| 8050国产精品久久久久久| 国产美女精品免费电影| 夜夜嗨av一区二区三区免费区| 黑人精品xxx一区一二区| 久久久久这里只有精品| 欧美激情一区二区三级高清视频| xxx欧美精品| 亚洲欧美中文在线视频| 精品一区二区三区四区| 久久久国产成人精品| 欧洲精品毛片网站| 日韩人体视频一二区| 国产精品jvid在线观看蜜臀| 亚洲人成网在线播放| 国产美女久久精品香蕉69| 国产在线精品播放| 亚洲白虎美女被爆操| 色香阁99久久精品久久久| 国产视频亚洲视频| 久久久国产成人精品| 国产啪精品视频网站| 欧美性极品xxxx娇小| 国产精品一二三在线| 九九热精品在线| 日韩在线视频网| 97av在线视频免费播放| 91久久久亚洲精品| 日韩电视剧免费观看网站| 色综合伊人色综合网| 热久久免费视频精品| 国产成人精品综合| 高清在线视频日韩欧美| 成人久久久久久| 在线观看日韩欧美| 成人福利在线观看| 亚洲影院污污.| 九九九热精品免费视频观看网站| 国产精品久久久久久久天堂| 米奇精品一区二区三区在线观看| 亚洲综合大片69999| 深夜成人在线观看| 欧美亚洲激情视频| 日韩在线视频中文字幕| 色噜噜久久综合伊人一本| 在线观看91久久久久久| 欧美一区二区三区……| 国产99久久精品一区二区| 精品福利一区二区| 亚洲欧美在线免费观看| 精品成人国产在线观看男人呻吟| www日韩中文字幕在线看| 亚洲成色777777在线观看影院| 久久影视电视剧免费网站| 日韩美女毛茸茸| 成人免费视频网址| 日韩电影在线观看中文字幕| 亚洲天天在线日亚洲洲精| 岛国av一区二区在线在线观看| 亚洲欧美激情四射在线日| 亚洲一区二区久久| 精品国产一区二区三区在线观看| 日韩精品免费在线视频| 亚洲字幕一区二区| 国产中文字幕日韩| 91精品久久久久久久久久另类| 精品国产一区二区三区四区在线观看| 色偷偷av亚洲男人的天堂| 激情懂色av一区av二区av| 色多多国产成人永久免费网站| 久热精品视频在线观看| 69久久夜色精品国产69| 亚洲精选在线观看| 大桥未久av一区二区三区| 欧美激情女人20p| 国产亚洲精品久久久久动| 91视频-88av| 亚洲精品suv精品一区二区| 亚洲国产精品99久久| 国产一区玩具在线观看| 欧美激情一级欧美精品| 国产a∨精品一区二区三区不卡| 久久97久久97精品免视看| 日本欧美国产在线| 亚洲精品视频中文字幕| 日韩av电影国产| 亚洲精品福利视频| 亚洲最大的网站| 国产欧美日韩精品专区| 欧美午夜精品久久久久久久| 久久久之久亚州精品露出| 成人午夜激情免费视频| 欧美日本啪啪无遮挡网站| 亚洲缚视频在线观看| 久久视频在线播放| 亚洲国产99精品国自产| 97色在线视频| 精品久久香蕉国产线看观看gif| 欧美成人合集magnet| 国产欧美日韩最新| 久久天天躁狠狠躁夜夜爽蜜月| 亚洲香蕉在线观看| 91欧美精品午夜性色福利在线| 亚洲成人免费在线视频| 精品久久久久久久久久ntr影视| 国产精品日韩专区| 日韩欧美中文免费| 久久久久久免费精品| 国产精品美女无圣光视频| 国产成人av在线| 日韩av男人的天堂| 国产精品免费小视频| 欧美特级www| 久久免费精品视频| 日韩亚洲精品视频|