IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

MS SQL Server Discussion :

Utilisation de la CPU


Sujet :

MS SQL Server

  1. #1
    Membre actif

    Profil pro
    Inscrit en
    Décembre 2002
    Messages
    146
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Décembre 2002
    Messages : 146
    Points : 204
    Points
    204
    Par défaut Utilisation de la CPU
    Bonjour

    Avec cette requête
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    set nocount on
    go
     
    PRINT ':: Relative time spent on I/O, CPU, and idle since server start'
    SELECT @@CPU_BUSY AS [@@CPU_BUSY], @@IDLE AS [@@IDLE], @@IO_BUSY AS [@@IO_BUSY],
    CONVERT (varchar(8), CONVERT (numeric (6, 4), (100.0 * @@CPU_BUSY / (@@CPU_BUSY + @@IDLE + @@IO_BUSY)))) + '%' AS Pct_CPU_BUSY,
    CONVERT (varchar(8), CONVERT (numeric (6, 4), (100.0 * @@IDLE / (@@CPU_BUSY + @@IDLE + @@IO_BUSY)))) + '%' AS Pct_IDLE,
    CONVERT (varchar(8), CONVERT (numeric (6, 4), (100.0 * @@IO_BUSY / (@@CPU_BUSY + @@IDLE + @@IO_BUSY)))) + '%' AS Pct_IO_BUSY
    PRINT ''
    J'ai un serveur avec sql 2008 avec 4 instances. le résultat est
    @@CPU_BUSY @@IDLE @@IO_BUSY Pct_CPU_BUSY Pct_IDLE Pct_IO_BUSY
    491582 70854453 98189 0.6881% 99.1745% 0.1374%

    sur une autre instance (même moteur sql)
    491648 70964479 98197 0.6871% 99.1757% 0.1372%

    sur une autre instance (même moteur sql)
    145609 71415727 13316 0.2034% 99.7780% 0.0186%

    sur le dernière instance
    29834 71551039 8919 0.0417% 99.9459% 0.0125%


    Il y a en permanance des requêtes sur la 1ere instance

    Je m’interroge sur le faible pourcentage de l’occupation du cpu alors que j’ai des traitements qui semble attendre.

    les valeurs en % de l'occupation de cpu n'est t il pas faible ?

    merci d'avance pour vos remarques
    j francois

  2. #2
    Expert éminent sénior
    Avatar de mikedavem
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Août 2005
    Messages
    5 450
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Ain (Rhône Alpes)

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : Distribution

    Informations forums :
    Inscription : Août 2005
    Messages : 5 450
    Points : 12 891
    Points
    12 891
    Par défaut
    Bonjour,

    Je pense que la méthode calcul n'est pas la bonne.

    Si tu veux avoir le pourcentage d'utilisation CPU il faut utiliser le ratio suivant :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    SELECT 100 * (@@CPU_BUSY * CAST(@@TIMETICKS AS FLOAT) / 1000) / ms_ticks AS cpu_used_in_percent
    FROM sys.dm_os_sys_info
    On compare le temps CPU utilisé depuis le démarrage de SQL Server via @@CPU_BUSY et @@TIMETICKS et le temps passé depuis le dernier démarrage de SQL Server (ms_ticks de la DMV sys.dm_os_sys_info).

    ++

  3. #3
    Membre confirmé
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Octobre 2008
    Messages
    699
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Suisse

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Boutique - Magasin

    Informations forums :
    Inscription : Octobre 2008
    Messages : 699
    Points : 586
    Points
    586
    Par défaut
    @ mikedavem :

    Du coup on a une utilisation moyenne du CPU depuis le dernier restart du service ?

    Quel serait un taux correct ?

  4. #4
    Expert éminent sénior
    Avatar de mikedavem
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Août 2005
    Messages
    5 450
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Ain (Rhône Alpes)

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : Distribution

    Informations forums :
    Inscription : Août 2005
    Messages : 5 450
    Points : 12 891
    Points
    12 891
    Par défaut
    Du coup on a une utilisation moyenne du CPU depuis le dernier restart du service ?
    Oui c'est cela. Si le but est de créer une baseline, il faut procéder par snapshot de valeurs et faire la différence. Personnellement je ne prendrais pas les valeurs de @@CPU_BUSY etc car elles ne sont pas forcément fiables dans le temps. Je me tournerai plus vers des valeurs de compteurs perfmon (ou sys.dm_os_performance_counters)

    Quel serait un taux correct ?
    La réponse est difficile à donner car elle dépend beaucoup de ton environnement (workload, nombre de processeurs, environnement virtuel ou non etc ...). Il faut également avoir un point de référence dans une situation normale pour dire si le taux est correct ou non ...

    Je commencerai par établir une baseline des métriques concernant les cpu (et autres) dans une situation de production normale. Après il te sera plus facile de dire si la valeur instantanée rencontrée sur le serveur est "normale" ou excessive.

    ++

Discussions similaires

  1. Problème utilisation de ressources (CPU / RAM)
    Par CAML dans le forum Administration
    Réponses: 2
    Dernier message: 09/07/2008, 08h41
  2. Réponses: 3
    Dernier message: 21/12/2007, 17h34
  3. Process utilise 99% du cpu
    Par yakotey dans le forum Administration système
    Réponses: 5
    Dernier message: 27/02/2007, 20h03
  4. Récuperer la valeur de l'utilisation totale du cpu
    Par xodeax dans le forum Administration système
    Réponses: 5
    Dernier message: 05/07/2006, 15h24
  5. Utilisation total du CPU
    Par programmerPhil dans le forum Administration système
    Réponses: 5
    Dernier message: 20/12/2005, 02h37

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo