UnmapViewOfFile 函式發生效能降低的情況

文章翻譯 文章翻譯
文章編號: 815227 - 檢視此文章適用的產品。
全部展開 | 全部摺疊

在此頁中

徵狀

使用對應檔案檢視大於 500 MB 的程式,可能會遭遇效能明顯降低的情況。對應檔案檢視常用以在兩個以上的處理程序間分享資訊。效能降低的情況是發生在 UnmapViewOfFile 函式中。

發生的原因

如果在您所安裝的 Microsoft Windows Server 2003 或 Microsoft Windows XP Service Pack 1 (SP1) 中程式對應的檔案檢視大於 500 MB 便會發生本問題。

解決方案

Windows XP Service Pack 1

Service Pack 資訊

如果要解決這個問題,請取得最新版的 Windows XP Service Pack。如需詳細資訊,請按一下下面的文件編號,檢視「Microsoft 知識庫」中的文件:
322389 如何取得最新版 Windows XP Service Pack

Hotfix 資訊

目前 Microsoft 已提供支援的 Hotfix,但是其目的只為修正本文中所描述的問題。請只在發生此特定問題的系統上套用這個 Hotfix。這個 Hotfix 可能會接受其他測試。因此,如果此問題沒有對您造成嚴重影響,Microsoft 建議您等候下一版包含此 Hotfix 的 Service Pack。

如果要解決這個問題,請向 Microsoft Online Customer Services 提出取得此 Hotfix 的要求。如果要線上提交取得此 Hotfix 的要求,請造訪下列 Microsoft 網站:
http://go.microsoft.com/?linkid=6294451
注意 如果發生其他問題,或者需要進行任何疑難排解,您必須另外建立一份服務要求。一般來說,如果有其他支援問題是所描述的此特定 Hotfix 無法解決的,才會收取支援費用。如果要另外建立一份服務要求,請造訪下列 Microsoft 網站:
http://support.microsoft.com/contactus/?ws=support
此 Hotfix 的英文版具有下表中所列的檔案屬性 (或更新的檔案屬性)。這些檔案的日期和時間是以 Coordinated Universal Time (UTC) 表示。當您檢視檔案資訊時,它會轉換成當地時間。如果要查看 UTC 與當地時間的差異,請使用 [控制台] 中 [日期和時間] 工具的 [時區] 索引標籤。
摺疊此表格展開此表格
日期時間版本大小檔名平台
28-Feb-200316:175.1.2600.11781,895,424Ntkrnlmp.exei386
28-Feb-200316:175.1.2600.11781,951,232Ntkrnlpa.exei386
28-Feb-200316:175.1.2600.11781,923,584Ntkrpamp.exei386
28-Feb-200316:175.1.2600.11781,927,424Ntoskrnl.exei386
28-Feb-200316:175.1.2600.11785,826,432Ntkrnlmp.exeia-64
28-Feb-200316:175.1.2600.11785,736,704Ntoskrnl.exeia-64

Windows Server 2003

然而問題發生在呼叫 UnmapViewOfFile 函式時,則必須在核心內部進行必要的程式碼變更。由於可能變更核心記憶體管理函式,因此將不會提供 Windows Server 2003 的 Hotfix。Windows Server 2003 Service Pack 1 中有提供 Windows Server 2003 的程式碼修正。

您可使用 [效能監視器] 找出受到這個問題影響的程式。如果要執行這項操作,請依照下列步驟執行:
  1. 您可以根據「Microsoft 知識庫」文件 248345 中所描述的步驟,或使用 [效能監視器精靈] 建立效能監視器記錄。
    如需詳細資訊,請按一下下面的文件編號,檢視「Microsoft 知識庫」中的文件:
    248345 如何使用 Windows 中的「系統監視器」建立記錄
  2. 記錄忙碌期間的伺服器活動。
  3. 停止效能監視器記錄,並檢視 [處理程序效能] 物件下的 [Working Set Size Peak]。找出工作組大小超過 500 MB 的所有處理程序。
  4. 在對應 [私用位元組] 記錄 ([處理程序效能] 物件下) 中,減去您於步驟 3 中找到的每一個處理程序的工作組大小值。
如果處理程序的工作組比私用位元組大 500 MB,則程式可能使用大量檔案對應檢視,因而在呼叫 UnmapViewOfFile 函式時便可能受效能降低的影響。 如果這些程式很長一段時間都沒有回應,則可能需要進行偵錯分析或程式碼檢視,以確認這些程式是否受到這個問題的影響。

如果程式確實受到此效能問題的影響,那麼在使用 Windows Server 2003 Service Pack 1 之前,可以透過下列 Windows Server 2003 適用的程式碼解決方法:
  1. 移除 Windows Server 2003 所執行程式的 UnmapViewOfFile 函式呼叫。只在處理程序必須將多個記憶體區段對應至同一記憶體位址時,才需要這個函式呼叫。作業系統會在最後一個執行緒結束時,清除共用區段。
  2. 如果您必須呼叫 UnmapViewViewOfFile 函式,請撰寫能夠建立工作物件 (CreateJobObject) 的新程式。設定 _JOBOBJECT_BASIC_LIMIT_INFORMATION 參數中的 MaximumWorkingSetSize 屬性,便能夠使用 SetInformationJobObject 函式將工作組大小上限設定為 500 MB (這個設定為 24 MB ,並具有 /3GB 參數)。將所有必要的處理程序與本工作物件建立關聯。
應該在所需處理程序啟動之後執行這個程式 。如果其中一個處理程序重新啟動,則必須重新執行這個程式。如果限制處理程序的工作組大小,則可能不會發生嚴重的效能減損情況。如果系統上仍有許多可用的 RAM ,則從處理程序工作組所移除的分頁,將會置於待命清單上。如果發生分頁錯誤,則在實體記憶體中便很可能是由待命清單上的分頁來處理。請務必執行效能基準測試以判斷此解決方法對效能的實際影響。

狀況說明

Microsoft 已確認本篇文章<適用於>一節所列之 Microsoft 產品確實有上述問題。 這個問題最早已在 Microsoft Windows XP Service Pack 2 中獲得修正。 此問題預定將會在 Windows Server 2003 Service Pack 1 中獲得修正。

屬性

文章編號: 815227 - 上次校閱: 2007年9月7日 - 版次: 6.0
這篇文章中的資訊適用於:
  • Microsoft Windows Server 2003, Datacenter Edition (32-bit x86)
  • Microsoft Windows Server 2003, Enterprise Edition
  • Microsoft Windows Server 2003, Standard Edition (32-bit x86)
  • Microsoft Windows Server 2003, Web Edition
  • Microsoft Windows XP Home Edition SP1
  • Microsoft Windows XP Professional SP1
關鍵字:?
kbtshoot kbbug kbfix kbqfe kbenv kbwinxpsp2fix kbwinxppresp2fix kbhotfixserver KB815227
Microsoft及(或)其供應商不就任何在本伺服器上發表的文字資料及其相關圖表資訊的恰當性作任何承諾。所有文字資料及其相關圖表均以「現狀」供應,不負任何擔保責任。Microsoft及(或)其供應商謹此聲明,不負任何對與此資訊有關之擔保責任,包括關於適售性、適用於某一特定用途、權利或不侵權的明示或默示擔保責任。Microsoft及(或)其供應商無論如何不對因或與使用本伺服器上資訊或與資訊的實行有關而引起的契約、過失或其他侵權行為之訴訟中的特別的、間接的、衍生性的損害或任何因使用而喪失所導致的之損害、資料或利潤負任何責任。

提供意見

 

Contact us for more help

Contact us for more help
Connect with Answer Desk for expert help.
Get more support from smallbusiness.support.microsoft.com