五月综合激情婷婷六月,日韩欧美国产一区不卡,他扒开我内裤强吻我下面视频 ,无套内射无矿码免费看黄,天天躁,日日躁,狠狠躁

新聞動態(tài)

Transactional replication(事務(wù)復(fù)制)詳解之如何跳過一個事務(wù)

發(fā)布日期:2021-12-27 06:43 | 文章來源:腳本之家

在transactional replication, 經(jīng)常會遇到數(shù)據(jù)同步延遲的情況。有時候這些延遲是由于在publication中執(zhí)行了一個更新,例如update ta set col=? Where ?,這個更新包含巨大的數(shù)據(jù)量。在subscription端,這個更新會分解成多條命令(默認情況下每個數(shù)據(jù)行一個命令),應(yīng)用到subscription上。 不得已的情況下,我們需要跳過這個大的事務(wù),讓replication繼續(xù)運行下去。

現(xiàn)在介紹一下transactional replication的一些原理和具體的方法

當publication database的article發(fā)生更新時, 會產(chǎn)生相應(yīng)的日志,Log reader會讀取這些日志信息,將他們寫入到Distribution 數(shù)據(jù)庫的msrepl_transactions和msrepl_commands中。

Msrepl_transactions中的每一條記錄都有一個唯一標識xact_seqno,xact_seqno對應(yīng)日志中的LSN。 所以可以通過xact_seqno推斷出他們在publication database中的生成順序,編號大的生成時間就晚,編號小的生成時間就早。

Distributionagent包含兩個子進程,reader和writer。 Reader負責從Distribution 數(shù)據(jù)庫中讀取數(shù)據(jù),Writer負責將reader讀取的數(shù)據(jù)寫入到訂閱數(shù)據(jù)庫.

reader是通過sp_MSget_repl_commands來讀取Distribution數(shù)據(jù)庫中(讀取Msrepl_transactions表和Msrepl_Commands表)的數(shù)據(jù)

下面是sp_MSget_repl_commands的參數(shù)定義

CREATE PROCEDURE sys.sp_MSget_repl_commands 
( 
@agent_id int, 
@last_xact_seqno varbinary(16), 
@get_count tinyint = 0, -- 0 = no count, 1 = cmd and tran (legacy), 2 = cmd only 
@compatibility_level int = 7000000, 
@subdb_version int = 0, 
@read_query_size int = -1 
) 

這個存儲過程有6個參數(shù),在Transactional replication 中,只會使用前4個(并且第三個參數(shù)和第四個參數(shù)的值是固定不變的.分別為0和10000000)。下面是一個例子:

execsp_MSget_repl_commands 46,0x0010630F000002A900EA00000000,0,10000000

@agent_id表示Distributionagentid,每個訂閱都會有一個單獨的Distributionagent來處理數(shù)據(jù)。 帶入@agent_id后,就可以找到訂閱對應(yīng)的publication 和所有的article。

@last_xact_seqno 表示上一次傳遞到訂閱的LSN。

大致邏輯是:Reader讀取subscription database的MSreplication_subscriptions表的transaction_timestamp列,獲得更新的上一次LSN編號,然后讀取分發(fā)數(shù)據(jù)庫中LSN大于這個編號的數(shù)據(jù)。 Writer將讀取到的數(shù)據(jù)寫入訂閱,并更新MSreplication_subscriptions表的transaction_timestamp列。然后Reader會繼續(xù)用新的LSN來讀取后續(xù)的數(shù)據(jù),再傳遞給Writer,如此往復(fù)。

如果我們手工更新transaction_timestamp列,將這個值設(shè)置為當前正在執(zhí)行的大事務(wù)的LSN,那么distribution agent就會不讀取這個大事務(wù),而是將其跳過了。

下面以一個實例演示一下

環(huán)境如下

Publisher: SQL108W2K8R21

Distributor: SQL108W2K8R22

Subscriber: SQL108W2K8R23

圖中高亮的publication中包含3個aritcles,ta,tb,tc

其中ta包含18,218,200萬數(shù)據(jù),然后我們進行了一下操作

在11:00進行了更新語句,

update ta set c=-11

后續(xù)陸續(xù)對表ta,tb,tc執(zhí)行一些插入操作

insert tb values(0,0)

insert tc values(0,0)

之后我們啟動replication monitor ,發(fā)現(xiàn)有很大的延遲,distribution agent一直在傳遞a)操作產(chǎn)生的數(shù)據(jù)

在subscription database中執(zhí)行下面的語句,得到當前最新記錄的事務(wù)編號

declare @publisher sysname 
declare @publicationDB sysname 
declare @publication sysname 
set @publisher='SQL108W2K8R22' 
set @publicationDB='pubdb' 
set @publication='pubdbtest2'
select transaction_timestamp From MSreplication_subscriptions 
where 
publisher=@publisher and 
publisher_db=@publicationDB and 
publication=@publication 

在我的環(huán)境中,事務(wù)編號為0x0000014900004E9A0004000000000000

返回到distribution database,執(zhí)行下面的語句,得到緊跟在大事務(wù)后面的事務(wù)編號. 請將參數(shù)替換成您實際環(huán)境中的數(shù)據(jù)。(請注意,如果執(zhí)行下列語句遇到性能問題,請將參數(shù)直接替換成值)

declare @publisher sysname 
declare @publicationDB sysname 
declare @publication sysname 
declare @transaction_timestamp [varbinary](16) 
set @publisher='SQL108W2K8R21' 
set @publicationDB='publicationdb2' 
set @publication='pubtest' 
set @transaction_timestamp= 0x0000014900004E9A0004000000000000
select top 1 xact_seqno from MSrepl_commands with (nolock) where xact_seqno>@transaction_timestamp and 
article_id in ( 
  select article_id From MSarticles a inner join MSpublications p on a.publication_id=p.publication_id and a.publisher_id=p.publisher_id and a.publisher_db=p.publisher_db 
  inner join sys.servers s on s.server_id=p.publisher_id 
  where p.publication=@publication and p.publisher_db=@publicationDB and s.name=@publisher 
) 
and publisher_database_id =( 
    select id From MSpublisher_databases pd inner join MSpublications p on pd.publisher_id=p.publisher_id 
    inner join sys.servers s on pd.publisher_id=s.server_id and pd.publisher_db=p.publisher_db 
    where s.name=@publisher and p.publication=@publication and pd.publisher_db=@publicationDB 
) 
Order by xact_seqno

在我的環(huán)境中,事務(wù)編號為0x0000018C000001000171

在subscription database中執(zhí)行下面的語句,跳過大的事務(wù)。請將參數(shù)替換成您實際環(huán)境中的數(shù)據(jù)

declare @publisher sysname
declare @publicationDB sysname 
declare @publication sysname 
declare @transaction_timestamp [varbinary](16) 
set @publisher='SQL108W2K8R22' 
set @publicationDB='pubdb' 
set @publication='pubdbtest2' 
set @transaction_timestamp= 0x0000018C000001000171
update MSreplication_subscriptions set transaction_timestamp=@transaction_timestamp 
where publisher=@publisher and publisher_db=@publicationDB and publication=@publication 

執(zhí)行完成后開啟distribution agent job即可。

接下來您就會發(fā)現(xiàn),事務(wù)已經(jīng)成功跳過,ta在訂閱端不會被更新,后續(xù)的更新會逐步傳遞到訂閱,延遲消失。

版權(quán)聲明:本站文章來源標注為YINGSOO的內(nèi)容版權(quán)均為本站所有,歡迎引用、轉(zhuǎn)載,請保持原文完整并注明來源及原文鏈接。禁止復(fù)制或仿造本網(wǎng)站,禁止在非maisonbaluchon.cn所屬的服務(wù)器上建立鏡像,否則將依法追究法律責任。本站部分內(nèi)容來源于網(wǎng)友推薦、互聯(lián)網(wǎng)收集整理而來,僅供學(xué)習參考,不代表本站立場,如有內(nèi)容涉嫌侵權(quán),請聯(lián)系alex-e#qq.com處理。

實時開通

自選配置、實時開通

免備案

全球線路精選!

全天候客戶服務(wù)

7x24全年不間斷在線

專屬顧問服務(wù)

1對1客戶咨詢顧問

在線
客服

在線客服:7*24小時在線

客服
熱線

400-630-3752
7*24小時客服服務(wù)熱線

關(guān)注
微信

關(guān)注官方微信
頂部