對 容錯移轉叢集 執行錯誤排除時,將需要分析 Windows cluster log (Cluster.log)。
可以使用 PowerShell 的 Get-ClusterLog 來產生 全部 或是 指定 節點伺服器的系統記錄檔。
本文以 [SQL Server] AlwaysOn, Error 41131, failover failed,容錯移轉 失敗 為例
逐步帶領各位使用 PowerShell 的 Get-ClusterLog 來產生 Cluster.log,執行 錯誤排除 [NT AUTHORITY\SYSTEM] 帳戶權限不足 的問題。
目的:產生 Failover Cluster log
作業系統:Windows 2008 R2/2012/2012 R2/2016 Cluster
請使用 「系統管理員身分」來啟動 「Windows PowerShell ISE」
提醒:請到各個 Node Server 去檢視 log。
-- 為每個 Node Server 產生 Failover Cluster log, -- 並存放於預設的本機路徑:C:\Windows\Cluster\Reports -- -UseLocalTime:採用 LocalTime,若未指定此參數,將使用 Greenwich Mean Time (GMT)。 Get-ClusterLog -Destination . -UseLocalTime-- 010_執行Get-ClusterLog
data:image/s3,"s3://crabby-images/e87a6/e87a61835f558f116a95d00f63017b81ba246b72" alt=""
-- 011_檢視產生的 Failover_Cluster_log
data:image/s3,"s3://crabby-images/ae265/ae2650ca33729826847334511ee304271b320a41" alt=""
[PowerShell] Get-ClusterLog: Generate Windows cluster log for troubleshooting
工作01. 使用 [PowerShell] Get-ClusterLog: 產生 Windows cluster log
-- 語法 Get-ClusterLog –Node [SQL Server node name] –TimeSpan 15
-- 範例 Get-ClusterLog –Node AGN02 –TimeSpan 15
-TimeSpan |
指定要產生 Cluster.log 的時間間距,以分鐘為單位。
例如:–TimeSpan 15,是指產生最近 15 分鐘內的 Cluster.log。
|
- Node | 指定需要產生 Cluster.log 節點伺服器。 |
-UseLocalTime | 採用 LocalTime,若未指定此參數,將使用 Greenwich Mean Time (GMT) |
Cluster.log |
系統紀錄 Cluster.log 預設是存放在 %WINDIR%\cluster\reports。
例如:C:\Windows\Cluster\Reports。
|
-- 01_01_PowerShell 產生 Windows cluster log
data:image/s3,"s3://crabby-images/73044/73044216a2a0eadf6aac3b32f781250b230c8095" alt=""
工作02. 分析 Windows cluster log(Cluster.log)
分析 Cluster.log
搜尋以下文字:
Failed to run diagnostics command.
The user does not have permission to perform this action.
-- 02_檢視Cluster_Log
data:image/s3,"s3://crabby-images/e7c74/e7c7444522adac04e929cfeeb07fbda9465791a7" alt=""
-- 03_查詢到相關聯的錯誤_The user does not have permission to perform this action.
data:image/s3,"s3://crabby-images/835ba/835ba3090b6ca2c66d3cf078de1ddf18a6d890b9" alt=""
分析
在 Cluster.log 報告中,可以看到系統紀錄了 權限不足 的問題。
這是因為 [NT AUTHORITY\SYSTEM] 帳戶的權限不足,無法執行 「健全狀況」的偵測,也無法執行 「容錯移轉(Failover) 」。
解決方案
賦予 [NT AUTHORITY\SYSTEM] 帳戶以下權限來解決問題:
- Alter Any Availability Group
- Connect SQL
- View server state
參考
補充資訊
-- 10_Error_41131
data:image/s3,"s3://crabby-images/64260/64260d0746c09b8be24a1cc63d3b8e3233879466" alt=""
-- 30_SQL_Log
data:image/s3,"s3://crabby-images/c5f5f/c5f5f7fc07af2fd47153b2578c19ac2910b45ac1" alt=""
-- 31_發出Failover
data:image/s3,"s3://crabby-images/a639e/a639e76a4f2f5ede5b45ae3f4c12622c193d0abe" alt=""
-- 32_Error_Reported_02_TO_01
data:image/s3,"s3://crabby-images/26289/26289fee40173117c39e9659fab4b9a556e3d6d1" alt=""
-- 33_RESOLVING_PENDING_FAILOVER
data:image/s3,"s3://crabby-images/8b811/8b8113076b8b9a1f024f913e7f051b72dc62f61c" alt=""
-- 34_state_change
data:image/s3,"s3://crabby-images/3b7f8/3b7f8abd3002d30562b5982f643d6df9bda5c005" alt=""
-- 35_Rollback_Failover
data:image/s3,"s3://crabby-images/648db/648dbb7d7c3083593128e20c3ae9023625b40b9e" alt=""
-- 36_state_change__SECONDARY_NORMAL
data:image/s3,"s3://crabby-images/fe1d0/fe1d0e4351d1190870d994dc75da8bccdd2ca83a" alt=""
-- 50_SQL_Log
data:image/s3,"s3://crabby-images/a0a90/a0a90912f39fa46b486edaa2525974d02f09b53e" alt=""
-- 51_發出 Failover
data:image/s3,"s3://crabby-images/7ccd3/7ccd3c451ec107e93c0f1c7b752fcce41ae877a1" alt=""
參考文件
[SQL Server] AlwaysOn, Error 41131, failover failed,容錯移轉 失敗
http://sharedderrick.blogspot.tw/2017/07/sql-server-alwayson-error-41131.html
Cannot create a high-availability group in Microsoft SQL Server 2012
https://support.microsoft.com/en-us/help/2847723/cannot-create-a-high-availability-group-in-microsoft-sql-server-2012
Windows Server 2008 R2: Troubleshooting Failover Clusters
https://technet.microsoft.com/en-us/library/hh272674.aspx
Microsoft.FailoverClusters.PowerShell
https://technet.microsoft.com/en-us/library/ee461009.aspx
Get-ClusterLog
https://technet.microsoft.com/itpro/powershell/windows/failoverclusters/get-clusterlog
沒有留言:
張貼留言