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 :

Sortie script dans erreur.log et stdout.log


Sujet :

Shell et commandes GNU

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Profil pro
    Inscrit en
    Novembre 2006
    Messages
    378
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2006
    Messages : 378
    Par défaut Sortie script dans erreur.log et stdout.log
    Bonjour
    plutôt que de réinventer la roue,
    quelqu'un connait il un script qui permet de logger dans un fichier erreur et un fichier sortie tout en affichant les données sur l'écran.

    le but est de mettre ces routines dans un script bash
    pour conserver les traces pour analyse ultérieures.

    sinon je vais me plonger dans le scripting mais cela doit déjà exister avec redirection et trap

    merci

  2. #2
    Expert confirmé Avatar de frp31
    Homme Profil pro
    Ingénieur systèmes et réseaux
    Inscrit en
    Juillet 2006
    Messages
    5 196
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Ingénieur systèmes et réseaux
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Juillet 2006
    Messages : 5 196
    Par défaut
    une méthode un peu porc mais qui marche toujours sur tous les unix/tous les shells

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    $ ping -c 4 undertaker  2> toto.err 1> toto.log  &  tail -f toto.err &
    [1] 10453
    [2] 11946
    ping: sendto: Host is down
    ping: sendto: Host is down
    ping: sendto: Host is down
    ping: sendto: Host is down
     
     
    $
     
    $ cat toto.err
    ping: sendto: Host is down
    ping: sendto: Host is down
    ping: sendto: Host is down
    ping: sendto: Host is down
    $ cat toto.log
    ping: wrote undertaker.pagnol.net 64 chars, ret=-1
    ping: wrote undertaker.pagnol.net 64 chars, ret=-1
    --- undertaker.pagnol.net ping statistics ---
    --- undertaker.pagnol.net ping statistics ---0.0% packe
    4 packets transmitted, 0 packets received, 100.0% packet loss
    $

    les deux fichiers STDOUT et ERROUT sont bien alimenté et la sortie écran reste dispo par le tail sur sur le fichier choisi


    sinon beaucoup plus propre en utilisant des pipes només
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
     
    $ mknod fifo p
    $ mknod fifor p 
    $ cat fifor > toto.err &               
    [1] 55
    $ cat fifo > toto.log &                
    [5] 23420
    $ ping -c 4 undertaker 2> fifor 1> fifo &
    [7] 28449
    $ ping: sendto: Host is down
    ping: sendto: Host is down
    ping: sendto: Host is down
    ping: sendto: Host is down
    ping: sendto: Host is down
    ping: sendto: Host is down
     
    $ rm fifo fifor toto.[el]??
    $

  3. #3
    Modérateur
    Avatar de N_BaH
    Profil pro
    Inscrit en
    Février 2008
    Messages
    7 651
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2008
    Messages : 7 651
    Par défaut
    Bonjour,

    adapté de l'ABS :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    $ maFonction() { echo "erreur" >&2; echo "standard" >&1;}
    $ exec 3>&1
    $ maFonction 3>std.log 2>&1 >&3 3>&- | tee err.log
    erreur
    $ exec 3>&-
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    $ cat std.log
    standard
    $ cat err.log
    erreur
    j'ai pas encore tout compris
    N'oubliez pas de consulter les cours shell, la FAQ, et les pages man.

  4. #4
    Membre éclairé
    Profil pro
    Inscrit en
    Novembre 2006
    Messages
    378
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2006
    Messages : 378
    Par défaut
    bon voici le code que j'essaye de mettre en place

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    #!/bin/bash
     
    #redirection STDERR dans un fichier de log et affichage sur le terminal en //
    exec 6>&2
    exec 2>>erreur.log | tee erreur.log
     
    #redirection STDOUT dans un fichier de log et affichage sur le terminal en //
    exec 5>&1
    exec 1>>trace.log | tee trace.log
     
     
    trap 'error_handle' ERR
    trap 'exit_handle' EXIT
     
    function error_handler()
    {
           SCRIPTNAME="$0"               
            LIGNE="$1"
            ERREUR="$2"
            echo "ERREUR : `date` dans ${SCRIPTNAME}: ligne ${LIGNE}: code erreur: ${ERREUR}"
    }
     
    function exit_handler()
    {
    # restaurer le STDERR
    exec 2>&6 6>&-
    #restaurer le STDOUT
    exec 1>&5 5>&-
    }
     
     
    ls -xyz
     
    #sortie
    exit_handle
    j'obtiens les erreurs suivantes :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    $ sh t1.sh 
    trap: ERR: bad trap
    t1.sh: 14: t1.sh: Syntax error: "(" unexpected
    t1.sh: 1: t1.sh: exit_handler: not found
    et je n'ai rien dans erreur.log et trace.log

    j'ai essayé de modifier à différents endroits mais sans succès
    merci de votre participation

  5. #5
    Modérateur
    Avatar de N_BaH
    Profil pro
    Inscrit en
    Février 2008
    Messages
    7 651
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2008
    Messages : 7 651
    Par défaut
    si tu lances ton script avec sh, c'est sh qui exécutera le script, quoi que dise le shebang.
    tu rends ton script excutable.
    tu l'appelles avec son chemin absolu ou relatif.

    trap -l ne montre pas de SIGERR.

    le nom des fonctions n'est pas le même partout :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    trap 'exit_handle' EXIT
     
    function error_handler()
    le mot reservé functionn'est pas nécessaire lorsqu'on utilise les () (ce mot-clè n'est d'ailleurs pas une spécification POSIX).
    N'oubliez pas de consulter les cours shell, la FAQ, et les pages man.

  6. #6
    Membre éclairé
    Profil pro
    Inscrit en
    Novembre 2006
    Messages
    378
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2006
    Messages : 378
    Par défaut
    exact, entre le moment où j'ai commencé le post et la fin, j'ai effectué plusieurs modifications pour tester et voilà le résultat un mix ;-)

    sinon voici le code
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    #!/bin/bash
     
    #redirection STDERR dans un fichier de log et affichage sur le terminal en //
    exec 6>&2
    exec 2>>erreur.log | tee erreur.log
     
    #redirection STDOUT dans un fichier de log et affichage sur le terminal en //
    exec 5>&1
    exec 1>>trace.log | tee trace.log
     
     
    trap 'error_handler' ERR
    trap 'exit_handler' EXIT
     
    error_handler()
    {
           SCRIPTNAME="$0"               
            LIGNE="$1"
            ERREUR="$2"
            echo "ERREUR : `date` dans ${SCRIPTNAME}: ligne ${LIGNE}: code erreur: ${ERREUR}"
    }
     
    exit_handler()
    {
    # restaurer le STDERR
    exec 2>&6 6>&-
    #restaurer le STDOUT
    exec 1>&5 5>&-
    }
     
     
    ls -xyz
    ls /home
     
    #sortie
    exit_handler

    voici le résultat
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    trap: ERR: bad trap
    ls*: option invalide -- 'y'
    Saisissez «*ls --help*» pour plus d'informations.
    user1
    user2
    user3
    par contre je n'ai rien dans mes fichiers en sortie
    si je retire "| tee erreur.log" et "| tee trace.log" , alors j'ai plus rien à l'écran mais bien dans les fichiers

    Comment mutualiser les 2 ?

    et comment contourner le pb du SIGERR

Discussions similaires

  1. [Batch] exporter le deroulement du script dans un fichier log
    Par Xbase dans le forum Scripts/Batch
    Réponses: 4
    Dernier message: 12/03/2015, 19h59
  2. Réponses: 5
    Dernier message: 02/05/2012, 13h32
  3. [Log4J] Sortie console dans fichier log
    Par zaitsev dans le forum Logging
    Réponses: 6
    Dernier message: 20/07/2011, 17h02
  4. Sauver les sorties consoles dans un fichier log
    Par Balbuzard dans le forum Logging
    Réponses: 4
    Dernier message: 30/03/2009, 00h48
  5. Déplacer les log de /var/log vers /home/log
    Par Seb33300 dans le forum Administration système
    Réponses: 4
    Dernier message: 01/05/2008, 13h45

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