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架構
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/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- Sqlserver 2014 主從兩節點用指令碼完成alwayson搭建SQLServer指令碼
- Sqlserver 2014 alwayson 架構新增輔助節點上的資料庫SQLServer架構資料庫
- 刪除alwayson主節點一個表的統計資訊導致一個輔助節點的同步延遲
- Sqlserver 2014 alwayson故障轉移群集節點被踢出群集SQLServer
- 對SQL Server 2014 alwayson 架構的資料庫在主節點加新的datafile檔案SQLServer架構資料庫
- Postgrsql 從節點當機,主節點執行DML語句出現等待情況SQL
- oracle兩節點RAC,由於gipc導致某節點crs無法啟動問題分析Oracle
- mongodb主從仲裁節點配置MongoDB
- 關於Oracle 11G RAC雙節點之間存在防火牆導致只能一個節點執行Oracle防火牆
- 一次心跳網路問題導致的節點新增失敗
- SQLServer2012對現有AlwaysOn群集新加節點SQLServer
- 搭建PowerDNS+LAP+NFS+MySQL主從半節點同步實現LAMP架構DNSNFSMySqlLAMP架構
- 點陣圖索引導致的會話阻塞問題(p7)索引會話
- multicast導致節點無法加入叢集AST
- layer彈框刪除ztree節點非阻塞問題解決
- websphere 受管節點問題Web
- inode節點耗盡導致資料庫OOM資料庫OOM
- ANALYZE導致的阻塞問題分析
- 以太坊公鏈節點連線節點超時問題排查
- 單節點執行ASM例項ASM
- RAC節點之間通訊問題 兩節點 11g RAC
- dom4j 根據xml節點路徑查詢節點,找到對應的目標節點下的子節點,對節點Text值進行修改XML
- 從Hash Join的執行計劃的細節中能看到點啥
- ROSE HA切換節點導致DG失敗、恢復ROS
- Linux,Network manager 導致節點異常重啟Linux
- 同時開啟節點導致資料DDL操作慢 ??
- 在多節點的叢集上執行Cassandra
- 如何執行一個 Conflux 節點UX
- RAC中job會在哪個節點執行
- JavaScript學習之DOM(節點、節點層級、節點操作)JavaScript
- 解決Linux索引節點(inode)用滿導致故障的方法Linux索引
- Linux索引節點(inode)用滿導致的一次故障Linux索引
- OpenStack 多臺計算節點時的問題
- 某資料庫的節點4因網路問題,主機關閉資料庫
- redis cluster 故障後,主從位於不同節點的修復。Redis
- alwayson只讀節點資料檔案的磁碟被寫滿
- 索引節點(inode)爆滿問題處理索引
- RAC 雙節點 轉單節點流程