En las experiencias con Moodle me han sucedido ya varias cosas que contar, una de ellas es la ejecución del cron. En ambientes donde no se conoce bien la carga que va a tener el uso de Moodle se actua bajo la percepción de un mejor o peor caso, basado en lo cual se decide un tiempo entre ejecuciones del cron de Moodle, por ejemplo 20 minutos, lo que sucede es que en ambientes grandes 20 minutos muchas veces no resulta ser suficiente, para lo cual hay que buscar un mecanismo para evitar la doble ejecución del cron, ya que en algunas oportunidades la ejecución queda «tomada» o «pegada» y nunca termina o no termina correctamente.
Encontré en Preventing Duplicate Cron Jobs Execution la forma de hacerlo, pero incluyendo las lineas que llaman al cron de Moodle en una instalación que se asume está en /var/www/html/, adicionando ademas la posibilidad de guardar el log en la carpeta de logs de apache.
PIDFILE=/var/run/moodle_cron.pid if [ -f $PIDFILE ] then PID=$(cat $PIDFILE) ps -p $PID > /dev/null 2>&1 if [ $? -eq 0 ] then echo "El proceso ya se esta ejecutando" exit 1 else ## El proceso no se encuentra por lo que se asume que no se esta ejecutando echo $$ > $PIDFILE if [ $? -ne 0 ] then echo "No se puede crear el PID" exit 1 else NOW=$(date +"%Y-%m-%d_%H-%M-%S") FILE=/var/log/httpd/moodle_cron.$NOW.log /usr/bin/php /var/www/html/admin/cli/cron.php > $FILE fi fi else echo $$ > $PIDFILE if [ $? -ne 0 ] then echo "No se puede crear el PID" exit 1 fi fi rm $PIDFILE