Cron (Unix)
En el sistema operativo Unix, cron es un administrador regular de procesos en segundo plano (demonio) que ejecuta procesos o guiones a intervalos regulares (por ejemplo, cada minuto, día, semana o mes). Los procesos que deben ejecutarse y la hora a la que deben hacerlo se especifican en el archivo Cron se puede definir como el equivalente a Tareas Programadas de Windows. Vista generalCron es desencadenado por crond, un archivo de configuración que específica comando shell para ejecutarse periódicamente a una hora específica. Los archivos crontab son almacenados en donde permanecen las listas de trabajos y otras instrucciones para el demonio cron. Los usuarios habilitados para crear su archivo crontab se especifican en el archivo cron.allow. De manera análoga, los que no lo tienen permitido figuran en cron.deny. Estos dos últimos archivos se encuentran en /etc/cron.d/, o /etc/, dependiendo de la versión de Unix. Cada línea de un archivo crontab representa un trabajo y es compuesto por una expresión CRON, seguida por un comando shell para ejecutarse. Algunas implementaciones de cron, tal como en la popular BSD 4a edición escrita por Paul Vixie, e incluido en muchas distribuciones Linux, agrega una especificación de nombre de usuario dentro del formato como un sexto campo, como quién ejecutará el trabajo especificado (sujeto a la existencia de un usuario en /etc/passwd y permisos autorizados). Esto solo es permitido en el sistema crontab (/etc/crontab y /etc/cron.d/*), no en otros donde son asignados cada usuario es asignado a una configuración. Para el "día de la semana" (campo 5), ambos 0 y 7, son considerados Domingo, a través de algunas versiones de Unix tal como AIX no toma como válido el "7" según la página de man. Mientras que cuando el trabajo es ejecutado normalmente cuando fueron especificados los campos tiempo/fecha, todos coinciden con la hora y fecha actual, esto es una excepción. Si tanto el "día del mes" como "día de la semana" son restringidos (no son " * " ), entonces o el "día del mes" (campo 3) o el "día de la semana" (campo 5) debe coincidir con el día actual. Formato del archivo crontabArchivo crontab de ejemplo: SHELL=/bin/bash PATH=/sbin:/bin:/usr/sbin:/usr/bin MAILTO=root HOME=/ # run-parts 01 * * * * root nice -n 19 run-parts /etc/cron.hourly 50 0 * * * root nice -n 19 run-parts /etc/cron.daily 22 4 * * 0 root nice -n 19 run-parts /etc/cron.weekly 42 4 1 * * root nice -n 19 run-parts /etc/cron.monthly Para agregar, quitar o modificar tareas, hay que editar el crontab. Esto se hace con la orden crontab -e, que abrirá el editor definido en la variable de entorno EDITOR y cargará el archivo crontab correspondiente al usuario que está identificado. Cada vez que se ejecuta el crontab, se envía un mensaje al usuario que aparece en la variable de entorno MAILTO, si está habilitado, indicándole la tarea realizada.
1 0 * * * echo -n "" > /www/apache/logs/error_log A continuación se ejecuta el script: /home/user/test.pl cada 5 minutos. */5 * * * * /home/user/test.pl .--------------- minuto (0-59) | .------------ hora (0-23) | | .--------- día del mes (1-31) | | | .------ mes (1-12) o jan,feb,mar,apr,may,jun,jul... (meses en inglés) | | | | .--- día de la semana (0-6) (domingo=0 o 7) o sun,mon,tue,wed,thu,fri,sat (días en inglés) | | | | | * * * * * comando a ejecutar Nota: no soporta variables de entorno
SintaxisEl formato de configuración de cron es muy sencillo.
########################################################## #minuto (0-59), # #| hora (0-23), # #| | día del mes (1-31), # #| | | mes (1-12), # #| | | | día de la semana (0-6 donde 0=Domingo) # #| | | | | comandos # ########################################################## 15 02 * * *
EjemplosPor ejemplo:
Ejecuta la orden who todos los lunes a las 10:30 y guarda la salida en el archivo usuarios.txt Para especificar dos o más valores en cada variable, estas deben estar separadas por comas, siguiendo el ejemplo anterior:
Ejecuta la orden who todos los lunes cada media hora y guarda la salida en el archivo usuarios.txt Si queremos que se ejecute cada 15 minutos sería
o
En este ejemplo veremos como pasarle más de un comando al cron y de paso como puede programarse una descarga:
Este otro es para programar el apagado del PC. En este caso todos los sábados a las 21.30
Editar crontab de un usuario en particular crontab [ -u usuario ] archivo crontab [ -u usuario ] { -l | -r | -e } La opción -u se utiliza para indicar el crontab de usuario que queremos administrar. Sólo root podrá usar la orden crontab con esta opción. La opción -e se utiliza para editarlo Definición de horarios predefinidosHay varios valores predefinidos que se pueden utilizar para sustituir la expresión CRON.
También está disponible Manipulación de zonas horariasMuchas implementaciones de cron simplemente interpretan entradas crontab en la configuración del sistema de zona horaria en virtud de lo que establece el demonio al ejecutarse. Esto puede ser el origen de conflictos si grandes equipos multiusuarios tienen usuarios en varias zonas horarias, especialmente si el sistema de zona horaria predefinida incluye el confusor potencial DST. Por lo tanto una implementación cron puede tener cualquier caso especial "TZ=<timezone>" variable de entorno ajustando líneas en el usuario crontab, interpretando entradas relativas crontab posteriores a la zona horaria.[1] HistoriaPrimeras versionesCron en Unix versión7, escrita por Brian Kernighan, fue un sistema de servicio (después llamado demonio) invocado de
Esta versión de cron fue básica y robusta, pero también consumió recursos si encontraba algún trabajo que hacer o no; al escuchar esta descripción, Douglas Comer, un profesor de la Universidad Purdue, remarcó, "Ah, un algoritmo de poca memoria.". En un experimento en la Universidad Purdue pasados los años setenta para extender los servicios de cron a todos los 100 usuarios sobre un tiempo compartido VAX que fue situado en un lugar de mucha carga del sistema. Capacidad multi-usuarioLa siguiente versión de cron, con la liberación System V, fue creada para extender las capacidades de cron para todos los usuarios de un sistema Unix, no solo root (o superusuario). Aunque esto hoy puede ser trivial con la mayoría de Unix y sistemas tipo Unix con procesadores potentes y un número pequeño de usuarios, al momento que requiere un nuevo enfoque sobre un sistema 1MIPS teniendo alrededor de 100 cuentas de usuario. Versiones modernasCon la ventaja del proyecto GNU y Linux, apareció un nuevo cron. Lo más relevante de este es el cron Vixie, originalmente codificado por Paul Vixie en 1987. La versión 3 de cron Vixie fue liberada después de 1993. La versión 4.1 fue renombrada como Cron ISC (Consorcio de Sistema de Internet) y fue liberada en enero del 2004. La versión 3, con unas mínimas correcciones de error, es usada en la mayoría de las distribuciones de GNU/Linux y BSD. En 2007, RedHat bifurcó cron-vixie 4.1 al proyecto cronie e incluyó anacron 2.3 en 2009. Otra implementación popular incluye anacron y fcron. De cualquier forma, anacron no es un programa cron independiente; se basa en otro programa cron para llamarlo en orden para ejecutarse. Referencias
Enlaces externos
|
Portal di Ensiklopedia Dunia