MySQL Server – a táblazárolási versenyhelyzetek százalékos arányának figyelése

Microsoft.MySQLServer.ManagedServer.Unix.TableLockContentionPct.Monitor (UnitMonitor)

Knowledge Base article:

Összefoglalás

A MyISAM tábla zárolására való várakozások számának százalékos aránya a zárolási kérések számához képest. A MySQL a következő táblákon alkalmaz táblaszintű zárolást: MyISAM, MEMORY és MERGE. A figyelő küszöbértékének elemzése az ügynök lekérdezéseikor visszaadott értékek átlagához képest történik, ahol az átlagszámításhoz használt minták számát a Minták száma paraméter határozza meg.

Okok

A hibás állapotot az jelzi, ha a táblazárolási versenyhelyzetek százalékos aránya magas. A táblazárolás engedélyezése előtti várakozások száma túl magas.

Megoldások

Ha túl magas a táblazárolási versenyhelyzetek százalékos aránya, a probléma megoldásához próbálja meg a következő lehetőségeket:

Beállítások

Alapértelmezett beállítások

Paraméter

Alapértelmezett érték

Figyelmeztetési küszöbérték

Nagyobb mint 45

Hibaküszöbérték

Nagyobb mint 55

Minták száma

3

A fent definiált paraméterértékek felülbírálásokkal módosíthatók az összes példány, illetve adott példányok vagy csoportok esetében.

Element properties:

TargetMicrosoft.MySQLServer.ManagedServer.Unix
Parent MonitorMicrosoft.MySQLServer.TableCachePerformanceRollup
CategoryPerformanceHealth
EnabledTrue
Alert GenerateTrue
Alert SeverityMatchMonitorHealth
Alert PriorityNormal
Alert Auto ResolveTrue
Monitor TypeMicrosoft.Oss.WSManEnumeration.GreaterThanThreshold.ThreeState.MonitorType
RemotableTrue
AccessibilityPublic
Alert Message
MySQL Server – a táblagyorsítótár-zárolási versenyhelyzetek százalékos aránya
A MySQL Server esetén pillanatnyilag a táblazárolási versenyhelyzetek százalékos aránya ({0}\%) magas.
RunAsDefault

Source Code:

<UnitMonitor ID="Microsoft.MySQLServer.ManagedServer.Unix.TableLockContentionPct.Monitor" Accessibility="Public" Target="Microsoft.MySQLServer.ManagedServer.Unix" TypeID="Oss!Microsoft.Oss.WSManEnumeration.GreaterThanThreshold.ThreeState.MonitorType" Enabled="onStandardMonitoring" ParentMonitorID="Microsoft.MySQLServer.TableCachePerformanceRollup">
<Category>PerformanceHealth</Category>
<AlertSettings AlertMessage="Microsoft.MySQLServer.ManagedServer.Unix.TableLockContentionPct.AlertMessage">
<AlertOnState>Warning</AlertOnState>
<AutoResolve>true</AutoResolve>
<AlertPriority>Normal</AlertPriority>
<AlertSeverity>MatchMonitorHealth</AlertSeverity>
<AlertParameters>
<AlertParameter1>$Data/Context/Value$</AlertParameter1>
</AlertParameters>
</AlertSettings>
<OperationalStates>
<OperationalState HealthState="Success" MonitorTypeStateID="StatusOK" ID="UnderThreshold"/>
<OperationalState HealthState="Warning" MonitorTypeStateID="StatusWarning" ID="OverWarningThreshold"/>
<OperationalState HealthState="Error" MonitorTypeStateID="StatusError" ID="OverErrorThreshold"/>
</OperationalStates>
<Configuration>
<Interval>300</Interval>
<TargetSystem>$Target/Host/Property[Type="Unix!Microsoft.Unix.Computer"]/NetworkName$</TargetSystem>
<Uri>http://schemas.microsoft.com/wbem/wscim/1/cim-schema/2/MySQL_ServerStatistics?__cimnamespace=root/mysql</Uri>
<WSManFilter/>
<ObjectName>MySQL Server</ObjectName>
<CounterName>Table Lock Contention Pct</CounterName>
<InstanceXPath>/DataItem/WsManData/*[local-name(.)='MySQL_ServerStatistics']/*[local-name(.)='InstanceID']</InstanceXPath>
<InstanceName>$Target/Property[Type="Microsoft.MySQLServer.Installation"]/InstanceID$</InstanceName>
<Value>$Data/WsManData/*[local-name(.)='MySQL_ServerStatistics']/*[local-name(.)='TableLockContentionPct']$</Value>
<WarningThreshold>45</WarningThreshold>
<ErrorThreshold>55</ErrorThreshold>
<NumSamples>3</NumSamples>
</Configuration>
</UnitMonitor>