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

Debian Discussion :

Comment exécuter un script en fouction du journal


Sujet :

Debian

  1. #1
    Débutant  
    Profil pro
    Inscrit en
    Mai 2005
    Messages
    3 096
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Mai 2005
    Messages : 3 096
    Points : 944
    Points
    944
    Par défaut Comment exécuter un script en fouction du journal
    Bonjour,

    J'aimerais faire un truc. J'ai un petit problème que mon Raspebrry boot sous Rasbian, il n'arrive pas démarrer un service.
    Je peux le voir en exécutant cette commande

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    journalctl -u iot-lora-gateway.service --no-pager -n 1
    S'il n'a pas démarré, la commande me retournera
    Oct 21 20:54:24 iotloragateway iot-lora-gateway[668]: 20:54:24 ERROR: [TTN] Connection to server "" failed, retry in 60 seconds
    L'idée est de faire un script qui va être exécuté par cron toutes le 5mn et s'il lit le texte 'ERROR: [TTN] Connection to server "" failed', il va exécuter la commande

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    sudo systemctl restart iot-lora-gateway.service
    Si non, on pourrait aussi analyser cette commande
    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
     
    sudo systemctl status iot-lora-gateway.service
    ● iot-lora-gateway.service - IOT LoRa Gateway Packet Forwarder
       Loaded: loaded (/lib/systemd/system/iot-lora-gateway.service; enabled; vendor preset: enabled)
       Active: active (running) since Wed 2020-10-21 20:53:53 BST; 15min ago
      Process: 481 ExecStartPre=/opt/iotloragateway/iot-lora-gateway-reset.sh (code=exited, status=0/SUCCESS)
     Main PID: 668 (iot-lora-gatewa)
        Tasks: 1 (limit: 2065)
       CGroup: /system.slice/iot-lora-gateway.service
               └─668 /opt/iotloragateway/iot-lora-gateway
     
    Oct 21 21:01:24 iotloragateway iot-lora-gateway[668]: src/ttn_transport.c:371:ttn_connect(): ttn_connect: sleeping() at 150, total 24
    Oct 21 21:01:24 iotloragateway iot-lora-gateway[668]: src/ttn_transport.c:371:ttn_connect(): ttn_connect: sleeping() at 160, total 24
    Oct 21 21:01:24 iotloragateway iot-lora-gateway[668]: src/ttn_transport.c:371:ttn_connect(): ttn_connect: sleeping() at 170, total 24
    Oct 21 21:01:24 iotloragateway iot-lora-gateway[668]: src/ttn_transport.c:371:ttn_connect(): ttn_connect: sleeping() at 180, total 24
    Oct 21 21:01:24 iotloragateway iot-lora-gateway[668]: src/ttn_transport.c:371:ttn_connect(): ttn_connect: sleeping() at 190, total 24
    Oct 21 21:01:24 iotloragateway iot-lora-gateway[668]: src/ttn_transport.c:371:ttn_connect(): ttn_connect: sleeping() at 200, total 24
    Oct 21 21:01:24 iotloragateway iot-lora-gateway[668]: src/ttn_transport.c:371:ttn_connect(): ttn_connect: sleeping() at 210, total 24
    Oct 21 21:01:24 iotloragateway iot-lora-gateway[668]: src/ttn_transport.c:371:ttn_connect(): ttn_connect: sleeping() at 220, total 24
    Oct 21 21:01:24 iotloragateway iot-lora-gateway[668]: src/ttn_transport.c:371:ttn_connect(): ttn_connect: sleeping() at 230, total 24
    Oct 21 21:01:24 iotloragateway iot-lora-gateway[668]: 21:01:24  ERROR: [TTN] Connection to server "" failed, retry in 480 seconds
    et si cette commande affiche la dernière ligne que l'on voit
    Oct 21 21:01:24 iotloragateway iot-lora-gateway[668]: 21:01:24 ERROR: [TTN] Connection to server "" failed,
    il exécute la commande
    sudo systemctl restart iot-lora-gateway.service

    Ce que je ne sais absolument pas faire, c'est comment analyser l'exécution d'une commande
    si la sortie contient une chaine de caractère, comme
    ERROR: [TTN] Connection to server "" failed

    L'idée finale est d'exécuter ce script dès que la Raspberry a démarré jusqu'à ce qu'il lise ceci
    INFO: [TTN] send status success for
    et s'il ne lit pas ceci, mais lis ceci
    ERROR: [TTN] Connection to server "" failed
    il lance la commande
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    sudo systemctl restart iot-lora-gateway.service
    Merci pour vos lumières
    Il ne suffit pas de tout savoir. Vouloir et persévérer, c'est déjà presque tout!

  2. #2
    Expert éminent sénior Avatar de Flodelarab
    Homme Profil pro
    Inscrit en
    Septembre 2005
    Messages
    5 243
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Charente (Poitou Charente)

    Informations forums :
    Inscription : Septembre 2005
    Messages : 5 243
    Points : 13 459
    Points
    13 459
    Par défaut
    Bonjour

    Tu as tout. L'algorithme, les commandes décisives. Qu'est-ce qui te manque pour avancer ?

    En bash, tu peux directement mettre la commande à la suite du if.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    if commande | grep -q 'chaine que je recherche'
    then
     
    else
     
    fi
    À toi de produire du code.
    Cette réponse vous apporte quelque chose ? Cliquez sur en bas à droite du message.

  3. #3
    Débutant  
    Profil pro
    Inscrit en
    Mai 2005
    Messages
    3 096
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Mai 2005
    Messages : 3 096
    Points : 944
    Points
    944
    Par défaut
    Hellooo

    Ouha, c'est aussi simple que cela??
    Je vais essayer, mais le problème que je devine c'est les "" et [] dans
    ERROR: [TTN] Connection to server "bridge.eu.thethings.network" failed
    Il me semble que le grep me retournait une difféente réponse sans les [].

    Mais je vais créer le script un peu plus tard!!

    Merciiiiiii
    Il ne suffit pas de tout savoir. Vouloir et persévérer, c'est déjà presque tout!

  4. #4
    Expert éminent sénior Avatar de Flodelarab
    Homme Profil pro
    Inscrit en
    Septembre 2005
    Messages
    5 243
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Charente (Poitou Charente)

    Informations forums :
    Inscription : Septembre 2005
    Messages : 5 243
    Points : 13 459
    Points
    13 459
    Par défaut
    Effectivement les crochets sont interprétés. Pour parer le problème, 3 idées au choix :
    • Soit tu utilises grep -F, ou fgrep, qui interprète le motif comme une chaîne fixe de caractères et non comme une expression rationnelle.
    • Soit tu échappes les crochets par des contre-obliques pour éviter leurs interprétations. ERROR: \[TTN\] Connection to server "bridge\.eu\.thethings\.network" failed. Les "double quotes" ne sont pas un problème, car non interprétés dans des 'simple quotes'.
    • Soit tu changes les caractères gênants par un point, qui signifie n'importe quel caractère, dans une expression rationnelle. ERROR: .TTN. Connection to server "bridge.eu.thethings.network" failed.
    Cette réponse vous apporte quelque chose ? Cliquez sur en bas à droite du message.

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

Discussions similaires

  1. Comment exécuter un script SQL ?
    Par Mafate dans le forum Débuter
    Réponses: 2
    Dernier message: 11/03/2008, 10h52
  2. Comment exécuter un script avant la compilation ?
    Par jackfirst72 dans le forum Delphi
    Réponses: 1
    Dernier message: 05/04/2007, 10h14
  3. Réponses: 3
    Dernier message: 26/02/2007, 19h19
  4. Réponses: 5
    Dernier message: 16/03/2006, 00h37
  5. Réponses: 1
    Dernier message: 23/02/2005, 11h23

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