国产一级一区二区_segui88久久综合9999_97久久夜色精品国产_欧美色网一区二区

掃一掃
關注微信公眾號

IIS常見問題-扼殺IIS服務器性能的十條規則
2007-09-24   網絡

下面的每一條戒律都將有效地影響代碼的性能和可伸縮性。換句話說,盡可能不要照著戒律去做!下面,我將解釋如何破壞他們以便提高性能和可伸縮性。

1、應該分配和釋放多個對象

你應該盡量避免過量分配內存,因為內存分配可能是代價高昂的。釋放內存塊可能更昂貴,因為大多數分配算符總是企圖連接臨近的已釋放的內存塊成為更大的塊。直到Windows NT? 4.0 service pack 4.0,在多線程處理中,系統堆通常都運行得很糟。堆被一個全局鎖保護,并且在多處理器系統上是不可擴展的。

2.不應該考慮使用處理器高速緩存

大多數人都知道由虛擬內存子系統導致的hard 頁錯誤代價很高,最好避免。但是許多人認為其他內存訪問方法沒有什么區別。自從80486以后,這一觀點就不對了。現代的CPUs比RAM要快得多,RAM至少需要兩級內存緩存 ,高速L1 緩存能保存8KB數據和8KB指令,而較慢的L2 緩存能保存幾百KB的數據和代碼,這些數據和代碼混合在一起。L1 緩存中內存區域的一個引用需要一個時鐘周期,L2 緩存的引用需要4到7個時鐘周期,而主內存的引用需要許多個處理器時鐘周期。后一數字不久將會超過100個時鐘周期。在許多方面,緩存像一個小型的,高速的,虛擬內存系統。

至于和緩存有關的基本內存單元不是字節而是緩存列。Pentium 緩存列有32個字節寬。Alpha 緩存列有64個字節寬。這意味著在L1 緩存中只有512個slot給代碼和數據。如果多個數據一起使用(時間位置)而并不存儲在一起(空間位置),性能會很差。數組的空間位置很好,而相互連接的列表和其他基于指針的數據結構的位置往往很差。

把數據打包到同一個緩存列中通常會有利于提高性能,但是它也會破壞多處理器系統的性能。內存子系統很難協調處理器間的緩存。如果一個被所有處理器使用的只讀數據,和一個由一個處理器使用并頻繁更新的數據共享一個緩存 列,那么緩存將會花費很長時間更新這個緩存列的拷貝。這個Ping-Pong高速游戲通常被稱為"緩存 sloshing"。如果只讀數據在一個不同的緩存 列中,就可以避免sloshing。

對代碼進行空間優化比進行速度優化效率更高。代碼越少,代碼所占的頁也越少,這樣需要的運行設置和產生的頁錯誤也會更少,同時占據的緩存 列也會更少。然而,某些核心函數應該進行速度優化。可以利用profiler去識別這些函數。

3.決不要緩存頻繁使用的數據。

軟件緩存可以被各種應用程序使用。當一個計算代價很高時,你會保存結果的一個拷貝。這是一個典型的時空折中方法:犧牲一些存儲空間以節省時間。如果做得好,這種方法可能非常有效。

你必須正確地進行緩存。如果緩存了錯誤數據,就會浪費存儲空間。如果緩存得太多,其他操作可以使用的內存將會很少。如果緩存得太少,效率又會很低,因為你必須重新計算被緩存 遺漏的數據。如果將時間敏感數據緩存得時間過長,這些數據將會過時。一般,服務器更關心的是速度而不是空間,所以他們要比桌面系統進行更多的緩存。一定要定期去除不用的緩存,否則將會有運行設置問題。

4.應該創建多個線程,越多越好。

  調整服務器中起作用的線程數目是很重要的。如果線程是I/O-bound的,將會花費很多時間用來等待I/O的完成-一個被阻塞的線程就是一個不做任何有用工作的線程。加入額外的線程可以增加通量,但是加入過多的線程將會降低服務器的性能,因為上下文交換將會成為一個重大的overhead。上下文交換速度應該低的原因有三個:上下文交換是單純的overhead,對應用程序的工作沒有任何益處;上下文交換用盡了寶貴的時鐘周期;最糟的是,上下文交換將處理器的緩存填滿了沒用的數據,替換這些數據是代價高昂的。

  有很多事情是依靠你的線程化結構的。每個客戶端一個線程是絕對不合適的。因為對于大量用戶端,它的擴展性不好。上下文交換變得難以忍受,Windows NT用盡了資源。線程池模型會工作得更好,在這種方法中一個工人線程池將處理一條請求列,因為Windows 2000提供了相應的APIs,如QueueUserWorkItem。

5.應該對數據結構使用全局鎖

  使數據線程安全的最簡單方法是把它套上一把大鎖。為簡單起見,所有的東西都用同一把鎖。這種方法會有一個問題:序列化。為了得到鎖,每一個要處理數據的線程都必須排隊等候。如果線程被一把鎖阻塞,它沒有在做任何有用的事。當服務器的負載較輕時,這個問題并不常見,因為一次可能只有一個線程需要鎖。在負載很重的情況下,對鎖的激烈爭奪可能就會成為一個大問題。

  設想在多車道高速公路上發生了一個意外事故,這條高速公路上的所有車輛都被轉向一條狹窄的道路。如果車輛很少,這一轉換對交通流的速率的影響可以忽略。如果車輛很多,當車輛慢慢并入那條單通道時,交通阻塞會延伸幾英里。

  有幾種技術能夠減少鎖競爭。

  · 不要過分保護,也就是說,不是非常必要不要鎖住數據。只有需要時才去持有鎖,而且時間不要過長。不要在大段代碼周圍或頻繁執行的代碼中沒必要地使用鎖,這一點很重要。
  · 對數據進行分割,使它能夠用一套獨立的鎖保護。例如,一個符號表可以按標識符的第一個字母分割,這樣在修改名字以Q開頭的符號的值時,就不會去讀名字以H開頭的符號的值。
  · 使用APIs的Interlocked 系列(InterlockedIncrement,InterlockedCompareExchangePointer等)自動修改數據而不需要鎖。
  · 當數據不是經常被修改時可以使用多讀者/單作者(multi-reader/single-writer)鎖。你將獲得更好的并發性,盡管鎖操作的代價將更高并且你可能會冒餓死作者的危險。
·   在關鍵部分使用循環計數器。參見Windows NT 4.0 service pack 3中的SetCriticalSectionSpinCount API。
  · 如果你不能得到鎖,使用TryEnterCriticalSection并做一些其他的有用的工作。
  高競爭導致serialization,serialization導致降低CPU的利用率,這促使用戶加入更多的線程,結果事情變得更糟。

6.不必注意多處理器機器

  你的代碼在多處理器系統上比在單處理器系統上運行得還要糟,這可能是件令人惡心的事。一個很自然的想法是,在一個N維系統上運行N次會更好。性能很差的原因是競爭:鎖競爭,總線競爭,和/或緩存列競爭。處理器都在是爭奪共享資源的所有權,而不是做更多的工作。

  如果你一定要編寫多線程應用程序的話,你應該在多處理器盒上對你的應用程序進行強度測試和性能測試。單處理器系統通過時間分片地執行線程而提供一個并發性的假象。多處理器盒具有真正的并發性,競爭環境和競爭更容易發生。

  7.應該始終使用模塊化調用;他們很有趣。

  利用同步模塊化調用來執行I/O操作對大多數桌面應用程序來說是合適的。但是,他們不是使用服務器上的CPU(s)的好方法。I/O操作要花費上百萬個時鐘周期來完成,這些時鐘周期本來可以被更好地利用。利用異步I/O你能得到顯著提高的用戶請求率和I/O通量,不過增加了額外的復雜性。

  如果你有需要花費很長時間的模塊化調用或I/O操作,你應該考調撥多少資源給他們。你想使用所有的線程還是有個限制?一般地,使用有限的幾個線程要好些。構建一個小的線程池和隊列,利用隊列來安排線程的工作完成模塊化調用。這樣,其他線程就可以拾取和處理你的非模塊化的請求。

  8.不要進行測量

  當你能夠測量你所談論的事情并用數字表達它時,這就表示你對他有了一定的了解;但是如果你不能用數字表達時,你的知識是貧瘠的不能令人滿意的;這可能是知識的開始,但這時你簡直不可能將你的思想提高到科學的水平。

  - Lord Kelvin (William Thomson)

  如果不測量你就不能了解應用程序的特性。你在黑暗中摸索,一半是靠猜測。如果不識別性能問題,你就不能做任何改進或做出工作量計劃。

  測量包括黑匣子測量和profiling。黑匣子測量的意思是收集由性能計數器(內存使用,上下文交換,CPU利用等)和外部檢測工具(通量,反映時間等)所顯示的數據。為了profile你的代碼,你編譯代碼的一個工具版,然后在各種條件下運行它,并收集關于執行時間和過程調用頻率的統計數據。

  測量如果不用于分析的話就一點用都沒有。測量將不僅告訴你有問題,而且甚至能幫助你找到問題發生在哪,但它不能告訴你為什么會有問題。對問題進行分析以便你能正確地改正他們。要從根本上解決問題而不是停留在表面現象。

  當你進行改動后,要重新測量。你要知道你的改動是否有效。改動也可能會暴露其他性能問題,測量-分析-改正-再測量的循環就會重新開始。你也必須要有規律地進行測量,以便發現性能衰退問題。

 9.應該使用單一用戶,單一請求的測試方法。

  書寫ASP和ISAPI應用程序的一個通病是只用一個瀏覽器去測試應用程序。當他們在Internet上應用他們的程序時,他們才發現他們的應用程序不能處理高負載,并且通量和反應時間另人可憐。

  用一個瀏覽器測試是必要的但是不夠的。如果瀏覽器反應得不夠快,你就知道你有麻煩了。但即使它在使用一個瀏覽器時很快,你也不知道它處理負載的能力如何。如果十幾個用戶同時請求會發生什么事?一百個呢?你的應用程序能容忍什么樣的通量?它能提供什么樣的反應時間?在輕載時這些數字會怎樣?中等負載呢?重載呢?在多處理器機器上你的應用程序會如何?對你的應用程序進行強度測試,這對于找出bugs發現性能問題來說是基本的。
  類似的負載測試考慮適用于所有的服務器應用程序。

  10.不應使用實際環境。

  人們往往只在幾個特定的,人工的環境(如下benchmarks)下調整應用程序。選擇和實際情況相對應的各種情況,并為針對各種操作進行優化,這一點很重要。如果你不這樣做,你的用戶和評論家一定會這樣做,并且他們將依此來評判你的應用程序的好壞。

熱詞搜索:

上一篇:IIS常見問題-解決IIS6上傳文件尺寸太小問題
下一篇:IIS常見問題-IIS 錯誤代碼大匯總

分享到: 收藏
国产一级一区二区_segui88久久综合9999_97久久夜色精品国产_欧美色网一区二区
亚洲成人黄色影院| 国产成人三级在线观看| 国产精品99精品久久免费| 欧美变态tickling挠脚心| 蜜桃视频免费观看一区| 精品国产欧美一区二区| 处破女av一区二区| 一区二区三区在线观看视频| 欧美日本高清视频在线观看| 免费xxxx性欧美18vr| 国产欧美一区二区精品性| 在线日韩av片| 国产精品99久久久久| 亚洲成人免费影院| 欧美激情一区二区三区在线| 欧美在线观看18| 韩国精品一区二区| 亚洲综合丁香婷婷六月香| xvideos.蜜桃一区二区| 欧美日韩在线直播| 成人av电影免费在线播放| 日韩va亚洲va欧美va久久| 国产精品国模大尺度视频| 91精品国产丝袜白色高跟鞋| 国产999精品久久久久久| 亚洲3atv精品一区二区三区| 国产精品每日更新| 日韩精品一区二区三区在线| 欧美综合天天夜夜久久| 国产成人精品免费| 激情久久久久久久久久久久久久久久| 亚洲乱码日产精品bd| 久久色.com| 日韩一级大片在线| 欧美日精品一区视频| av一二三不卡影片| 国产乱色国产精品免费视频| 天天色图综合网| 亚洲综合图片区| 日韩毛片视频在线看| 中文字幕欧美区| 久久综合给合久久狠狠狠97色69| 欧美日韩国产片| 欧美日韩国产天堂| 欧美午夜精品一区二区蜜桃| 91美女在线观看| av电影天堂一区二区在线| 懂色av中文一区二区三区| 国产成人丝袜美腿| 国产99精品视频| 99免费精品在线观看| 成人晚上爱看视频| 99久久精品国产毛片| 99视频一区二区| 91丨九色porny丨蝌蚪| 色综合天天综合网天天狠天天 | 亚洲欧美视频在线观看| 国产精品久久久久婷婷二区次| 国产清纯美女被跳蛋高潮一区二区久久w | 欧美挠脚心视频网站| 欧美日韩一区二区在线观看| 欧美日韩午夜在线视频| 3d动漫精品啪啪| 精品国产乱码久久久久久影片| 精品乱人伦小说| 国产日韩欧美在线一区| 中文字幕一区日韩精品欧美| 亚洲伊人色欲综合网| 亚洲成人免费在线观看| 麻豆精品一区二区三区| 国产iv一区二区三区| 99久久婷婷国产| 51久久夜色精品国产麻豆| 国产午夜三级一区二区三| 一区二区三区在线视频免费| 免费观看日韩电影| 国产成人av电影免费在线观看| 97国产一区二区| 91精品国产乱码久久蜜臀| 国产亚洲精品bt天堂精选| 一区二区三区丝袜| 国产一区二区三区免费播放| 97久久人人超碰| 日韩视频一区二区三区在线播放| 久久嫩草精品久久久久| 一区二区三区在线观看网站| 久久99精品国产91久久来源| 99精品视频免费在线观看| 日韩午夜激情av| 亚洲免费观看视频| 国产一区二区三区免费| 欧美日本精品一区二区三区| 国产欧美精品国产国产专区| 午夜久久久影院| av电影在线观看完整版一区二区| 欧美一级搡bbbb搡bbbb| 亚洲人123区| 国产成人午夜精品影院观看视频| 欧美人与性动xxxx| ...av二区三区久久精品| 麻豆精品一区二区| 欧美色综合影院| 国产精品久久久久久久久免费丝袜| 日本伊人色综合网| 欧美三级在线视频| 亚洲色图在线视频| 高清日韩电视剧大全免费| 日韩免费在线观看| 天天影视色香欲综合网老头| 一本色道久久综合精品竹菊| 中文字幕亚洲一区二区av在线| 国产永久精品大片wwwapp| 5566中文字幕一区二区电影| 亚洲一区二区三区四区在线免费观看 | 午夜精品久久久久久久久| av高清不卡在线| 国产视频视频一区| 精品中文字幕一区二区 | 欧美丰满少妇xxxxx高潮对白| 日韩久久一区二区| 成人免费高清视频在线观看| www国产成人免费观看视频 深夜成人网 | 亚洲免费电影在线| 91麻豆视频网站| 亚洲女人的天堂| 色88888久久久久久影院按摩| 国产精品久久午夜| 成人av在线一区二区| 欧美激情一区三区| 丰满少妇在线播放bd日韩电影| 久久综合久久综合亚洲| 蜜桃视频在线观看一区二区| 日韩精品一区二区三区中文不卡 | 亚洲综合网站在线观看| 欧美色网一区二区| 三级一区在线视频先锋 | 91国产精品成人| 一区二区三区四区国产精品| 欧美无砖专区一中文字| 亚洲va中文字幕| 日韩一级大片在线| 国产一区日韩二区欧美三区| 国产精品二区一区二区aⅴ污介绍| 成人免费看的视频| 亚洲成人在线观看视频| 精品国产一区二区三区四区四 | 图片区小说区国产精品视频| 欧美精品久久天天躁| 另类中文字幕网| 日本一区二区三区免费乱视频| 99精品国产91久久久久久| 亚洲一区在线看| 欧美va亚洲va国产综合| 丁香六月综合激情| 亚洲美女区一区| 欧美高清性hdvideosex| 国产精品一区二区免费不卡| 一区二区三区在线观看国产| 日韩视频免费观看高清完整版| 国产成人在线视频网址| 夜色激情一区二区| 久久一区二区三区四区| 欧美综合一区二区| 国产福利电影一区二区三区| 洋洋av久久久久久久一区| 欧美成人欧美edvon| 91免费国产在线| 经典三级视频一区| 亚洲影视资源网| 国产日韩欧美精品综合| 欧美午夜精品免费| 成熟亚洲日本毛茸茸凸凹| 日本v片在线高清不卡在线观看| 国产精品美女久久久久aⅴ| 日韩一卡二卡三卡四卡| 色哟哟精品一区| 国产美女精品在线| 日韩国产精品91| 亚洲精品视频一区二区| 精品国产乱码久久久久久影片| 欧美在线三级电影| 成人丝袜高跟foot| 国产在线国偷精品免费看| 石原莉奈在线亚洲二区| 一区二区三区视频在线看| 国产精品国产自产拍高清av王其 | 国产精品亚洲第一区在线暖暖韩国| 五月激情六月综合| 一区二区三区在线播放| 亚洲四区在线观看| 欧美国产激情一区二区三区蜜月| 欧美成人综合网站| 欧美一区二区精品| 7777精品伊人久久久大香线蕉超级流畅 | 26uuu成人网一区二区三区| 欧美一级欧美三级| 6080国产精品一区二区| 4hu四虎永久在线影院成人| 欧美日韩国产在线播放网站| 欧美性生活一区|