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

Shell et commandes GNU Discussion :

[script] temps reel d'execution


Sujet :

Shell et commandes GNU

  1. #1
    Membre éclairé Avatar de rberthou
    Profil pro
    Inscrit en
    Septembre 2007
    Messages
    612
    Détails du profil
    Informations personnelles :
    Âge : 60
    Localisation : France

    Informations forums :
    Inscription : Septembre 2007
    Messages : 612
    Points : 690
    Points
    690
    Par défaut [script] temps reel d'execution
    Bonjour

    J'utilise de nombreux travaux batch et je garde une trace de leur exécution dans une base de données.

    Je souhaite ajouter le temps "reel" d'exécution (par exemple celui obtenu via la commande time) dans ces données.

    J'affiche cela si j'execute une truc du genre
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    time /home/moi/bin/monbatch.sh
    mais je souhaiterai que cela soit directement dans mon script et la je ne trouve pas sauf en doublant tous mes scripts (ce que j'aimerai eviter)

    style
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    #!/bin/sh
    time /home/moi/bin/monbatch.sh 
     
    #traitement des valeurs affichaient par time
    ...
    # sauvegarde en base de données
    ...
    - Informaticien passionné
    - ( java, c++, cobol, php, asp, ... )
    - http://www.berthou.com/fr/

  2. #2
    Membre chevronné

    Profil pro
    Inscrit en
    Mars 2004
    Messages
    1 296
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2004
    Messages : 1 296
    Points : 1 803
    Points
    1 803
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    /usr/bin/time  -a -f "%S sys" -o /tmp/toto ls -l 
    read titi </tmp/toto
    echo $titi
    0.00 sys
    ..........
     
    rm /tmp/toto      # ne pas oublier, faire un "trapp" est encore mieux
    donc traitement de la variable "$titi"
    Marc
    Slackware for ever ......
    BASH - KSH ( http://marcg.developpez.com/ksh/ )

  3. #3
    Membre éclairé Avatar de rberthou
    Profil pro
    Inscrit en
    Septembre 2007
    Messages
    612
    Détails du profil
    Informations personnelles :
    Âge : 60
    Localisation : France

    Informations forums :
    Inscription : Septembre 2007
    Messages : 612
    Points : 690
    Points
    690
    Par défaut
    Oui merci mais dans ce cas je dois doubler tous mes scripts...

    J'aimerai bien trouver une solution pour faire cela dans mon script

    dans le style
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
    #!/bin/sh
     
    # init du time pour le process en cours (et ces enfants)
    timeinit
     
    # traitement
    .....
     
    # recuperation du time
    gettime
     
    # fin du traitement
    - Informaticien passionné
    - ( java, c++, cobol, php, asp, ... )
    - http://www.berthou.com/fr/

  4. #4
    Modérateur
    Avatar de ggnore
    Profil pro
    Inscrit en
    Juillet 2004
    Messages
    2 472
    Détails du profil
    Informations personnelles :
    Âge : 45
    Localisation : France

    Informations forums :
    Inscription : Juillet 2004
    Messages : 2 472
    Points : 4 029
    Points
    4 029
    Par défaut
    Pourquoi ne pas écrire la date avec les détails qui t'intéressent au début du script, et la même chose à la fin ?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    DATEDEBUT=$(date +'%F')
    HEUREDEBUT=$(date +'%T')
    traitement ...
    HEUREFIN=$(date +'%T')
    Toutes les vertus des hommes se perdent dans l’intérêt comme les fleuves se perdent dans la mer.
    N'oubliez pas de consulter les FAQ Linux et les cours et tutoriels Linux

  5. #5
    Membre éclairé Avatar de rberthou
    Profil pro
    Inscrit en
    Septembre 2007
    Messages
    612
    Détails du profil
    Informations personnelles :
    Âge : 60
    Localisation : France

    Informations forums :
    Inscription : Septembre 2007
    Messages : 612
    Points : 690
    Points
    690
    Par défaut
    La date système ne m'intéresse pas (et je la mémorise déjà) car cela ne me donne que la durée de l'exécution pas la durée réelle (temps CPU).
    - Informaticien passionné
    - ( java, c++, cobol, php, asp, ... )
    - http://www.berthou.com/fr/

  6. #6
    Membre actif
    Profil pro
    Architecte de système d'information
    Inscrit en
    Mai 2007
    Messages
    248
    Détails du profil
    Informations personnelles :
    Âge : 71
    Localisation : France

    Informations professionnelles :
    Activité : Architecte de système d'information
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2007
    Messages : 248
    Points : 289
    Points
    289
    Par défaut
    Peut être en regardant /proc/[PID]/stat. Il y a un champ nommé utime.

  7. #7
    Membre éclairé Avatar de rberthou
    Profil pro
    Inscrit en
    Septembre 2007
    Messages
    612
    Détails du profil
    Informations personnelles :
    Âge : 60
    Localisation : France

    Informations forums :
    Inscription : Septembre 2007
    Messages : 612
    Points : 690
    Points
    690
    Par défaut
    Oui....
    je pense trouve mon bonheur dans /proc ...

    J'avoue que je n'avais pas pensé a cela...

    merci...
    - Informaticien passionné
    - ( java, c++, cobol, php, asp, ... )
    - http://www.berthou.com/fr/

  8. #8
    Membre éclairé Avatar de rberthou
    Profil pro
    Inscrit en
    Septembre 2007
    Messages
    612
    Détails du profil
    Informations personnelles :
    Âge : 60
    Localisation : France

    Informations forums :
    Inscription : Septembre 2007
    Messages : 612
    Points : 690
    Points
    690
    Par défaut
    Voici le résultat ...

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    XRUNA=`cat /proc/$$/stat | awk -F '[ ]' '{print "cutime=" $16 " cstime=" $17 }'`
    et je passe ensuite XRUNA en paramètre a mon traitement de trace des batchs...

    Encore merci..
    - Informaticien passionné
    - ( java, c++, cobol, php, asp, ... )
    - http://www.berthou.com/fr/

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Rediriger sortie de script en temps reel
    Par raph382 dans le forum Débuter avec Java
    Réponses: 18
    Dernier message: 10/01/2011, 17h25
  2. Réponses: 10
    Dernier message: 31/03/2010, 15h59
  3. [Info][Debutant(e)]affichage temps reel
    Par nine dans le forum Développement Web en Java
    Réponses: 15
    Dernier message: 26/11/2004, 17h03
  4. Réponses: 5
    Dernier message: 19/07/2004, 17h27
  5. Linux et le temps réel
    Par Shrem dans le forum Administration système
    Réponses: 6
    Dernier message: 11/12/2002, 08h21

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