SQLServer 訂閱過期解決方法
阿新 • • 發佈:2019-01-05
由於分發資料庫執行一個較長的事務,達到了系統預定的72小時,導致了該訂閱過期,資料庫分發代理已不可再啟用,提示錯誤如下:
錯誤資訊:已將此(這些)訂閱標記為不活動,必須將其重新初始化。需要刪除 NoSync 訂閱,然後重新建立它們
右鍵訂閱,發現該訂閱已處於不活的狀態!~
怎麼解決?難道要重新初始化??!
後來找到一個系統的儲存過程 sp_changesubstatus,該儲存過程可以更改訂閱的3種狀態:active 、inactive、subscribed。
--此儲存過程在釋出伺服器的釋出資料庫中執行 exec sp_changesubstatus @publication = 'your publication name' ,@subscriber = 'your subscriber name' ,@status = 'active'
執行之後,重新關閉和啟動該分發代理作業,發現沒有作用!~提示還是一樣!~後來發現,如果訂閱過期,該儲存過程是無法更改的,更改無效!~
關於訂閱的活動狀態,還有一個地方可以更改,即更改分發庫中的一個表 MSsubscriptions 的狀態欄位(0 = 不活動;1 = 已訂閱;2 = 活動),訂閱中的每個已釋出專案在MSsubscriptions表中佔一行。
--select * from distribution.dbo.MSpublications --select * from distribution.dbo.MSsubscriptions where status<>2 update sub set status = 2 from distribution.dbo.MSsubscriptions sub where status<>2 and publication_id=27
執行之後,重新關閉和啟動該分發代理作業,很快,複製正常了!~
在釋出和訂閱庫測試操作資料,同步正常!總是完成了!~
注:即使訂閱過期或處於不活動狀態,訂閱伺服器中的更新仍會傳播到釋出伺服器中。
此外,由於系統預設最大事務保質期為72小時,如果有事務在這期間沒有傳遞到訂閱,則“清除分發”作業標記為停用,該訂閱的事務將被清空。如果訂閱過期超過336小時(14天),則訂閱將被“過期的訂閱清除” 作業執行刪除。(更多參考訂閱過期和停用)
為了避免過期導致的問題,有兩種方法設定:
1. 禁用“過期的訂閱清除” 作業;
2. 設定更長的保質期。