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 :

Cron : Une tache s'exécute 10 fois


Sujet :

Administration système

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Homme Profil pro
    Inscrit en
    Mai 2011
    Messages
    24
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Mai 2011
    Messages : 24
    Par défaut Cron : Une tache s'exécute 10 fois
    Bonjour,

    je viens découvrir Cron pour exécuter les taches automatiquement.
    Mon fichier est un shell qui envoi un fichier par mail...

    jusqu'à la il marche bien... mais il envoie 10 fois???

    Voici mon crontab -e
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
     
    16 16 * * 5 envoimail > /dev/null # tous les vendredi 16h16.
    Pourquoi il m'envoie 10 mail ??? Je ne comprend rien, aidez-moi svp

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

    Avec ce que tu nous montres, il va être difficile de le savoir...

    que fait ton script? Peux-tu nous le montrer?

  3. #3
    Membre averti
    Homme Profil pro
    Inscrit en
    Mai 2011
    Messages
    24
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Mai 2011
    Messages : 24
    Par défaut
    Mon script fait sa :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    echo | mutt -s "$(date +%d.%m.%Y-[%H:%M]) Log fichier" mandahaa_1@yahoo.fr -a log.sql.gz

    j'ai même testé en rajoutant sleep 60 avant mail ... tjs plus 7 8 fois ...

  4. #4
    Expert confirmé

    Profil pro
    Inscrit en
    Janvier 2011
    Messages
    1 946
    Détails du profil
    Informations personnelles :
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations forums :
    Inscription : Janvier 2011
    Messages : 1 946
    Par défaut
    Salut,

    À tout hasard, le "echo" est-il vraiment nécessaire ?

  5. #5
    Modérateur
    Avatar de gangsoleil
    Homme Profil pro
    Manager / Cyber Sécurité
    Inscrit en
    Mai 2004
    Messages
    10 150
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Savoie (Rhône Alpes)

    Informations professionnelles :
    Activité : Manager / Cyber Sécurité

    Informations forums :
    Inscription : Mai 2004
    Messages : 10 150
    Par défaut
    Bonjour,

    Je suppose que par 10 executions, tu veux dire que tu recois 10 mails.

    Que disent les logs de la crontab sur l'execution ?
    Si tu executes la commande a la main, recois-tu plusieurs fois le mail ?
    "La route est longue, mais le chemin est libre" -- https://framasoft.org/
    Les règles du forum

  6. #6
    Membre averti
    Homme Profil pro
    Inscrit en
    Mai 2011
    Messages
    24
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Mai 2011
    Messages : 24
    Par défaut
    Si je lance le script à la main, je reçois une seule fois.

    j'ai enlevé "echo".

    pour le log...d'après moi, je n'ai pas de log installé...parce que je n'ai pas de /etc/syslog.conf.

    c'est vraiment bizarre que j'ai 10 fois le mail...

  7. #7
    Membre prolifique
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 839
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Février 2006
    Messages : 12 839
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par ltime Voir le message
    Bonjour,

    je viens découvrir Cron pour exécuter les taches automatiquement.
    Mon fichier est un shell qui envoi un fichier par mail...

    jusqu'à la il marche bien... mais il envoie 10 fois???

    Voici mon crontab -e
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
     
    16 16 * * 5 envoimail > /dev/null # tous les vendredi 16h16.
    Pourquoi il m'envoie 10 mail ??? Je ne comprend rien, aidez-moi svp
    Salut
    Déjà enlève le >/dev/null - Ainsi le compte qui a généré le cron recevra un email interne contenant tout ce qui est affiché par "envoimail" et la date de lancement.

    Ensuite rien ne t'empêche de créer un second script "toto.sh" qui fait ceci
    Code /bin/sh : Sélectionner tout - Visualiser dans une fenêtre à part
    date >>/tmp/verif

    Et mettre dans le cron
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    0,5,10,15,20,25,30,35,40,45,50,55 * * * * toto.sh     # Toutes les 5 mn
    Chaque fois que le cron lancera le script (toutes les 5mn), il rajoutera une ligne dans le fichier "/tmp/verif". Te suffit d'attendre le créneau horaire et regarder avant et après ledit fichier voir s'il a été augmenté de 1 ligne ou de 10 lignes...


    Citation Envoyé par ltime Voir le message
    pour le log...d'après moi, je n'ai pas de log installé...parce que je n'ai pas de /etc/syslog.conf.
    syslog est un outil de prise en charge des logs et non le log lui-même. Le log, lui, est lié au service et tout service possède bien un log (/var/log/cron pour le cron)

    Citation Envoyé par ltime Voir le message
    c'est vraiment bizarre que j'ai 10 fois le mail...
    Peut-être que ça fait 10 semaines qu'il tourne et que tu n'as regardé qu'aujourd'hui...
    Mon Tutoriel sur la programmation «Python»
    Mon Tutoriel sur la programmation «Shell»
    Sinon il y en a pleins d'autres. N'oubliez pas non plus les différentes faq disponibles sur ce site
    Et on poste ses codes entre balises [code] et [/code]

  8. #8
    Membre averti
    Homme Profil pro
    Inscrit en
    Mai 2011
    Messages
    24
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Mai 2011
    Messages : 24
    Par défaut
    Salut,

    J'ai essaie ton script comme cela :
    crontab
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    */5 * * * * toto  # toto est executable (chmod +x)
    dans toto

    Résultat : /tmp/verif
    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
    lundi 26 septembre 2011, 09:50:01 (UTC+0200)
    lundi 26 septembre 2011, 09:50:01 (UTC+0200)
    lundi 26 septembre 2011, 09:50:01 (UTC+0200)
    lundi 26 septembre 2011, 09:50:01 (UTC+0200)
    lundi 26 septembre 2011, 09:50:01 (UTC+0200)
    lundi 26 septembre 2011, 09:50:01 (UTC+0200)
    lundi 26 septembre 2011, 09:50:01 (UTC+0200)
    lundi 26 septembre 2011, 09:50:01 (UTC+0200)
    lundi 26 septembre 2011, 09:50:01 (UTC+0200)
    lundi 26 septembre 2011, 09:50:01 (UTC+0200)
    lundi 26 septembre 2011, 09:55:01 (UTC+0200)
    lundi 26 septembre 2011, 09:55:01 (UTC+0200)
    lundi 26 septembre 2011, 09:55:01 (UTC+0200)
    lundi 26 septembre 2011, 09:55:01 (UTC+0200)
    lundi 26 septembre 2011, 09:55:01 (UTC+0200)
    lundi 26 septembre 2011, 09:55:01 (UTC+0200)
    lundi 26 septembre 2011, 09:55:01 (UTC+0200)
    lundi 26 septembre 2011, 09:55:01 (UTC+0200)
    lundi 26 septembre 2011, 09:55:01 (UTC+0200)
    lundi 26 septembre 2011, 09:55:01 (UTC+0200)
    pour chaque fois ....

    ça prouve que cron execute bien 10 fois...mais pourquoi ?

    Citation Envoyé par Sve@r Voir le message
    Citation de Sve@r :

  9. #9
    Modérateur
    Avatar de gangsoleil
    Homme Profil pro
    Manager / Cyber Sécurité
    Inscrit en
    Mai 2004
    Messages
    10 150
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Savoie (Rhône Alpes)

    Informations professionnelles :
    Activité : Manager / Cyber Sécurité

    Informations forums :
    Inscription : Mai 2004
    Messages : 10 150
    Par défaut
    Bonjour,

    Comment edites-tu la crontab ? Est-ce que tu ne l'aurais pas ajoute a tous les utilisateurs ?
    "La route est longue, mais le chemin est libre" -- https://framasoft.org/
    Les règles du forum

  10. #10
    Membre averti
    Homme Profil pro
    Inscrit en
    Mai 2011
    Messages
    24
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Mai 2011
    Messages : 24
    Par défaut
    crontab -e.

    je n'ai pas ajouter pour ts les users...en plus je n'ai pas de 10 users...

    Citation Envoyé par gangsoleil Voir le message
    Bonjour,

    Comment edites-tu la crontab ? Est-ce que tu ne l'aurais pas ajoute a tous les utilisateurs ?

  11. #11
    Membre prolifique
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 839
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Février 2006
    Messages : 12 839
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par ltime Voir le message
    Salut,

    J'ai essaie ton script comme cela :
    crontab
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    */5 * * * * toto  # toto est executable (chmod +x)
    Tiens, je ne connaissais pas la syntaxe "*/5". J'ai appris un truc

    Citation Envoyé par ltime Voir le message
    ça prouve que cron execute bien 10 fois...mais pourquoi ?
    Ok, ton cron s'exécute 10 fois, maintenant je te crois.

    Donc maintenant il nous faudrait le listing du dossier /var/spool/cron

    Et aussi que tu nous dises combien tu as de processus "crond" qui tournent sur ta machine. Imaginons par exemple qu'il y en ait 10...
    Mon Tutoriel sur la programmation «Python»
    Mon Tutoriel sur la programmation «Shell»
    Sinon il y en a pleins d'autres. N'oubliez pas non plus les différentes faq disponibles sur ce site
    Et on poste ses codes entre balises [code] et [/code]

  12. #12
    Membre averti
    Homme Profil pro
    Inscrit en
    Mai 2011
    Messages
    24
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Mai 2011
    Messages : 24
    Par défaut
    ls /var/spool/cron/

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    atjobs  atspool  crontabs
    ls /var/spool/cron/crontabs/

    Bingo!!! : ps -x

    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
      997 ?        Ss     0:00 /usr/sbin/cron
     1028 ?        S      0:00 /bin/sh /usr/bin/mysqld_safe
     1140 ?        S      0:00 logger -t mysqld -p daemon.error
     1199 ?        Ss     0:03 /usr/sbin/sshd
     1614 tty2     Ss+    0:00 /sbin/getty 38400 tty2
     1615 tty3     Ss+    0:00 /sbin/getty 38400 tty3
     1616 tty4     Ss+    0:00 /sbin/getty 38400 tty4
     1617 tty5     Ss+    0:00 /sbin/getty 38400 tty5
     1618 tty6     Ss+    0:00 /sbin/getty 38400 tty6
     9839 ?        Ss     0:17 /usr/sbin/apache2 -k start
    11668 ?        Ss     0:00 cron restart
    11742 ?        Ss     0:00 cron restart
    11943 ?        Ss     0:00 cron restart
    12072 ?        Ss     0:00 cron restart
    12535 ?        Ss     0:00 cron restart
    12653 ?        Ss     0:00 cron restart
    12706 ?        Ss     0:00 cron restart
    12898 ?        Ss     0:00 cron restart
    13030 ?        Ss     0:00 cron restart
    Alors là... c'est bien 10 processus de cron qui est lancé...mais pourquoi et comment je vais assurer qu'un seul soit lancé au démarrage? sinon on peut dire que c'est RESOLU.

  13. #13
    Membre prolifique
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 839
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Février 2006
    Messages : 12 839
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par ltime Voir le message
    Alors là... c'est bien 10 processus de cron qui est lancé...mais pourquoi ?
    Mouais. La peur de manquer sans doute. Imaginons que le cron soit super important, style "ouais, mon cron gère le super accélérateur de particules européen", ben vaut mieux qu'il y en ait 10 qui tournent comme ça s'il y en a 9 qui plantent...
    Mon Tutoriel sur la programmation «Python»
    Mon Tutoriel sur la programmation «Shell»
    Sinon il y en a pleins d'autres. N'oubliez pas non plus les différentes faq disponibles sur ce site
    Et on poste ses codes entre balises [code] et [/code]

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

Discussions similaires

  1. Réponses: 0
    Dernier message: 21/03/2014, 12h34
  2. Problème d'execution d'une tache cron
    Par Jarod23 dans le forum Administration système
    Réponses: 2
    Dernier message: 20/03/2007, 10h19
  3. Exécuter une tache en arrière-plan
    Par EvilAngel dans le forum Windows
    Réponses: 6
    Dernier message: 20/02/2007, 11h15
  4. Creer une tache cron
    Par zulot dans le forum Serveurs (Apache, IIS,...)
    Réponses: 8
    Dernier message: 24/09/2006, 22h12
  5. Sous-requête excutée plusieurs fois dans une requête
    Par sheridan31 dans le forum Oracle
    Réponses: 8
    Dernier message: 03/07/2006, 16h18

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