Analyse du pourcentage d'accès au cache de requêtes du serveur MySQL

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

Knowledge Base article:

Résumé

Pourcentage de requêtes du cache de requêtes qui sont accomplies. Le cache de requêtes stocke le contenu d'une instruction SELECT avec le résultat correspondant ; ces résultats sont invalidés après une instruction INSERT, UPDATE ou DELETE. La taille du cache de requêtes est contrôlée par la variable globale « query_cache_size ». La taille d'une requête pouvant être insérée dans le cache de requêtes est contrôlée par la variable globale « query_cache_limit ». Le seuil d'analyse est comparé à la moyenne des valeurs retournées sous forme de sondages à l'agent, où le paramètre Nombre d'échantillons contrôle le nombre d'échantillons inclus dans le calcul de la moyenne.

Causes

Un état non intègre indique que le pourcentage de requêtes accomplies du cache de requêtes est faible. Le cache de requêtes ne dispose peut-être pas de suffisamment d'espace de stockage pour les requêtes récemment utilisées. Par ailleurs, les instructions INSERT, UPDATE et DELETE fréquentes videront le cache de requêtes.

Résolutions

Pour résoudre les problèmes liés à des pourcentages d'accès au cache de requêtes faibles, augmentez query_cache_size pour permettre de stocker davantage de requêtes. Le fait d'augmenter query_cache_limit permet de stocker des requêtes de plus grande taille dans le cache de requêtes si la plupart des requêtes sont au-dessus de cette limite. Ces deux variables peuvent être modifiées en ajoutant le nom de la variable respective, suivi de la taille, sous le groupe d'instances dans le fichier de configuration.

Configuration

Configuration par défaut

Paramètre

Valeur par défaut

Seuil d'avertissement

Inférieur à 90

Seuil d’erreur

Inférieur à 80

Nombre d’échantillons

3

Les remplacements permettent de modifier les valeurs de paramètre définies ci-dessus pour toutes les instances ou pour des instances ou groupes spécifiques.

Element properties:

TargetMicrosoft.MySQLServer.ManagedServer.Unix
Parent MonitorMicrosoft.MySQLServer.QueryCachePerformanceRollup
CategoryPerformanceHealth
EnabledTrue
Alert GenerateTrue
Alert SeverityMatchMonitorHealth
Alert PriorityNormal
Alert Auto ResolveTrue
Monitor TypeMicrosoft.Oss.WSManEnumeration.LessThanThreshold.ThreeState.MonitorType
RemotableTrue
AccessibilityPublic
Alert Message
Pourcentage d'accès au cache de requêtes du serveur MySQL
Le pourcentage d'accès au cache de requêtes actuel ({0} \%) pour le serveur MySQL est faible
RunAsDefault

Source Code:

<UnitMonitor ID="Microsoft.MySQLServer.ManagedServer.Unix.QueryCacheHitPct.Monitor" Accessibility="Public" Target="Microsoft.MySQLServer.ManagedServer.Unix" TypeID="Oss!Microsoft.Oss.WSManEnumeration.LessThanThreshold.ThreeState.MonitorType" Enabled="onStandardMonitoring" ParentMonitorID="Microsoft.MySQLServer.QueryCachePerformanceRollup">
<Category>PerformanceHealth</Category>
<AlertSettings AlertMessage="Microsoft.MySQLServer.ManagedServer.Unix.QueryCacheHitPct.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="OverThreshold"/>
<OperationalState HealthState="Warning" MonitorTypeStateID="StatusWarning" ID="UnderWarningThreshold"/>
<OperationalState HealthState="Error" MonitorTypeStateID="StatusError" ID="UnderErrorThreshold"/>
</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>Query Cache Hit 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(.)='QCacheHitPct']$</Value>
<WarningThreshold>90</WarningThreshold>
<ErrorThreshold>80</ErrorThreshold>
<NumSamples>3</NumSamples>
</Configuration>
</UnitMonitor>