国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數據庫 > SQL Server > 正文

SqlServer 復制中將大事務分成小事務分發的方法

2024-08-31 01:04:22
字體:
來源:轉載
供稿:網友

在sql server 復制中,當在發布數據庫執行1個大事務時,如一次性操作 十萬或百萬以上的數據。當操作數據在發布數據庫執行完成后 ,日志讀取器代理將掃描事務日志,一次性傳遞到分發數據庫中。若上個事務未傳遞完成,連續執行多個事務,日志讀取器代理將掃描日志中多個事務同時傳遞到分發數據庫中,默認最大掃描500個事務。如果執行多次上百萬或千萬的數據將堵塞很久。

日志讀取器代理可配置將大事務劃分為多個小事務進行傳遞到分發數據庫中,分發隊列則按照小事務分發到訂閱數據庫中,這樣數據就很快同步!

在沒改代理參數之前,本人執行1次插入30萬的數據到發布表中。插入完成后,監控發布到分發的記錄如下:

大事務,小事務,分發,SqlServer

可以看到,這1個事務的命令都得一次傳遞完才能分發,而分發又消耗時間,這里等待太久影響事務的實時性。
如果還有其他事務,默認500(參考參數:-ReadBatchSize),也將一起傳遞,耗時較長。

現在更改參數,掃描到 1000 左右的命令就即時分發,需要設置如下參數:
-MaxCmdsInTran number_of_commands

大事務,小事務,分發,SqlServer

注:該參數只能添加到日志讀取器代理中,在代理配置文件沒有此參數的設置。

添加后重啟 日志讀取器代理。

再次插入 30 萬的數據!~到監視器查看

大事務,小事務,分發,SqlServer

可以看到,命令達到 1000 左右就進行分發了,此時查看訂閱數據庫,數據也同步過來了,這樣就省去了較多掃描命令的時間。
更詳細查看每個事務的命令數,如下:

SELECT top 10 A.xact_seqno,A.entry_time,COUNT(*) AS cmdsFROM distribution.dbo.MSrepl_transactions A(NOLOCK) INNER JOIN distribution.dbo.MSrepl_commands B(NOLOCK) ON A.xact_seqno=B.xact_seqnoGROUP BY A.xact_seqno,A.entry_timeORDER BY cmds DESC

大事務,小事務,分發,SqlServer

這個參數雖好,但是也可能引起數據的一致性。

如:

在發布更新了一批數據,但是訂閱查詢時卻有不同。

分發事務遇到沖突或者死鎖,也導致這部分的數據不一致。


注:相關教程知識閱讀請移步到MSSQL教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 南投县| 安乡县| 乃东县| 浮梁县| 潍坊市| 柳林县| 临沭县| 西平县| 侯马市| 永年县| 鹰潭市| 东乡族自治县| 吴桥县| 黎川县| 资中县| 马关县| 沧源| 闽清县| 淅川县| 勃利县| 孝昌县| 弥勒县| 济宁市| 孟村| 巴青县| 淮北市| 云龙县| 锡林浩特市| 绥滨县| 通渭县| 丰镇市| 睢宁县| 五莲县| 双柏县| 合山市| 大洼县| 台安县| 双流县| 扶余县| 五常市| 屏南县|