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

Administration système Discussion :

Script fonctionne pas avec cron


Sujet :

Administration système

  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Avril 2006
    Messages
    142
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2006
    Messages : 142
    Par défaut Script fonctionne pas avec cron
    J'ai le script suivant me permettant de signer les fichier Release des différents dépots que nous maintenons :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    #!/bin/bash
     
    fichier_sign="/mirror/mcollective/dists/lenny
                  /mirror/mcollective/dists/squeeze
                  /mirror/debian/mirror/apt.puppetlabs.com/debian/dists/lenny
                  /mirror/debian/mirror/apt.puppetlabs.com/debian/dists/squeeze"
     
    for i in $fichier_sign;
    do
      /usr/bin/gpg --passphrase "passwd" --yes --output $i/Release.gpg -ba $i/Release
      if [ $? != 0 ]; then
        echo "Impossible de signer le depot : $i"
      fi
    done
    L'idée était que ce dernier soit lancé par CRON tous les matins, du fait qu'un apt-mirror est réalisé chaque nuit ...

    Ce script fonctionne si je le lance en root.
    Or, dès lors que je le met en cron, celui-ci "ne tourne pas". J'ai bien une entrée dans le syslog m'indiquant que CRON a traité ma demande, mais mes fichiers restent inchangé.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    (root) CMD (root /opt/scripts/depot/auto-sign.sh 2>&1 > /var/log/auto-sign.log)
    Si je passe le script à la main, le résultat est bon, la date de création des fichiers de signatures étant celle à laquelle j'ai lancé à la main le script


    Auriez-vous des idées ?

  2. #2
    Invité
    Invité(e)
    Par défaut
    Salut,

    Tu ne vois rien dans le fichier log /var/log/auto-sign.log?

  3. #3
    Membre confirmé
    Profil pro
    Inscrit en
    Avril 2006
    Messages
    142
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2006
    Messages : 142
    Par défaut
    Et bien justement non, alors que j'ai des choses sur la sortie standard lorsque je l'éxecute (Meme si je lui dit de tout m'envoyer dans /dev/null, étrange d'ailleurs). En toute logique, je devrais me retrouver avec des messages gpg, meme si je soumet le password ... Hors, il ne sont visible que sur la sortie standard, rien dans les logs.

  4. #4
    Rédacteur

    Avatar de ram-0000
    Homme Profil pro
    Consultant en sécurité
    Inscrit en
    Mai 2007
    Messages
    11 517
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 62
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Consultant en sécurité
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Mai 2007
    Messages : 11 517
    Par défaut
    Une piste peut être, ton environnement qui n'est pas le même sous cron/root par rapport à login/root ?

    En début de script, tu pourrais peut être rajouter l'exécution du ~root/.profile ou ~root/.bashrc ?
    Raymond
    Vous souhaitez participer à la rubrique Réseaux ? Contactez-moi

    Cafuro Cafuro est un outil SNMP dont le but est d'aider les administrateurs système et réseau à configurer leurs équipements SNMP réseau.
    e-verbe Un logiciel de conjugaison des verbes de la langue française.

    Ma page personnelle sur DVP
    .

  5. #5
    Invité
    Invité(e)
    Par défaut
    mmmh

    peux-tu mettre ceci tout à la fin: 2>&1 de la ligne et revérifier ton fichier log

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    /opt/scripts/depot/auto-sign.sh  > /var/log/auto-sign.log 2>&1

  6. #6
    Membre confirmé
    Profil pro
    Inscrit en
    Avril 2006
    Messages
    142
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2006
    Messages : 142
    Par défaut
    @Mygale1978 : Il me retourne :
    /bin/sh: root : commande introuvable
    En gros, il a pas le /usr/bin dans le path ?

    @ram-0000 : Cela corroborerait l'erreur remonté ?

    Comment puis-je tester l'environnement de cron/root ?

  7. #7
    Rédacteur

    Avatar de ram-0000
    Homme Profil pro
    Consultant en sécurité
    Inscrit en
    Mai 2007
    Messages
    11 517
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 62
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Consultant en sécurité
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Mai 2007
    Messages : 11 517
    Par défaut
    Citation Envoyé par Nelmo Voir le message
    Comment puis-je tester l'environnement de cron/root ?
    SET (ou set ?) > /tmp/cron.log que tu rajoute dans un script (nouveau script de test) que tu lances par cron
    Raymond
    Vous souhaitez participer à la rubrique Réseaux ? Contactez-moi

    Cafuro Cafuro est un outil SNMP dont le but est d'aider les administrateurs système et réseau à configurer leurs équipements SNMP réseau.
    e-verbe Un logiciel de conjugaison des verbes de la langue française.

    Ma page personnelle sur DVP
    .

  8. #8
    Invité
    Invité(e)
    Par défaut
    Non,

    /bin/sh: root : commande introuvable
    En gros, il a pas le /usr/bin dans le path ?
    root /opt/scripts/depot/auto-sign.sh
    ta crontab essaie d'interpréter root comme étant une commande du shell.

    Si tu édites ta crontab avec crontab -e, tu n'as pas à spécifier le user root.

    Il faut donc virer "root" devant.

  9. #9
    Membre confirmé
    Profil pro
    Inscrit en
    Avril 2006
    Messages
    142
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2006
    Messages : 142
    Par défaut
    Merci Mygale, je viens de comprendre mon erreur ...

    Maintenant, je me retrouve avec le message dans les logs (Pour chacun des dépots)
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    gpg: cannot open `/dev/tty': Aucun périphérique ou adresse
    Impossible de signer le depot ...
    A ce niveau, ce pourrait être un probleme de l'environnement de CRON ? Je ne comprend pas trop pourquoi /dev/tty est inaccessible


    @ram-0000 : Merci pour l'idée, ca va me servir pour d'autre truc. C'est "set"

    Le cron utilise /bin/sh mais l'env de l'utilisateur root utilise /bin/bash. Cela peut-il avoir une incidence sur l'erreur remonté par gpg ?

  10. #10
    Invité
    Invité(e)
    Par défaut
    Citation Envoyé par Nelmo Voir le message
    Merci Mygale, je viens de comprendre mon erreur ...

    Maintenant, je me retrouve avec le message dans les logs (Pour chacun des dépots)
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    gpg: cannot open `/dev/tty': Aucun périphérique ou adresse
    Impossible de signer le depot ...
    A ce niveau, ce pourrait être un probleme de l'environnement de CRON ? Je ne comprend pas trop pourquoi /dev/tty est inaccessible
    man gpg

    --no-tty
    Make sure that the TTY (terminal) is never used for any output. This option is needed in some cases because GnuPG sometimes prints warnings
    to the TTY even if --batch is used.
    Tu peux ajouter cette option à ta commande gpg dans ton script et voir ce que ça donne.

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

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

    peut-on voir la ligne que tu as écrite dans ...crontab ? .../etc/cron* ?

    pourquoi un script bash aurait-il une erreur portant sur /bin/sh ?
    N'oubliez pas de consulter les cours shell, la FAQ, et les pages man.

  12. #12
    Membre confirmé
    Profil pro
    Inscrit en
    Avril 2006
    Messages
    142
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2006
    Messages : 142
    Par défaut
    C'était effectivement ca.

    J'ai mis un peu de temps a parcourir le man, je me disais que c'était plutot gpg qui était pas content ... Merci pour ta confirmation, je me demandais si ca allait marcher.

    Merci à vous, sujet reglé de mon coté, j'ai ajouté --no-tty dans ma commande gpg.

    @n_BaH :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
     59 16 * * * root /opt/scripts/depot/auto-sign.sh > /var/log/auto-sign.log 2>&1

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

Discussions similaires

  1. Script fonctionnant en manuel mais pas avec cron
    Par megayaya dans le forum Shell et commandes GNU
    Réponses: 9
    Dernier message: 28/03/2013, 12h06
  2. Réponses: 9
    Dernier message: 08/01/2013, 10h35
  3. Substitution ne fonctionne pas avec cron
    Par jejeman dans le forum Shell et commandes GNU
    Réponses: 2
    Dernier message: 24/10/2012, 16h03
  4. fichier shell qui ne fonctionne pas avec le cron mais fonctionne dans le shell
    Par diabli73 dans le forum Shell et commandes GNU
    Réponses: 4
    Dernier message: 20/10/2008, 19h12
  5. Réponses: 6
    Dernier message: 22/09/2008, 14h07

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