您好,登錄后才能下訂單哦!
如何解決Sqlserver 2014 alwayson架構主節點執行alter table導致從節點的阻塞問題,針對這個問題,這篇文章詳細介紹了相對應的分析和解答,希望可以幫助更多想解決這個問題的小伙伴找到更簡單易行的方法。
環境:
sqlserver 2014 alwayson架構
1個主節點
1個standby節點
6個只讀節點
問題展現:
一臺只讀節點出現阻塞,主節點無法同步數據到這個只讀節點。
問題原因:
在主節點執行了一個DDL語句,對一個表的字段類型進行了修改。
ALTER TABLE table1 ALTER COLUMN [Name] [NVARCHAR] (MAX)
此時正好只讀庫有一個關于table1表的長事務查詢。
這個table1表的長事務查詢阻塞了主節點執行ALTER TABLE table1 ALTER COLUMN [Name] [NVARCHAR] (MAX)對只讀庫的同步。
導致在只讀節點上的table1表無法執行alter table操作。
這樣導致所有的主節點的日志都無法從主節點同步到這個只讀節點上。
而只讀節點上所有后面對table1表的查詢都被阻塞了。
查詢主從同步腳本:
SELECT availability_mode_desc ,
role_desc ,
replica_server_name ,
last_redone_time ,
GETDATE() now ,
DATEDIFF(ms, last_redone_time, GETDATE()) diffMS
FROM ( ( sys.availability_groups AS ag
JOIN sys.availability_replicas AS ar ON ag.group_id = ar.group_id
)
JOIN sys.dm_hadr_availability_replica_states AS ar_state ON ar.replica_id = ar_state.replica_id
)
JOIN sys.dm_hadr_database_replica_states dr_state ON ag.group_id = dr_state.group_id
AND dr_state.replica_id = ar_state.replica_id;
解決辦法:
為了盡快解決此問題,最快的辦法是殺掉那個只讀節點上的長事務查詢的session
讓主節點的這個alter table的DDL操作可以同步到只讀節點上,阻塞解決,同步也恢復正常。
關于如何解決Sqlserver 2014 alwayson架構主節點執行alter table導致從節點的阻塞問題問題的解答就分享到這里了,希望以上內容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關注億速云行業資訊頻道了解更多相關知識。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。