FIX: 您記憶體不足時收到錯誤訊息與 Web 同步處理在 SQL Server 2005 或 SQL Server 2008 中使用合併式複寫

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

在此頁中

徵狀

您使用 SQL Server 2005 合併複寫或 SQL Server 2008 合併複寫使用 Web 同步處理基礎訂閱者。記憶體遺漏發生在重複的同步處理之後,並在一段時間後,您可能會收到 「 缺記憶體 」 錯誤。 當主機處理程序不會重新啟動一段很長的時間等搭配-連續參數使用 「 合併代理程式 」 (Replmerg.exe) 時時,這就很明顯或當連續參數指定代理程式設定檔套用至代理程式中。 也這個問題會影響 RMO 應用程式或服務您開發應用程式執行幾天,而不關閉時,在迴圈中執行同步處理。

發生的原因

數個內部的物件會在每個同步處理時遺漏。

解決方案

SQL Server 2005 Service Pack 3

這個問題的修正程式先於累計更新 6 的 SQL Server 2005 Service Pack 3 發行。如更多有關此累積更新套件,按一下 [下面的文件編號,檢視 「 Microsoft 知識庫 」 中的發行項]:
974648SQL Server 2005 Service Pack 3 的累積更新套件 6
附註因為組建是累計,每個新的修正程式版本包含所有 Hotfix 及先前的 SQL Server 2005 隨附所有安全性修正程式都修正發行。Microsoft 建議您考慮安裝最新的修正程式發行版本包含此 Hotfix。如需詳細資訊,請按一下下列的文件編號,檢視 「 Microsoft 知識庫 」 中的文件:
960598SQL Server 2005 會建置發行 SQL Server 2005 Service Pack 3 之後所發行。
Microsoft SQL Server 2005 的 Hotfix 會建立特定的 SQL Server Service Pack。您必須將 SQL Server 2005 Service Pack 3 Hotfix 套用到 SQL Server 2005 Service Pack 3 的安裝。預設狀況下,在 SQL Server Service Pack 中提供任何 Hotfix 包含在下一個 SQL Server Service Pack。

發行版本的 SQL Server 2008

重要如果您執行發行版本的 SQL Server 2008,您必須安裝此修正程式。

這個問題的修正程式先於累計更新 8 發行。如需有關如何取得此累積更新套件的 SQL Server 2008 的詳細資訊,按一下 [下列面的文件編號,檢視 「 Microsoft 知識庫 」 中的發行項]:
975976SQL Server 2008 的累積更新套件 8
附註因為組建是累計,每個新的修正程式版本包含所有 Hotfix 及先前的 SQL Server 2008 隨附所有安全性修正程式都修正版本。我們建議您考慮安裝最新的修正程式發行版本包含此 Hotfix。如需詳細資訊,請按一下下列的文件編號,檢視 「 Microsoft 知識庫 」 中的文件:
956909SQL Server 2008 建置發行 SQL Server 2008 之後所發行

SQL Server 2008 Service Pack 1

重要如果您執行 SQL Server 2008 Service Pack 1,您必須安裝此修正程式。

這個問題的修正程式先於累計更新 5 的 SQL Server 2008 Service Pack 1 發行。如更多有關此累積更新套件,按一下 [下面的文件編號,檢視 「 Microsoft 知識庫 」 中的發行項]:
975977SQL Server 2008 Service Pack 1 的累積更新套件 5
附註因為組建是累計,每個新的修正程式版本包含所有 Hotfix 及先前的 SQL Server 2008 隨附所有安全性修正程式都修正版本。Microsoft 建議您考慮安裝最新的修正程式發行版本包含此 Hotfix。如需詳細資訊,請按一下下列的文件編號,檢視 「 Microsoft 知識庫 」 中的文件:
970365SQL Server 2008 建置發行 SQL Server 2008 Service Pack 1 之後所發行
Microsoft SQL Server 2008 的 Hotfix 會建立特定的 SQL Server Service Pack。您必須將 SQL Server 2008 Service Pack 1 Hotfix 套用至 SQL Server 2008 Service Pack 1 的安裝。預設狀況下,在 SQL Server Service Pack 中提供任何 Hotfix 包含在下一個 SQL Server Service Pack。

狀況說明

Microsoft 已確認<適用於>一節所列之 Microsoft 產品確實有此問題。

其他可行方案

如果要解決這個問題而定,使用 [下列的其中一個方法]:

方法 1

如果您使用合併代理程式 」 以連續模式,定期,停止合併代理程式程序,並重新啟動。

比方說在五天後收到 「 缺記憶體 」 錯誤,並且您合併代理程式 」 排程為作業。然後,您排定新的 SQL Server 代理程式工作,以呼叫 sp_stop_job 後面接著 sp_start_job 指定將循環受影響的處理程序每隔五天您合併代理程式 」 的工作名稱。當您停止合併代理程式 (Replmerg.exe) 處理時,都會釋放任何遺漏的記憶體內部處理序記憶體空間。

如需有關使用方式的詳細資訊-連續參數的上合併] 代理請參閱下列 Microsoft 開發 o 人 h 員 ? 工 u 具 ? 網路 (MSDN) 網站:
http://msdn.microsoft.com/en-us/library/ms147839.aspx

sp_stop_jobhttp://msdn.microsoft.com/en-us/library/ms182793(SQL.90).aspx

sp_start_jobhttp://msdn.microsoft.com/en-us/library/ms186757(SQL.90).aspx

方法 2

如果您使用 [合併代理程式從工作您可能使用額外的步驟,而不是依賴連續參數設定內工作的手動重複循環邏輯。而不是一個合併代理程式程序,內部永遠連續迴圈的排程 「 合併代理程式 」 為作業步驟重複例如每分鐘一次經常為基礎。處理程序將會結束之間重試,並這釋放任何遺漏的記憶體。
編輯工作,以便在之間暫停的迴圈中重複步驟重複合併代理程式。
  1. 後步驟 [3]"偵測非記錄式代理程式關機 」 加入名為一個新步驟 [4] 」 無限的重試 Loop"。 TSQL 和命令來設定類型"waitfor 延遲 ' 0: 00: 05 '",此 TSQL 延遲將提供 5 的第二個暫停其中您可以設定為一種 「 合併代理程式 」 會簡短地暫停執行之間並不執行不斷的輪詢間隔。 在 [進階] 索引標籤中指定為 [移至步驟 [2] 執行代理程式] 和 [On 失敗動作為 「 移至步驟 [2] 的執行代理程式]"On 成功動作"。
  2. 編輯 [2] 的步驟執行代理程式以確保達到迴圈步驟 [4]。 在步驟 [2] 的 [進階] 索引標籤上,設定 On 成功動作,"移至步驟: [4] 無限的重試循環播放 」,並設定在失敗動作,來 「 跳至下一步 」。
  3. 編輯步驟 [3] 偵測非記錄式代理程式關機以確定到達 [4] 的步驟迴圈。在步驟 [3] 的 [進階] 索引標籤上,設定 [On 成功動作,[移至下一步]。您也可以決定是否要讓 [步驟 [3] 上失敗動作?設定為"移至下一步"或"結束作業回報失敗"。若設定為 [結束,則複寫監視器] 和 [工作監視器中顯示工作失敗。如果它被設定成以進到第四個迴圈步驟失敗時,可能會無限期,重新執行 「 合併代理程式 」,無限期地記錄 「 錯誤。

方法 3

同樣地如果使用 RMO 應用程式呼叫 MergeSynchronizationAgent.Synchronize() 方法這會同步處理訂閱者資料庫在迴圈中的停止並重新啟動程序定期釋放任何因為這個問題的遺漏的記憶體。
這個物件和方法相關的更多資訊,請參閱下列 Microsoft 開發 o 人 h 員 ? 工 u 具 ? 網路 (MSDN) 網站: http://msdn.microsoft.com/en-us/library/microsoft.sqlserver.replication.mergesynchronizationagent.synchronize(SQL.90).aspx

?考

如需有關如何使用-連續參數上合併] 代理請造訪下列 Microsoft 開發 o 人 h 員 ? 工 u 具 ? 網路 (MSDN) 網站:
http://msdn.microsoft.com/en-us/library/ms147839.aspx

如需有關 sp_stop_job 預存程序中,請造訪下列 Microsoft 開發 o 人 h 員 ? 工 u 具 ? 網路 (MSDN) 網站]:
http://http://msdn.microsoft.com/en-us/library/ms182793(SQL.90).aspx

如需有關 sp_start_job 預存程序的詳細資訊,請造訪下列 Microsoft 開發 o 人 h 員 ? 工 u 具 ? 網路 (MSDN) 網站]:
http://msdn.microsoft.com/en-us/library/ms186757(SQL.90).aspx

為更多有關如何取得 SQL Server 2005 Service Pack 3,請按一下下面的文件編號,檢視 「 Microsoft 知識庫 」 中的發行項:
913089如何取得最新的 Service Pack,SQL Server 2005 的
如需有關 SQL Server 2005 Service Pack 3 (SP3) 中的新功能,以及關於 SQL Server 2005 SP3 的改進的詳細資訊,請造訪下列 Microsoft 網站]:
http://go.microsoft.com/fwlink/?LinkId=131442
更多有關的 SQL Server 更新命名的結構描述會按一下下列文章編號,檢視發行項 「 Microsoft 知識庫 」 中:
822499Microsoft SQL Server 軟體更新套件的新命名結構描述
如需有關軟體更新術語的詳細資訊,按一下 [下面的文件編號,檢視 「 Microsoft 知識庫 」 中的發行項]:
824684用來描述 Microsoft 軟體更新標準術語的說明

屬性

文章編號: 974660 - 上次校閱: 2009年11月2日 - 版次: 3.2
這篇文章中的資訊適用於:
  • Microsoft SQL Server 2005 Standard Edition
  • Microsoft SQL Server 2005 Enterprise Edition
  • Microsoft SQL Server 2005 Developer Edition
  • Microsoft SQL Server 2005 Workgroup Edition
  • Microsoft SQL Server 2005 Standard X64 Edition
  • Microsoft SQL Server 2005 Enterprise X64 Edition
  • Microsoft SQL Server 2005 Enterprise Edition for Itanium Based Systems
  • Microsoft SQL Server 2008 Developer
  • Microsoft SQL Server 2008 Enterprise
  • Microsoft SQL Server 2008 Standard
  • Microsoft SQL Server 2008 Web
  • Microsoft SQL Server 2008 Workgroup
關鍵字:?
kbmt kbsurveynew kbexpertiseadvanced kbqfe kbfix KB974660 KbMtzh
機器翻譯
重要:本文是以 Microsoft 機器翻譯軟體翻譯而成,而非使用人工翻譯而成。Microsoft 同時提供使用者人工翻譯及機器翻譯兩個版本的文章,讓使用者可以依其使用語言使用知識庫中的所有文章。但是,機器翻譯的文章可能不盡完美。這些文章中也可能出現拼字、語意或文法上的錯誤,就像外國人在使用本國語言時可能發生的錯誤。Microsoft 不為內容的翻譯錯誤或客戶對該內容的使用所產生的任何錯誤或損害負責。Microsoft也同時將不斷地就機器翻譯軟體進行更新。
按一下這裡查看此文章的英文版本:974660
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