SQLServer 訂閱到期解決方案

來源:互聯網
上載者:User

標籤:src   pre   sqlserver   無效   ora   str   log   tor   alt   

原文: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<>2update sub set status = 2from distribution.dbo.MSsubscriptions sub where status<>2 and publication_id=27

執行之後,重新關閉和啟動該分發代理作業,很快,複製正常了!~



在發布和訂閱庫測試操作資料,同步正常!總是完成了!~


註:即使訂閱到期或處於不活動狀態,訂閱伺服器中的更新仍會傳播到發行伺服器中。


此外,由於系統預設最大事務保質期為72小時,如果有事務在這期間沒有傳遞到訂閱,則“清除分發”作業標記為停用,該訂閱的事務將被清空。如果訂閱到期超過336小時(14天),則訂閱將被“到期的訂閱清除” 作業執行刪除。(更多參考訂閱到期和停用)

為了避免到期導致的問題,有兩種方法設定:

1. 禁用“到期的訂閱清除” 作業;

2. 設定更長的保質期。






本文出自“Hello.KK (SQL Server)”的部落格,轉載請務必保留此出處http://blog.csdn.net/kk185800961/article/details/46688827


SQLServer 訂閱到期解決方案

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.