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
- 對SQL Server 2014 alwayson 架構的資料庫在主節點加新的datafile檔案SQLServer架構資料庫
- Postgrsql 從節點當機,主節點執行DML語句出現等待情況SQL
- SQLServer2012對現有AlwaysOn群集新加節點SQLServer
- oracle兩節點RAC,由於gipc導致某節點crs無法啟動問題分析Oracle
- runc hang 導致 Kubernetes 節點 NotReady
- 關於Oracle 11G RAC雙節點之間存在防火牆導致只能一個節點執行Oracle防火牆
- mongodb主從仲裁節點配置MongoDB
- FILE+POS 方式 GreatSQL 主從複製架構給主節點磁碟擴容SQL架構
- alicdn邊緣節點不穩定導致頁面崩潰問題
- layer彈框刪除ztree節點非阻塞問題解決
- 搭建PowerDNS+LAP+NFS+MySQL主從半節點同步實現LAMP架構DNSNFSMySqlLAMP架構
- ANALYZE導致的阻塞問題分析
- websphere 受管節點問題Web
- 以太坊公鏈節點連線節點超時問題排查
- 如何執行一個 Conflux 節點UX
- rac新增節點容易遇到的問題
- selenium-grid 有多個節點,但 pytest.main 批次執行用例,每次只有一個節點執行用例,不能同時多個節點執行,要怎樣才能多個節點同時執行AI
- SQLServer 2012 AG主節點無法截斷事務日誌SQLServer
- 多路徑配置問題和ACFS啟用原因導致rac二節點不能正常啟動
- 資料庫——查詢樹形結構某節點的所有子節點、所有父節點資料庫
- 記一次鎖使用不當導致Dubbo執行緒阻塞問題執行緒
- “alter database switchover to xx“過程不當導致的primary-primary 雙主問題Database
- 從Hash Join的執行計劃的細節中能看到點啥
- 從節點崩了,還怎麼「主從讀寫分離」?
- dom4j 根據xml節點路徑查詢節點,找到對應的目標節點下的子節點,對節點Text值進行修改XML
- zookeeper叢集奇偶數節點問題
- JavaScript學習之DOM(節點、節點層級、節點操作)JavaScript
- redis cluster 故障後,主從位於不同節點的修復。Redis
- Geth簡介及如何執行以太坊節點
- rac新增節點容易遇到的問題(11g)
- 11g rac新增節點容易遇到的問題
- Python從頭實現以太坊(二):Pinging引導節點Python
- ORACLE 11.2.0.4 rac for linux 鏈路宕導致的單節點異常當機OracleLinux
- ADAMoracle多節點計算網路預言機架構Oracle架構
- nacos註冊中心單節點ap架構原始碼解析架構原始碼
- 【linux】修改ip後hadoop只有四個節點的問題LinuxHadoop
- consul 多節點/單節點叢集搭建
- Mysql主從架構搭建的時候遇到的問題MySql架構