1. 程式人生 > >SQLServer 訂閱過期解決方法

SQLServer 訂閱過期解決方法

由於分發資料庫執行一個較長的事務,達到了系統預定的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. 設定更長的保質期。