Cron-Job: Unterschied zwischen den Versionen
(cron job test) |
|||
Zeile 4: | Zeile 4: | ||
'''Wichtig''': Sie müssen den Cron-Prozess unbedingt aufsetzen, andernfalls funktioniert Ihre Moodle-Site '''nicht''' richtig. | '''Wichtig''': Sie müssen den Cron-Prozess unbedingt aufsetzen, andernfalls funktioniert Ihre Moodle-Site '''nicht''' richtig. | ||
Wenn der Cron-Prozess nicht richtig funktioniert, bekommen Sie eine entsprechende Meldung auf der Seite '''Website-Administration-Mitteilungen'''. Damit lässt sich der Cron-Job überprüfen. | |||
Um das Moodle-Cron-Skript in regelmäßigen Abständen auszuführen, wird ein spezielles Programm (typischerweise <code>cron</code>) verwendet. | Um das Moodle-Cron-Skript in regelmäßigen Abständen auszuführen, wird ein spezielles Programm (typischerweise <code>cron</code>) verwendet. |
Version vom 6. April 2013, 13:05 Uhr
Der Cron-Prozess von Moodle ist ein PHP-Skript, das zum Moodle-Standardpaket gehört, und das regelmäßig im Hintergrund ausgeführt werden muss. Das Skript führt in verschiedenen Zeitabständen verschiedene Aufgaben aus, z.B. E-Mails-versenden, Moodle-Berichte aktualisieren, RSS-Feeds aktualisieren , Aktivitätenabschluss kennzeichnen, Forumsbeiträge veröffentlichen. Da zu verschiedenen Aufgaben verschiedene Zeitintervalle gehören, werden nicht alle Aufgaben jedes Mal ausgeführt, wenn das Cron-Skript gestartet wird.
Wichtig: Sie müssen den Cron-Prozess unbedingt aufsetzen, andernfalls funktioniert Ihre Moodle-Site nicht richtig.
Wenn der Cron-Prozess nicht richtig funktioniert, bekommen Sie eine entsprechende Meldung auf der Seite Website-Administration-Mitteilungen. Damit lässt sich der Cron-Job überprüfen.
Um das Moodle-Cron-Skript in regelmäßigen Abständen auszuführen, wird ein spezielles Programm (typischerweise cron
) verwendet.
Einen Cron-Job einrichten bedeutet im wesentlichen eine Zeile in die Liste der Cron-Prozesse auf Ihrem Server einzutragen. Auf Unix-basierten Systemen ist diese Liste eine Datei crontab, die alle Nutzer/innen des Servers haben.
Allgemeines
Das Aufsetzen eines Cron-Prozesses erfordert zwei Schritte:
- Das richtige Kommando identifizieren, das ausgeführt werden muss.
- Den richtigen Platz auf Ihrem Server finden, wo das Kommando eingetragen werden muss.
Das richtige Kommando identifizieren
In Moodle gibt es zwei Möglichkeiten, das Cron-Skript auszuführen:
- CLI-Skript (CLI = command line interpreter, Kommandozeileninterpreter): Der Pfad zu diesem Skript ist /path_to_moodle/admin/cli/cron.php. Dieses Skript muss von einem PHP CLI Programm auf Ihrem Server ausgeführt werden, z.B. durch folgendes Kommando:
/usr/bin/php /path/to/moodle/admin/cli/cron.php
- Webbasiertes Skript: Dieses Skript muss im Webbrowser aufgerufen werden, der Zugriff erfolgt über die URL <code>http://Ihre.Moodle.Site/admin/cron.php</code>. Sie können einen kommandozeilen-basierten Webbrowser verwenden (z.B.
wget
), d.h. das Kommando könnte z.B. lauten:
/usr/bin/wget http://Ihre.Moodle.Site/admin/cron.php
Der Vorteil dieses Kommandos besteht darin, dass es von überall ausgeführt werden kann, also nicht notwendigerweise von Ihrem Moodle-Server aus (auf den Sie evtl. gar keinen Zugriff haben), sondern von irgend einem Server aus, auf den Sie zugreifen dürfen.
Den richtigen Platz auf dem Server finden
Dieser Platz hängt ganz wesentlich von Ihrem System ab. Lesen Sie die Dokumentation für Ihre Plattform oder von Ihrem Hosting-Provider. In den meisten Fällen müssen Sie das richtige Kommando (siehe vorheriger Abschnitt) in eine Datei eintragen - entweder über eine ggeignete Benutzerschnittstelle oder durch direktes Editieren dieser Datei.
Wenn Sie das CLI-Skript verwenden, dann müssen Sie außerdem sicherstellen, dass es vom richtigen Nutzer (des Servers) ausgeführt wird. Diese Einschränkung gilt nicht, wenn Sie das webbasierte Skript verwenden.
Beispiel: Einrichten des Cron-Prozesses unter Ubuntu/Debian Linux, angemeldet als Nutzer root
:
- Verwende das crontab-Kommando, um den Crontab-Editor für den Nutzer
www-data
zu öffnen (das ist der Apache Webservernutzer auf Debian-basierten Systemen):
$ crontab -u www-data -e
- Ergänzen Sie im Crontab-Editor folgende Zeile, um das CLI-Skript alle 15 Minuten auszuführen:
*/15 * * * * /usr/bin/php /path/to/moodle/admin/cli/cron.php >/dev/null
- Hinweis: Der Eintrag
>/dev/null
am Ende der Zeile sendet alle Ausgaben des Skripts an "bin" und und verhindert, dass Sie alle 15 Minuten eine E-Mail erhalten.
- Alternativ können Sie folgende Zeile eintragen, um das webbasierte Skript alle 15 Minuten auszuführen:
*/15 * * * * /usr/bin/wget -q -O /dev/null/ http://Ihre.Moodle.Site/admin/cron.php
Siehe auch Cron unter Windows bzw. Cron unter Mac OS X für Windows- bzw. MacOSX-Server (englische Anleitungen).
Cron-Einstellungen in Moodle
Als Administrator/in können Sie auf der Seite Einstellungen > Website-Administration > Sicherheit > Website-Rechte verschiedene Einstellungen für den Cron-Prozess vornehmen.
Remote Cron
Wenn Sie das webbasierte Cron-Skript verwenden, können Sie den Moodle-Cron-Job von einem beliebigen anderen Server aus steuern.
Siehe auch
Diskussionsbeiträge im Kurs Using Moodle auf moodle.org:
- Cron - can someone give me a quick confirmation of function?
- Cronjob Question
- Slow cron : avoiding simultaneous cron
- Visibility of cron.php
- How to log the output of a Scheduled Task on Windows - this discussion explains a nice trick that can be very useful when you are experiencing problems with your Windows Scheduled Task and you need to log the output of the Scheduled Task to a log file.