監視 Linux 上 SQL 執行個體遭封鎖的工作階段。注意: 根據預設會停用此監視器。如有需要,請使用覆寫加以啟用。
封鎖工作階段監視器會偵測封鎖情況是否存在。
如果有一個工作階段在某一項特定資源上保持鎖定,而另一個工作階段嘗試要在同一項資源上取得衝突的鎖定類型,這種情況就會發生封鎖。封鎖是任何具備鎖定式並行處理功能的關聯式資料庫管理系統 (RDBMS) 所無法避免的特性。但是太多封鎖卻會造成效能的問題。
如果鎖定和封鎖增加到會對系統效能造成明顯的影響,通常是下列其中一個原因所造成:
工作階段對一組資源保持鎖定,而且根本不釋放。通常是下列原因造成:
未復原的已取消查詢
被遺棄的交易
工作階段(由 session_id 或 “SPID” 識別)對一組資源長時間保持鎖定,然後才釋放。通常是下列原因造成:
長時間執行的交易
缺少適當的索引
鎖定提示使用不當
應用程式設計不良的其他相關問題
終止封鎖鏈結開頭的工作階段
縮短交易時間
建立適當的索引
請使用鎖定提示。請參閱《SQL Server 線上叢書》
使用資料列版本設定隔離等級
設定 SQL Server 的設定 (記憶體設定、鎖定逾時等等)
變更監視器上此特定資料庫或所有資料庫的臨界值
或者,如果已封鎖的工作階段與此資料庫無關:
停用此特定資料庫或所有資料庫的監視器
名稱 | 描述 | 預設值 |
警示優先順序 | 定義警示優先順序。 | 高 |
警示嚴重性 | 定義警示嚴重性。 | 錯誤 |
已啟用 | 啟用或停用該工作流程。 | 是 |
產生警示 | 定義工作流程是否要產生警示。 | 是 |
間隔 (秒) | 每次重複執行工作流程之間的時間間隔 (秒)。 | 300 |
已封鎖的工作階段數目 | 允許已封鎖的工作階段數目上限。 | 1 |
同步處理時間 | 同步處理時間使用 24 小時制。可予省略。 |
|
逾時 (秒) | 指定流程被關閉及標示為失敗之前,允許執行的時間。 | 200 |
資料庫連線的逾時 (秒) | 若工作流程無法在指定的期限之內存取資料庫,將會失敗並登錄一則事件。 | 15 |
等候時間 (分鐘) | 考慮將程序用於進行「封鎖 SPID」分析之前的程序執行時間下限。 | 1 |
Target | Microsoft.SQLServer.Linux.DBEngine | ||
Parent Monitor | System.Health.PerformanceState | ||
Category | PerformanceHealth | ||
Enabled | True | ||
Alert Generate | True | ||
Alert Severity | Error | ||
Alert Priority | High | ||
Alert Auto Resolve | True | ||
Monitor Type | Microsoft.SQLServer.Linux.MonitorType.DBEngine.BlockingSessions | ||
Remotable | True | ||
Accessibility | Public | ||
Alert Message |
| ||
RunAs | Default |
<UnitMonitor ID="Microsoft.SQLServer.Linux.Monitor.DBEngine.BlockingSessions" Accessibility="Public" Enabled="true" Target="SqlDiscL!Microsoft.SQLServer.Linux.DBEngine" ParentMonitorID="Health!System.Health.PerformanceState" Remotable="true" Priority="Normal" TypeID="Microsoft.SQLServer.Linux.MonitorType.DBEngine.BlockingSessions" ConfirmDelivery="false">
<Category>PerformanceHealth</Category>
<AlertSettings AlertMessage="Microsoft.SQLServer.Linux.Monitor.DBEngine.BlockingSessions.AlertMessage">
<AlertOnState>Error</AlertOnState>
<AutoResolve>true</AutoResolve>
<AlertPriority>High</AlertPriority>
<AlertSeverity>Error</AlertSeverity>
<AlertParameters>
<AlertParameter1>$Data/Context/Property[@Name='BlockedSPIDList']$</AlertParameter1>
<AlertParameter2>$Target/Property[Type="SqlCoreLib!Microsoft.SQLServer.Core.DBEngine"]/InstanceName$</AlertParameter2>
<AlertParameter3>$Target/Property[Type="SqlCoreLib!Microsoft.SQLServer.Core.DBEngine"]/MachineName$</AlertParameter3>
</AlertParameters>
</AlertSettings>
<OperationalStates>
<OperationalState ID="Blocked" MonitorTypeStateID="Blocked" HealthState="Error"/>
<OperationalState ID="NotBlocked" MonitorTypeStateID="NotBlocked" HealthState="Success"/>
</OperationalStates>
<Configuration>
<MachineName>$Target/Property[Type="SqlCoreLib!Microsoft.SQLServer.Core.DBEngine"]/MachineName$</MachineName>
<NetbiosComputerName>$Target/Property[Type="SqlCoreLib!Microsoft.SQLServer.Core.DBEngine"]/NetbiosComputerName$</NetbiosComputerName>
<InstanceName>$Target/Property[Type="SqlCoreLib!Microsoft.SQLServer.Core.DBEngine"]/InstanceName$</InstanceName>
<ConnectionString>$Target/Property[Type="SqlCoreLib!Microsoft.SQLServer.Core.DBEngine"]/ConnectionString$</ConnectionString>
<InstanceVersion>$Target/Property[Type="SqlCoreLib!Microsoft.SQLServer.Core.DBEngine"]/Version$</InstanceVersion>
<InstanceEdition>$Target/Property[Type="SqlCoreLib!Microsoft.SQLServer.Core.DBEngine"]/Edition$</InstanceEdition>
<IntervalSeconds>300</IntervalSeconds>
<SyncTime/>
<WaitMinutes>1</WaitMinutes>
<NumberBlockedSPIDs>1</NumberBlockedSPIDs>
<TimeoutSeconds>200</TimeoutSeconds>
<SqlTimeoutSeconds>15</SqlTimeoutSeconds>
</Configuration>
</UnitMonitor>