Recueillir des métriques custom SQL Server

Ce guide explique comment recueillir des métriques custom depuis SQL Server.

Requêtes personnalisées

Pour recueillir des métriques custom plus complexes avec l’intégration Datadog/SQL Server, utilisez l’option custom_queries dans le fichier conf.d/sqlserver.d/conf.yaml à la racine du répertoire de configuration de votre Agent. Consultez l’exemple de fichier sqlserver.d/conf.yaml pour en savoir plus.

Configuration

custom_queries dispose des options suivantes :

OptionObligatoireDescription
queryOuiLe SQL à exécuter. Il peut s’agir d’une simple déclaration ou d’un script sur plusieurs lignes. Toutes les rangées des résultats sont évaluées. Utilisez une barre verticale (|) si vous avez besoin d’un script sur plusieurs lignes.
columnsOuiListe représentant toutes les colonnes, triées par ordre séquentiel de gauche à droite.

Deux types d’informations sont obligatoires :
-name : le suffixe à ajouter à metric_prefix afin de former un nom de métrique complet. Si le type est défini sur tag, la colonne est considérée comme un tag et appliquée à chaque métrique recueillie par cette requête.
- type : la méthode d’envoi (gauge, count, rate, etc.). Cette option peut également être définie sur tag pour ajouter à chaque métrique de la rangée le nom et la valeur (<nom>:<valeur_rangée>) de l’élément en tant que tag dans cette colonne.
tagsNonLa liste des tags statiques à appliquer à chaque métrique.
  • Au moins un des éléments définis dans columns doit correspondre à un type de métrique (gauge, count, rate, etc.).

  • Le nombre d’éléments définis dans columns doit correspondre au nombre de colonnes renvoyées par la requête.

  • L’ordre des éléments dans columns doit correspondre à celui des valeurs renvoyées par la requête.

    custom_queries:
      - query: Select F3, F2, F1 from Table;
        columns:
          - {name: f3_metric_alias, type: gauge}
          - {name: f2_tagkey      , type: tag  }
          - {name: f1_metric_alias, type: count}
        [...]
    

Exemple

La table company ci-dessous est issue d’une base de données testdb. Elle contient trois entrées d’employé :

testdb=# SELECT * FROM company;

id| name  | age| address    |salary | entry_date | last_raise_time
-------------------------------------------------------------------
1 | Paul  | 32 | California | 20000 | 1457570000 | 1457570300
2 | Allen | 25 | Texas      | 30000 | 1457570060 | 1457570300
3 | Teddy | 23 | Norway     | 45000 | 1457570120 | 1457570300

La requête SQL suivante permet de récupérer l’âge et le salaire de Paul en tant que valeurs de métrique, ainsi que son nom et son adresse en tant que tags.

SELECT age,salary,name,address FROM company WHERE name = 'Paul'

La configuration correspondante de custom_queries dans le fichier YAML est la suivante :

custom_queries:
  - query: SELECT age,salary,name,address FROM company WHERE name = 'Paul'
    columns:
      - name: employee_age
        type: gauge
      - name: employee_salary
        type: gauge
      - name: name
        type: tag
      - name: localisation
        type: tag
    tags:
      - 'query:custom'

Après avoir mis à jour le fichier YAML SQL Server, redémarrez l’Agent Datadog.

Validation

Pour vérifier vos résultats, recherchez les métriques dans le Metrics Explorer.

Debugging

Lancez la sous-commande status de l’Agent et cherchez sqlserver dans la section Checks :

sqlserver
--------
  - instance #0 [ERROR]: 'Missing query parameter in custom_queries'
  - Collected 0 metrics, 0 events & 0 service checks

Les logs de l’Agent peuvent également fournir des informations utiles.

Recueillir des métriques à partir de counters de performance

Par défaut, le check Datadog/SQL Server récupère uniquement une partie des métriques présentes dans la table sys.dm_os_performance_counters.

Voici un exemple de configuration basique pour la collecte de métriques à partir de counters de performance. Remarque : vous pouvez spécifier des tags à envoyer avec vos métriques si vous le souhaitez :

custom_metrics:
  - name: sqlserver.clr.execution
    counter_name: CLR Execution
    tags:
      - tag_name:value

Descriptions des paramètres :

ParamètreDescription
nameNom de votre métrique dans Datadog.
counter_nameLe nom du counter des objets de base de données SQL Server.
tagsListe de paires de tags key:value.

Si un counter est associé à plusieurs instances, vous pouvez choisir de récupérer une seule instance avec le nom de paramètre instance_name :

custom_metrics:
  - name: sqlserver.exec.in_progress
    counter_name: OLEDB calls
    instance_name: Cumulative execution time (ms) per second

Pour une granularité supérieure, affinez la requête en spécifiant un object_name :

custom_metrics:
- name: sqlserver.cache.hit_ratio
  counter_name: Cache Hit Ratio
  instance_name: SQL Plans
  object_name: SQLServer:Plan Cache

Pour recueillir toutes les instances d’un counter associé à plusieurs instances, utilisez la valeur sensible à la casse ALL pour le paramètre instance_name, qui requiert une valeur pour le paramètre tag_by. Cet exemple récupère les métriques portant le tag db:mydb1, db:mydb2 :

custom_metrics:
  - name: sqlserver.db.commit_table_entries
    counter_name: Commit table entries
    instance_name: ALL
    tag_by: db

Les counters sont tirés de la table par défaut sys.dm_os_performance_counters. Le check Datadog/SQL Server prend également en charge sys.dm_os_wait_stats, sys.dm_os_memory_clerks et sys.dm_io_virtual_file_stats.

Pour envoyer une métrique tirée de l’une des tables supplémentaires, spécifiez la table dans la définition du counter avec le paramètre table, ainsi que les colonnes du counter à envoyer avec le paramètre columns :

custom_metrics:
  - name: sqlserver.LCK_M_S
    table: sys.dm_os_wait_stats
    counter_name: LCK_M_S
    columns:
      - max_wait_time_ms
      - signal_wait_time_ms

L’exemple ci-dessus envoie deux métriques, sqlserver.LCK_M_S.max_wait_time.ms et sqlserver.LCK_M_S.signal_wait_time_ms.

Remarque : si les métriques comme sys.dm_io_virtual_file_stats et sys.dm_os_memory_clerks ne sont pas associées à un counter_name, seules les colonnes doivent être spécifiées.

custom_metrics:
  - name: sqlserver.io_file_stats
    table: sys.dm_io_virtual_file_stats
    columns:
      - num_of_reads
      - num_of_writes

L’exemple ci-dessus envoie deux métriques, sqlserver.io_file_stats.num_of_reads et sqlserver.io_file_stats.num_of_writes, chacune étant taguée avec l’ID de la base de données et l’ID du fichier.

Recueillir des métriques avec une procédure personnalisée (obsolète)

La méthode qui suit pour recueillir des métriques custom à partir d’une base de données est désormais obsolète. Nous vous conseillons d’utiliser le paramètre custom_queries, qui nécessite moins de configuration, offre plus de flexibilité dans les types de T-SQL pouvant être exécutés, et permet un debugging simplifié. La collecte de métriques avec une procédure personnalisée génère une vaste quantité de métriques custom, ce qui peut avoir une incidence sur votre facture.

Configurer une procédure stockée

Vous devez configurer une table temporaire pour recueillir les métriques custom afin de les envoyer à Datadog. La table doit contenir les colonnes suivantes :

ColonneDescription
metricLe nom de la métrique tel qu’il apparaît dans Datadog.
typeLe type de métrique (gauge, rate ou histogram).
valueLa valeur de la métrique (doit pouvoir être convertie en valeur de type float).
tagsLes tags qui apparaissent dans Datadog, séparés par une virgule.

La procédure stockée suivante est créée dans la base de données principale :

-- Créer une procédure stockée avec le nom <NOM_PROCÉDURE>
CREATE PROCEDURE [dbo].[<NOM_PROCÉDURE>]
AS
BEGIN

  -- Créer une table temporaire
  CREATE TABLE #DataDog
  (
    [metric] varchar(255) not null,
    [type] varchar(50) not null,
    [value] float not null,
    [tags] varchar(255)
  )

  -- Supprimer les nombres de lignes des ensembles de résultats
  SET NOCOUNT ON;

  -- Créer un count variable et le définir comme égal au nombre de connexions utilisateur
  DECLARE @count float;
  SET @count = (select cntr_value from sys.dm_os_performance_counters where counter_name = 'User Connections');

  -- Insérer des métriques custom dans la table #Datadog
  INSERT INTO #Datadog (metric, type, value, tags)
  VALUES ('sql.test.test', 'gauge', @count, 'db:master,env:staging')
        ,('sql.test.gauge', 'gauge', FLOOR(RAND()*20), 'tag:test')
        ,('sql.test.rate', 'rate', FLOOR(RAND()*20), 'metric:gauge')
        ,('sql.test.histogram', 'histogram', FLOOR(RAND()*20), 'metric:histogram')
  SELECT * from #DataDog
END
GO

-- Autoriser l'exécution de la procédure stockée
GRANT EXECUTE ON [dbo].[<NOM_PROCÉDURE>] To Public
GO

La procédure stockée renvoie les métriques custom suivantes :

  • sql.test.test
  • sql.test.gauge
  • sql.test.rate
  • sql.test.histogram.95percentile
  • sql.test.histogram.avg
  • sql.test.histogram.count
  • sql.test.histogram.max
  • sql.test.histogram.median

Mettre à jour la configuration de l’intégration SQL Server

Pour recueillir des métriques avec une procédure personnalisée, créez une définition d’instance dans votre fichier sqlserver.d/conf.yaml avec la procédure à exécuter. Une instance distincte est nécessaire pour toute configuration existante. Les instances avec une procédure stockée ne traitent rien d’autre que cette dernière, par exemple :

  - host: 127.0.0.1,1433
    username: datadog
    password: "<MOTDEPASSE>"
    database: master
  - host: 127.0.0.1,1433
    username: datadog
    password: "<MOTDEPASSE>"
    stored_procedure: "<NOM_PROCÉDURE>"
    database: master

Vous pouvez également spécifier :

ParamètreDescriptionValeur par défaut
ignore_missing_databaseNe pas effectuer le check si la base de données spécifiée n’existe pas sur le serveur.False
proc_only_ifExécuter cette requête SQL avant chaque appel de stored_procedure. Si elle renvoie 1, appeler la procédure.
proc_only_if_databaseLa base de données dans laquelle la requête SQL proc_only_if est exécutée.attribut de la base données

Remarque : la condition de protection proc_only_if est utile pour les scénarios de haute disponibilité où la base de données peut être déplacée d’un serveur à l’autre.

Dépannage

Si vos métriques custom n’apparaissent pas dans Datadog, vérifiez le fichier de log de l’Agent. Si vous voyez l’erreur Could not call procedure <NOM_PROCÉDURE>: You must supply -1 parameters for this stored procedure, la raison est peut-être l’une des suivantes :

  • Le <NOM_PROCÉDURE> est incorrect.
  • Il est possible que le nom d’utilisateur de la base de données spécifié dans la configuration ne soit pas autorisé à exécuter la procédure stockée.

Pour aller plus loin

Documentation, liens et articles supplémentaires utiles:

PREVIEWING: may/unit-testing