Diferencia entre revisiones de «Cron (Unix)»
(→Formato del fichero crontab) |
|||
Línea 64: | Línea 64: | ||
Fichero crontab de ejemplo: | Fichero crontab de ejemplo: | ||
− | < | + | <syntaxhighlight lang="bash"> |
SHELL=/bin/bash | SHELL=/bin/bash | ||
PATH=/sbin:/bin:/usr/sbin:/usr/bin | PATH=/sbin:/bin:/usr/sbin:/usr/bin | ||
Línea 75: | Línea 75: | ||
22 4 * * 0 root nice -n 19 run-parts /etc/cron.weekly | 22 4 * * 0 root nice -n 19 run-parts /etc/cron.weekly | ||
42 4 1 * * root nice -n 19 run-parts /etc/cron.monthly | 42 4 1 * * root nice -n 19 run-parts /etc/cron.monthly | ||
− | </ | + | </syntaxhighlight> |
Para agregar, quitar o modificar tareas, hay que editar el crontab. Esto se hace con la orden ''crontab -e'', que abrirá el [[Editor de texto|editor]] definido en la [[variable de entorno]] '''EDITOR''' y cargará el fichero '''crontab''' correspondiente al usuario que está logueado. | Para agregar, quitar o modificar tareas, hay que editar el crontab. Esto se hace con la orden ''crontab -e'', que abrirá el [[Editor de texto|editor]] definido en la [[variable de entorno]] '''EDITOR''' y cargará el fichero '''crontab''' correspondiente al usuario que está logueado. | ||
− | + | Las primeras cuatro líneas son variables que indican lo siguiente: | |
+ | '''SHELL''' es el 'shell' bajo el cual se ejecuta el cron. Si no se especifica, se tomará por defecto el indicado en la línea /etc/passwd correspondiente al usuario que este ejecutando cron. | ||
− | + | '''PATH''' contiene o indica la ruta a los directorios en los cuales cron buscará el comando a ejecutar. Este path es distinto al path global del sistema o del usuario. | |
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
+ | '''MAIL TO''' es a quien se le envía la salida del comando (si es que este tiene alguna salida). Cron enviará un correo a quien se especifique en este variable, es decir, debe ser un usuario válido del sistema o de algún otro sistema. Si no se especifica, entonces cron enviará el correo al usuario propietario del comando que se ejecuta. | ||
+ | '''HOME''' es el directorio raíz o principal del comando cron, si no se indica entonces, la raíz será la que se indique en el archivo /etc/passwd correspondiente al usuario que ejecuta cron. | ||
Línea 126: | Línea 115: | ||
*La última columna corresponde a la [[Ruta (informática)|ruta]] absoluta del binario o ''script'' que se quiere ejecutar. | *La última columna corresponde a la [[Ruta (informática)|ruta]] absoluta del binario o ''script'' que se quiere ejecutar. | ||
+ | |||
+ | {| cellspacing="1" cellpadding="1" border="1" | ||
+ | |- | ||
+ | ! scope="col" | Ejemplo | ||
+ | ! scope="col" | Descripción | ||
+ | |- | ||
+ | | 01 * * * * | ||
+ | | Se ejecuta al minuto 1 de cada hora de todos los días | ||
+ | |- | ||
+ | | 15 8 * * * | ||
+ | | A las 8:15 a.m. de cada día | ||
+ | |- | ||
+ | | 15 20 * * * | ||
+ | | A las 8:15 p.m. de cada día | ||
+ | |- | ||
+ | | 00 5 * * 0 | ||
+ | | A las 5 a.m. todos los domingos | ||
+ | |- | ||
+ | | * 5 * * Sun | ||
+ | | Cada minuto de 5:00a.m. a 5:59a.m. todos los domingos | ||
+ | |- | ||
+ | | 45 19 1 * * | ||
+ | | A las 7:45 p.m. del primero de cada mes | ||
+ | |- | ||
+ | | 01 * 20 7 * | ||
+ | | Al minuto 1 de cada hora del 20 de julio | ||
+ | |- | ||
+ | | 10 1 * 12 1 | ||
+ | | A la 1:10 a.m. todos los lunes de diciembre | ||
+ | |- | ||
+ | | 00 12 16 * Wen | ||
+ | | Al mediodía de los días 16 de cada mes y que sea Miércoles | ||
+ | |- | ||
+ | | 30 9 20 7 4 | ||
+ | | A las 9:30 a.m. del dia 20 de julio y que sea jueves | ||
+ | |- | ||
+ | | 30 9 20 7 * | ||
+ | | A las 9:30 a.m. del dia 20 de julio sin importar el día de la semana | ||
+ | |- | ||
+ | | 20 * * * 6 | ||
+ | | Al minuto 20 de cada hora de los sábados | ||
+ | |- | ||
+ | | 20 * * 1 6 | ||
+ | | Al minuto 20 de cada hora de los sábados de enero | ||
+ | |- | ||
+ | | 59 11 * 1-3 1,2,3,4,5 | ||
+ | | A las 11:59 a.m. de lunes a viernes, de enero a marzo | ||
+ | |- | ||
+ | | 45 * 10-25 * 6-7 | ||
+ | | Al minuto 45 de todas las horas de los días 10 al 25 de todos los meses y que el día sea sábado o domingo | ||
+ | |- | ||
+ | | 10,30,50 * * * 1,3,5 | ||
+ | | En el minuto 10, 30 y 50 de todas las horas de los días lunes, miércoles y viernes | ||
+ | |- | ||
+ | | */15 10-14 * * * | ||
+ | | Cada quince minutos de las 10:00a.m. a las 2:00p.m. | ||
+ | |- | ||
+ | | * 12 1-10/2 2,8 * | ||
+ | | Todos los minutos de las 12 del día, en los días 1,3,5,7 y 9 de febrero a agosto. (El incremento en el tercer campo es de 2 y comienza a partir del 1) | ||
+ | |- | ||
+ | | 0 */5 1-10,15,20-23 * 3 | ||
+ | | Cada 5 horas de los días 1 al 10, el día 15 y del día 20 al 23 de cada mes y que el día sea miércoles | ||
+ | |- | ||
+ | | 3/3 2/4 2 2 2 | ||
+ | | Cada 3 minutos empezando por el minuto 3 (3,6,9, etc.) de las horas 2,6,10, etc (cada 4 horas empezando en la hora 2) del día 2 de febrero y que sea martes | ||
+ | |} | ||
+ | |||
+ | Como se puede apreciar en el último ejemplo la tarea cron que estuviera asignada a ese renglón con esos datos, solo se ejecutaría si se cumple con los 5 campos (AND). Es decir, para que la tarea se ejecute tiene que ser un martes 2 de febrero a las 02:03. Siempre es un AND booleano que solo resulta verdadero si los 5 campos son ciertos en el minuto específico. | ||
+ | |||
+ | El caso anterior deja claro entonces que: | ||
+ | |||
+ | El programa cron se invoca cada minuto y ejecuta las tareas que sus campos se cumplan en ese preciso minuto. | ||
+ | |||
+ | En algunas distribuciones cuando se editan crontabs de usuarios normales es necesario reiniciar el servicio para que se puedan releer los archivos de crontab en ''/var/spool/cron''. | ||
+ | <syntaxhighlight lang="bash"> | ||
+ | #> service crond restart | ||
+ | </syntaxhighlight> | ||
=== Ejemplos === | === Ejemplos === | ||
Por ejemplo: | Por ejemplo: | ||
− | :< | + | :<syntaxhighlight lang="bash">30 10 * * 1 /usr/bin/who >> /home/quien.tex</syntaxhighlight> |
Ejecuta la orden '''who''' todos los lunes a las '''10:30''' y guarda la salida en el fichero ''quien.tex'' | Ejecuta la orden '''who''' todos los lunes a las '''10:30''' y guarda la salida en el fichero ''quien.tex'' | ||
Para especificar dos o más valores en cada variable, estas deben estar separadas por comas, siguiendo con el ejemplo anterior: | Para especificar dos o más valores en cada variable, estas deben estar separadas por comas, siguiendo con el ejemplo anterior: | ||
− | :< | + | :<syntaxhighlight lang="bash">0,30 * * * 1 /usr/bin/who >> /home/quien.tex</syntaxhighlight> |
Ejecuta la orden who todos los lunes cada media hora y guarda la salida en el fichero ''quien.tex'' | Ejecuta la orden who todos los lunes cada media hora y guarda la salida en el fichero ''quien.tex'' | ||
Si queremos que se ejecute cada 15 minutos sería | Si queremos que se ejecute cada 15 minutos sería | ||
− | :< | + | :<syntaxhighlight lang="bash">0,15,30,45 * * * * /usr/bin/who >> /home/quien.tex</syntaxhighlight> |
o | o | ||
− | :< | + | :<syntaxhighlight lang="bash">*/15 * * * * /usr/bin/who >> /home/quien.tex</syntaxhighlight> |
En este ejemplo veremos como pasarle más de un comando al cron y de paso como puede programarse una descarga: | En este ejemplo veremos como pasarle más de un comando al cron y de paso como puede programarse una descarga: | ||
− | :< | + | :<syntaxhighlight lang="bash">30 21 * * * cd /media/sda7/dexter/distributions/isos;wget http://example.com/fichero_a_descargar.loquesea</syntaxhighlight> |
Este otro es para programar el apagado del PC. En este caso todos los sábados a las 21.30 | Este otro es para programar el apagado del PC. En este caso todos los sábados a las 21.30 | ||
− | :< | + | :<syntaxhighlight lang="bash">30 21 * * 6 /sbin/shutdown -h now</syntaxhighlight> |
'''Editar crontab de un usuario en particular''' | '''Editar crontab de un usuario en particular''' |
Revisión del 19:01 18 may 2010
El nombre cron viene del griego chronos que significa "tiempo". 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 en la que deben hacerlo se especifican en el fichero crontab
.
Cron se podría definir como el "equivalente" a Tareas Programadas de Windows.
Sumario
Vista General
Cron es impulsado por un cron, un archivo de configuraciòn que especifica comando shell para ejecutarse periòdicamente a una hora especifica. Los archivos crontab son almacenados en donde pemanecen las listas de trabajos y otras instrucciones para el demonio cron. Los usuarios habilitados para crear su fichero crontab se especifican en el fichero cron.allow. De manera análoga, los que no lo tienen permitido figuran en /etc/cron.d/cron.deny, o /etc/cron.deny, dependiendo de la versión de Unix.
Cada lìnea de un archivo contab representa un trabajo y es compuesto por una expresion 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 contab (/etc/crontab and /etc/cron.d/*), no en otros donde son asiganados cada usuario es asignado a una configuración.
Para el "día de la semana" (campo 5), ambos 0 y 7, son considerados Domingo, através de algunas versiones de Unix tal como AIX no toma como vàlido el "7" en el man. Mientras que cuando el trabajo es ejecutado normalmente cuando fueron especificados los campos tiempo/fecha, todos coinsiden con la hora y fecha actual, esto es una excepción.
Si ambos "día del mes" y "día de la semana" son restringidos (no " * " ), entonces tampoco el "día del mes" (campo 3) o el "día de la semana" (campo 5) debe coincidir con el día actual.
Historia
Primeras versiones
Cron en Unix versión7, escrita por Brian Kernighan, fue un sistema de servicio (después llamado demonio) invocado de /etc/inittab
cuando el {{Sistema_operativo|S.O.]] entròen modo multiusuario. Este algoritmo fue sencillo:
- Leer
/usr/etc/crontab
- Determinar si algún comando se estaba ejecutando en la fecha y hora actul, y si se ejecutaba como Root.
- Suspender por un minuto
- Repetir paso 1.
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 algorítmo de poca memoria.". En un experimento en la Universidad Purdue pasados los 1970s para extender los servicios de cron a todos los 100 usuarios sobre un tiempo compartido VAX que fue situadoen un lugar de mucha carga del sistema.
Capacidad Multi-usuario
La 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 mayoria 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 al rededor de 100 cuentas de usuario.
Versiones Modernas
Con 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. Versión 3 de cron Vixie fue liberado después de 1993. Version 4.1 fue renombrada como Cron ISC (Consorcio de Sistema de Internet) y fue liberado en Enero del 2004. Versión 3, con unas mínimas correcciones de error, es usadd en la mayoria de las distribuciones de Linux y BSDs.
En 2007, RedHat bifucó 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.
Iniciar cron
Cron es un demonio (servicio), lo que significa que solo requiere ser iniciado una vez, generalmente con el mismo arranque del sistema. El servicio de cron se llama crond. En la mayoría de las distribuciones el servicio se instala automáticamente y queda iniciado desde el arranque del sistema, se puede comprobar de varias maneras:
#> /etc/rc.d/init.d/crond status
#> /etc/init.d/crond status Usa cualquiera de los dos dependiendo de tu distro
crond (pid 507) is running...
o si tienes el comando service instalado:
#> service crond status
crond (pid 507) is running...
se puede también revisar a través del comando ps:
# ps -ef | grep crond
si por alguna razón, cron no esta funcionando:
#> /etc/rc.d/init.d/crond start
Starting crond: [ OK ]
Si el servicio no estuviera configurado para arrancar desde un principio, bastaría con agregarlo con el comando chkconfig:
#> chkconfig --level 35 crond on
Formato del fichero crontab
Fichero 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 fichero crontab correspondiente al usuario que está logueado.
Las primeras cuatro líneas son variables que indican lo siguiente:
SHELL es el 'shell' bajo el cual se ejecuta el cron. Si no se especifica, se tomará por defecto el indicado en la línea /etc/passwd correspondiente al usuario que este ejecutando cron.
PATH contiene o indica la ruta a los directorios en los cuales cron buscará el comando a ejecutar. Este path es distinto al path global del sistema o del usuario.
MAIL TO es a quien se le envía la salida del comando (si es que este tiene alguna salida). Cron enviará un correo a quien se especifique en este variable, es decir, debe ser un usuario válido del sistema o de algún otro sistema. Si no se especifica, entonces cron enviará el correo al usuario propietario del comando que se ejecuta.
HOME es el directorio raíz o principal del comando cron, si no se indica entonces, la raíz será la que se indique en el archivo /etc/passwd correspondiente al usuario que ejecuta cron.
Sintaxis
El formato de configuración de cron es muy sencillo.
- El símbolo almohadilla «#» es un comentario, todo lo que se encuentre después de ese carácter no será ejecutado por cron.
- El momento de ejecución se especifica de acuerdo con la siguiente tabla:
- Minutos: (0-59)
- Horas: (0-23)
- Días: (1-31)
- Mes: (1-12)
- Día de la semana: (0-6), siendo 1=lunes, 2=martes,... 6=sábado y 0=domingo (a veces también 7=domingo)
########################################################## #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 * * *
- Para especificar todos los valores posibles de una variable se utiliza un asterisco (*).
- La última columna corresponde a la ruta absoluta del binario o script que se quiere ejecutar.
Ejemplo | Descripción |
---|---|
01 * * * * | Se ejecuta al minuto 1 de cada hora de todos los días |
15 8 * * * | A las 8:15 a.m. de cada día |
15 20 * * * | A las 8:15 p.m. de cada día |
00 5 * * 0 | A las 5 a.m. todos los domingos |
* 5 * * Sun | Cada minuto de 5:00a.m. a 5:59a.m. todos los domingos |
45 19 1 * * | A las 7:45 p.m. del primero de cada mes |
01 * 20 7 * | Al minuto 1 de cada hora del 20 de julio |
10 1 * 12 1 | A la 1:10 a.m. todos los lunes de diciembre |
00 12 16 * Wen | Al mediodía de los días 16 de cada mes y que sea Miércoles |
30 9 20 7 4 | A las 9:30 a.m. del dia 20 de julio y que sea jueves |
30 9 20 7 * | A las 9:30 a.m. del dia 20 de julio sin importar el día de la semana |
20 * * * 6 | Al minuto 20 de cada hora de los sábados |
20 * * 1 6 | Al minuto 20 de cada hora de los sábados de enero |
59 11 * 1-3 1,2,3,4,5 | A las 11:59 a.m. de lunes a viernes, de enero a marzo |
45 * 10-25 * 6-7 | Al minuto 45 de todas las horas de los días 10 al 25 de todos los meses y que el día sea sábado o domingo |
10,30,50 * * * 1,3,5 | En el minuto 10, 30 y 50 de todas las horas de los días lunes, miércoles y viernes |
*/15 10-14 * * * | Cada quince minutos de las 10:00a.m. a las 2:00p.m. |
* 12 1-10/2 2,8 * | Todos los minutos de las 12 del día, en los días 1,3,5,7 y 9 de febrero a agosto. (El incremento en el tercer campo es de 2 y comienza a partir del 1) |
0 */5 1-10,15,20-23 * 3 | Cada 5 horas de los días 1 al 10, el día 15 y del día 20 al 23 de cada mes y que el día sea miércoles |
3/3 2/4 2 2 2 | Cada 3 minutos empezando por el minuto 3 (3,6,9, etc.) de las horas 2,6,10, etc (cada 4 horas empezando en la hora 2) del día 2 de febrero y que sea martes |
Como se puede apreciar en el último ejemplo la tarea cron que estuviera asignada a ese renglón con esos datos, solo se ejecutaría si se cumple con los 5 campos (AND). Es decir, para que la tarea se ejecute tiene que ser un martes 2 de febrero a las 02:03. Siempre es un AND booleano que solo resulta verdadero si los 5 campos son ciertos en el minuto específico.
El caso anterior deja claro entonces que:
El programa cron se invoca cada minuto y ejecuta las tareas que sus campos se cumplan en ese preciso minuto.
En algunas distribuciones cuando se editan crontabs de usuarios normales es necesario reiniciar el servicio para que se puedan releer los archivos de crontab en /var/spool/cron.
#> service crond restart
Ejemplos
Por ejemplo:
30 10 * * 1 /usr/bin/who >> /home/quien.tex
Ejecuta la orden who todos los lunes a las 10:30 y guarda la salida en el fichero quien.tex
Para especificar dos o más valores en cada variable, estas deben estar separadas por comas, siguiendo con el ejemplo anterior:
0,30 * * * 1 /usr/bin/who >> /home/quien.tex
Ejecuta la orden who todos los lunes cada media hora y guarda la salida en el fichero quien.tex
Si queremos que se ejecute cada 15 minutos sería
0,15,30,45 * * * * /usr/bin/who >> /home/quien.tex
o
*/15 * * * * /usr/bin/who >> /home/quien.tex
En este ejemplo veremos como pasarle más de un comando al cron y de paso como puede programarse una descarga:
30 21 * * * cd /media/sda7/dexter/distributions/isos;wget http://example.com/fichero_a_descargar.loquesea
Este otro es para programar el apagado del PC. En este caso todos los sábados a las 21.30
30 21 * * 6 /sbin/shutdown -h now
Editar crontab de un usuario en particular
crontab [ -u usuario ] fichero
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 predefinidos
Hay varios valores predefinidos que se pueden utilizar para sustituir la expresión CRON.
Entrada | Descripción | Equivale A |
---|---|---|
@yearly |
Se ejecuta una vez al año | 0 0 1 1 *
|
@annually |
(igual que @yearly ) |
0 0 1 1 *
|
@monthly |
Se ejecuta una vez al mes | 0 0 1 * *
|
@weekly |
Se ejecuta una vez a la semana | 0 0 * * 0
|
@daily |
Se ejecuta una vez al día | 0 0 * * *
|
@midnight |
(igual que @daily ) |
0 0 * * *
|
@hourly |
Se ejecuta una vez cada hora | 0 * * * *
|
También esta disponible @reboot
, que permite a un trabajo ejecutarse una vez cada vez que el demonio cron se inicie, que eso tipìcamente coincidirá con el arranque del servidor. Puede ser útili si es necesario levantar un servidor o demonio bajo un usuario en particular o si el usuario no tiene permisos al archivo rc.d/init.d.
Manipulación de Zonas horarias (Timezone)
Muchas implementaciones 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 predefinada 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 contab, interpretando entradas relativas crontab posterioresres a la zona horaria.[1]