Wo ist meine Protokolldatei von crontab?

9

no / var / log / cron, no /var/log/cron.log auf meinem debian7, Wo ist meine Logdatei von crontab?

ls /var/log/cron*
ls: cannot access /var/log/cron*: No such file or directory
it_is_a_literature
quelle

Antworten:

13

Ich denke an debian cronschreibt Logs in /var/log/syslog.
Wenn Ihr System davon abhängt rsyslogoder syslogdSie entweder in /etc/rsyslog.confoder /etc/syslog.conffür Zeile prüfen und auskommentieren können :

# cron.* /var/log/cron.log

und starten Sie dann die Dienste neu.

Wenn Ihr System systemdzum Beispiel davon abhängt , können Sie dies mit folgendem Befehl überprüfen:

journalctl _COMM=cron

oder

journalctl _COMM=cron --since="date" --until="date"

Für das Datumsformat können Sie journalctl überprüfen .

Taliezin
quelle
nein /etc/rsyslog.con und /etc/syslog.conf in meinem debian7.
it_is_a_literature
Für die erste Datei ist ein Tippfehler /etc/rsyslog.conf, wenn Sie nicht mit systemd arbeiten.
Taliezin
was ist mit sudo journalctl --since yesterday -u cron.service? Was ist _COMM?
Bindestrich
4

Standardmäßig wird die Ausgabe von crontabJobs an die lokale E-Mail-Adresse des besitzenden Benutzers gesendet. Beispiel: Die crontabAusgabe für aUser auf Host www.aDomain.com wird an [email protected] gesendet . Das System verwendet seinen Standardmailer, um die Aufgabe auszuführen.

Sie können diese Ausgabe an eine alternative E-Mail-Adresse umleiten, indem Sie eine MAILTOAnweisung in die crontab-Datei einfügen. Zum Beispiel:

# Mail any output to [email protected], no matter whose crontab this is
[email protected]
# Run the following command ten minutes after midnight, every day
10 0 * * *       $HOME/bin/aJob.sh 

Seien Sie vorsichtig, wenn Sie eine externe E-Mail-Adresse verwenden, um Crontab-Protokolle zu erhalten. Häufig gesendete Nachrichten werden möglicherweise von einem Spamfilter erfasst. Sie müssten dann die Nachrichten für Dienste wie Yahoo, HotMail oder Gmail als Nicht-Spam markieren .

Eine alternative Lösung wäre, die Ausgabe Ihrer crontab-Befehle in eine Datei Ihrer Wahl umzuleiten. Im folgenden Beispiel wird die Ausgabe stdoutund an stderrgesendet /tmp/aJob.log. Diese Methode verhindert, dass eine E-Mail-Nachricht gesendet wird.

# Run the following command ten minutes after midnight, every day
10 0 * * *       $HOME/bin/aJob.sh >> /tmp/aJob.log 2>&1

Eine andere Alternative besteht darin, stderrProtokolle an E-Mails und stdoutProtokolle an eine Datei zu senden . In diesem Fall werden Sie per E-Mail benachrichtigt, wenn Ihre crontabBefehle unerwartete Fehlermeldungen generieren. Der Unterschied zum vorherigen Beispiel besteht darin, dass 2>&1entfernt wird, damit die stderrAusgabe an die Konsole und damit an E-Mails gesendet werden kann.

# Mail any output to [email protected], no matter whose crontab this is
[email protected]    
# Run the following command ten minutes after midnight, every day
10 0 * * *       $HOME/bin/aJob.sh >> /tmp/aJob.log

Lesen Sie mehr Crontab-Tabellen und Crontab-Befehl

ikrabbe
quelle
0

Da dies nicht mit debian markiert ist und auch in Fedora-Suchen angezeigt wird, können Sie hier nach aktuellen (systemd-basierten) Fedora suchen:

sudo systemctl status crond

Typische Ausgabe

 crond.service - Command Scheduler
   Loaded: loaded (/usr/lib/systemd/system/crond.service; enabled; vendor preset: enabled)
   Active: active (running) since Sun 2019-09-29 16:09:21 CEST; 47min ago
 Main PID: 1167 (crond)
    Tasks: 1
   Memory: 2.8M
      CPU: 948ms
   CGroup: /system.slice/crond.service
           └─1167 /usr/sbin/crond -n

Sep 29 16:09:21 ncelrnd0216 systemd[1]: Started Command Scheduler.
Sep 29 16:09:21 ncelrnd0216 crond[1167]: (CRON) STARTUP (1.5.4)
Sep 29 16:09:21 ncelrnd0216 crond[1167]: (CRON) INFO (Syslog will be used instead of sendmail.)
Sep 29 16:09:21 ncelrnd0216 crond[1167]: (CRON) INFO (RANDOM_DELAY will be scaled with factor 31% if used.)
Sep 29 16:09:21 ncelrnd0216 crond[1167]: (CRON) INFO (running with inotify support)

und alldie Protokolle mit

journalctl --unit crond -n all
Eddygeek
quelle