婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > Transactional replication(事務復制)詳解之如何跳過一個事務

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

熱門標簽:400外呼系統合法 電銷機器人被曝光 廣州人工電銷機器人費用 如何在地圖標注自己店鋪 地圖標注一個圓圈怎么用 寧波人工外呼系統有效果嗎 真人語音電銷機器人 洛陽外呼系統平臺 怎樣把地圖標注導入公司地址

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

現在介紹一下transactional replication的一些原理和具體的方法

當publication database的article發生更新時, 會產生相應的日志,Log reader會讀取這些日志信息,將他們寫入到Distribution 數據庫的msrepl_transactions和msrepl_commands中。 

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

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

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

下面是sp_MSget_repl_commands的參數定義

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個參數,在Transactional replication 中,只會使用前4個(并且第三個參數和第四個參數的值是固定不變的.分別為0和10000000)。下面是一個例子:

execsp_MSget_repl_commands 46,0x0010630F000002A900EA00000000,0,10000000

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

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

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

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

下面以一個實例演示一下

環境如下

Publisher: SQL108W2K8R21

Distributor: SQL108W2K8R22

Subscriber: SQL108W2K8R23

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

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

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

update ta set c=-11

后續陸續對表ta,tb,tc執行一些插入操作

insert tb values(0,0)

insert tc values(0,0)

之后我們啟動replication monitor ,發現有很大的延遲,distribution agent一直在傳遞a)操作產生的數據

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

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 

在我的環境中,事務編號為0x0000014900004E9A0004000000000000

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

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

在我的環境中,事務編號為0x0000018C000001000171

在subscription database中執行下面的語句,跳過大的事務。請將參數替換成您實際環境中的數據

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 

執行完成后開啟distribution agent job即可。

接下來您就會發現,事務已經成功跳過,ta在訂閱端不會被更新,后續的更新會逐步傳遞到訂閱,延遲消失。

您可能感興趣的文章:
  • spring 中事務注解@Transactional與trycatch的使用
  • Spring事務注解@Transactional失效的八種場景分析
  • 解決@Transactional注解事務不回滾不起作用的問題
  • Java注解@Transactional事務類內調用不生效問題及解決辦法
  • Spring聲明式事務@Transactional知識點分享
  • springboot中事務管理@Transactional的注意事項與使用場景
  • 淺談Spring中@Transactional事務回滾及示例(附源碼)
  • 基于Transactional事務的使用以及注意說明

標簽:煙臺 石家莊 北海 晉中 東營 珠海 咸寧 南昌

巨人網絡通訊聲明:本文標題《Transactional replication(事務復制)詳解之如何跳過一個事務》,本文關鍵詞  Transactional,replication,事務,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Transactional replication(事務復制)詳解之如何跳過一個事務》相關的同類信息!
  • 本頁收集關于Transactional replication(事務復制)詳解之如何跳過一個事務的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    亚洲精品成人在线| 久久婷婷国产综合国色天香| 国产精品66部| 久久精品国内一区二区三区| 一区二区三区欧美亚洲| 国产精品二三区| 国产午夜精品一区二区三区嫩草 | 欧美一区二区三区白人| 欧美情侣在线播放| 欧美日韩专区在线| 在线观看国产精品网站| 一本一本大道香蕉久在线精品| 风间由美一区二区三区在线观看| 国产一区二区免费看| 韩国av一区二区三区在线观看| 久久成人综合网| 精东粉嫩av免费一区二区三区 | 2024国产精品视频| 精品国产一区二区三区久久久蜜月| 欧美精品一卡二卡| 欧美成人一区二区| 国产偷国产偷精品高清尤物| 18成人在线观看| 一片黄亚洲嫩模| 天天综合色天天综合色h| 婷婷久久综合九色综合伊人色| 日本麻豆一区二区三区视频| 免费成人在线网站| 国产精品1区2区| 99精品黄色片免费大全| 欧美自拍偷拍午夜视频| 欧美电影免费观看完整版| 26uuu精品一区二区在线观看| 中文字幕不卡在线观看| 亚洲卡通动漫在线| 毛片基地黄久久久久久天堂| 国产99一区视频免费 | 亚洲精品乱码久久久久久黑人| 亚洲在线中文字幕| 狠狠狠色丁香婷婷综合久久五月| 粉嫩av一区二区三区| 色婷婷综合久久| 日韩一区二区三区四区五区六区| 欧美高清在线精品一区| 亚洲五码中文字幕| 国产成人丝袜美腿| 欧美日韩高清一区二区| 久久亚洲影视婷婷| 亚洲综合另类小说| 国产99久久久国产精品潘金 | 亚洲免费在线电影| 久久av资源站| 一本一道久久a久久精品综合蜜臀| 欧美mv和日韩mv国产网站| 一区二区三区不卡在线观看 | 久久丝袜美腿综合| 亚洲网友自拍偷拍| 成人黄动漫网站免费app| 在线综合+亚洲+欧美中文字幕| 中文字幕亚洲在| 国产一区二区三区av电影| 欧美色偷偷大香| 中文字幕一区二区三区四区不卡| 捆绑调教美女网站视频一区| 欧美三级电影网站| 一区二区在线观看视频| 国产v综合v亚洲欧| 精品蜜桃在线看| 日本色综合中文字幕| 91成人在线观看喷潮| 一区免费观看视频| 国产成人av在线影院| 欧美精品一区二区三区四区 | 日韩在线观看一区二区| 色综合久久久网| 国产精品女主播av| 国产精品99精品久久免费| 日韩限制级电影在线观看| 午夜久久福利影院| 欧美日韩精品免费| 午夜天堂影视香蕉久久| 欧美日韩精品久久久| 亚洲综合免费观看高清在线观看| 日本精品视频一区二区| 亚洲精品高清在线观看| 日本乱人伦一区| 亚洲国产精品欧美一二99| 91精品福利在线| 一区二区三区自拍| 欧美性生交片4| 婷婷开心久久网| 91精品国产综合久久久久久久| 日韩高清电影一区| 精品国产一区二区在线观看| 国产酒店精品激情| 中文字幕一区二区三区蜜月| 色8久久人人97超碰香蕉987| 午夜精品aaa| 精品美女一区二区三区| 国产福利精品导航| 亚洲日本青草视频在线怡红院| 91福利视频网站| 日本午夜精品一区二区三区电影| 久久综合狠狠综合久久综合88| 成人精品鲁一区一区二区| 亚洲欧美日韩电影| 91精品啪在线观看国产60岁| 黄色小说综合网站| 中文字幕日韩欧美一区二区三区| 欧美性大战久久久久久久| 青青国产91久久久久久| 中文字幕第一区第二区| 欧美日韩免费观看一区三区| 久久99久久久久| 国产精品美女久久久久av爽李琼 | 一区二区三区中文字幕电影| 欧美一区二区三区视频| 成人精品gif动图一区| 婷婷成人激情在线网| 中文幕一区二区三区久久蜜桃| 91精品办公室少妇高潮对白| 九九视频精品免费| 亚洲国产综合人成综合网站| 久久精品视频免费观看| 欧美日韩一区视频| 成人av在线一区二区三区| 香蕉久久夜色精品国产使用方法| 久久午夜色播影院免费高清| 欧美三电影在线| 成人激情校园春色| 蜜桃精品视频在线| 亚洲一区在线观看免费 | 国产一区二区剧情av在线| 亚洲一区免费视频| 中文一区二区在线观看| 欧美一区二区免费观在线| 色老综合老女人久久久| 国产成人精品免费一区二区| 日本视频在线一区| 一区二区三区四区在线| 国产精品乱码人人做人人爱 | 麻豆成人免费电影| 亚洲综合男人的天堂| 亚洲国产精品v| 欧美成人vps| 宅男在线国产精品| 在线免费观看日韩欧美| 成人激情文学综合网| 国产一区二区三区免费播放| 麻豆精品视频在线观看免费| 亚洲v中文字幕| 亚洲精品日韩专区silk| 亚洲男人的天堂av| 亚洲欧美色图小说| 成人免费在线观看入口| 国产精品久久久久一区二区三区| 欧美激情一区二区三区四区| 欧美激情艳妇裸体舞| 亚洲精品一区二区三区影院| 欧美精品一区二区三区高清aⅴ| 在线成人免费视频| 欧美日韩激情一区二区三区| 欧美日韩一区二区三区高清| 欧美日韩亚洲国产综合| 欧美日韩一区二区三区不卡| 欧美人体做爰大胆视频| 91精品国产乱| 欧美成人一区二区| 久久久久久免费网| 国产日韩欧美高清在线| 中文字幕色av一区二区三区| 日韩毛片精品高清免费| 亚洲在线观看免费| 日本视频中文字幕一区二区三区| 久久精品久久久精品美女| 国产一区在线观看麻豆| 成人午夜在线免费| 91美女福利视频| 欧美高清视频在线高清观看mv色露露十八| 欧美日韩视频在线观看一区二区三区| 7777精品伊人久久久大香线蕉超级流畅| 欧美日韩三级一区| 久久久久亚洲蜜桃| 亚洲色图欧洲色图| 视频一区二区三区在线| 国产一区亚洲一区| 91免费精品国自产拍在线不卡| 欧美日本免费一区二区三区| 精品国产91久久久久久久妲己| 国产精品欧美综合在线| 婷婷综合五月天| 国产999精品久久久久久| 色噜噜狠狠一区二区三区果冻| 日韩欧美国产一二三区| 最新欧美精品一区二区三区| 香蕉久久一区二区不卡无毒影院 | 精品综合免费视频观看| 91啪亚洲精品| 日韩欧美一级特黄在线播放| 国产精品不卡在线观看|