Sqlserver 2014 alwayson架構主節點執行alter table導致從節點的阻塞問題

ywxj_001發表於2017-12-17
環境:
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操作可以同步到只讀節點上,阻塞解決,同步也恢復正常。




來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/22996654/viewspace-2148782/,如需轉載,請註明出處,否則將追究法律責任。

相關文章