Cron/es

En este artículo se describe como configurar y utilizar los demonios cron en Gentoo Linux.

¿Qué hace cron?
Cron es un demonio que ejecuta tareas de manera programada basado en la configuración de la orden crontab. Cumple esta tarea despertando cada minuto y revisando la existencia de trabajos de cron en las crontabs de los usuarios.

El cron de facto
Existen varias implementaciones del gestor cron para escoger en Portage. Todas ofrecen un interfaz similar, el uso de la orden crontab o una orden parecida. Existe una herramienta relacionada llamada Anacron, que trabaja junto a cron en sistemas que no están encendidos de forma continua.

Vale la pena mencionar que los paquetes disponibles de cron dependen de. Este paquete técnicamente no aparece en las dependencias de los paquetes cron, pero ofrece la funcionalidad de tipo cron de la que la mayoría de los usuarios disfrutan.

Antes de comenzar a trabajar con cron, tendrá que elegir que implementación quiere utilizar. Para facilitar la toma de esta decisión, abajo se resume información acerca de cada una.

vixie-cron
Vixie cron es un cron con muchas características, basado en el cron SysV. Cada usuario tiene su propio crontab y le está permitido especificar variables de entorno dentro de su crontab. A diferencia de las demás variantes de cron, también ofrece soporte para SELinux y PAM. Soporta menos plataformas que Dcron, pero más que Fcron.

Características de :


 * Soporte para SELinux
 * Soporte para PAM
 * Definir variables de entorno en las crontabs (PATH, SHELL, HOME, etc.)
 * Cada usuario tiene una crontab personal, el acceso se controla mediante y

cronie
Cronie es un proyecto derivado de vixie-cron realizado por Fedora. Debido a que es una derivación de vixie-cron, ofrece las mismas características que éste. Además cronie incluye una implementación de anacron que se puede habilitar mediante el ajuste USE.

dcron (El cron de Dillon)
Dcron pretende ser una implementación sencilla, elegante y segura de cron. No permite especificar variables de entorno en las crontabs y todos los trabajos cron se ejecutan desde. Al igual que vixie cron, cada usuario tiene su propia crontab.

Características de :


 * Rápido, sencillo y sin características innecesarias
 * El acceso a crontab se limita al grupo cron, en otras palabras, no requiere capacidades externas

fcron
Fcron pretende sustituir a vixie cron y anacron. Su diseño toma en cuenta los sistemas que no están encendidos continuamente y está repleto de características adicionales. Tiene restricciones para iniciar los trabajos, control del orden de ejecución, la posibilidad de asignar valores "nice" (prioridades) a los trabajos y de ejecutar trabajos al arrancar el sistema. Eche un vistazo a la página oficial de fcron para obtener más información.

Características de :


 * Diseñado para funcionar en sistemas que no están constantemente encendidos, esto es, puede ejecutar una tarea después de reiniciar la máquina si no se ejecutó en el momento en el que estaba programada
 * Configuración de variables de entorno y muchas otras opciones en las crontabs
 * Sintaxis mejorada para crontabs con soporte de muchas características nuevas
 * Cada usuario puede tener una crontab personal, el acceso se controla con los ficheros y
 * Sintaxis mejorada de crontab con soporte para muchas características nuevas

bcron
Bcron es un sistema cron nuevo, diseñado para operar de manera segura. Para esto el sistema se divide en varios programas separados, cada uno responsable de una tarea distinta con comunicaciones estrictamente controladas entre ellas. El interfaz de usuario es un reemplazo exacto para programas similares (como vixie-cron), aunque la parte interna es muy diferente. Para más información vea la página de bcron en http://untroubled.org/bcron.

Características de :


 * Reemplazo exacto de vixie-cron
 * Diseño multiproceso
 * Soporte nativo de horario de verano

anacron
Anacron no es un demonio cron, es una aplicación que funciona conjuntamente con uno. Ejecuta tareas a intervalos especificados en días y no asume que el sistema está encendido de manera continua. Ejecuta las tareas que no pudieron ejecutarse si el sistema estaba apagado. Anacron normalmente requiere un demonio cron para ejecutarlo diariamente.

Instalación
Elija la implementación de cron que prefiera e instálela.

Asegúrese de que el demonio cron elegido se ha añadido al proceso init del sistema. Si no se realiza este paso, el demonio cron no podrá realizar su trabajo.

Opcionalmente, si no se ha instalado Fcron, la instalación de Anacron como auxiliar del demonio cron puede ser una sabia elección.

De nuevo, no olvide añadir acacron al proceso init del sistema.

Crontab del sistema
Los mensajes que se indican después de la instalación de algunos de estos paquetes cron indican al usuario que debe lanzar la orden crontab /etc/crontab. El fichero es la "crontab del sistema". Una instalación de cron lo usa junto a para ejecutar los guiones que se encuentran en. Observe que solo vixie-cron y cronie programan las tareas en de forma automática. Los usuarios de dcron y fcron deberán ejecutar crontab /etc/crontab cada vez que hagan cambios al fichero.

Por favor, observe que los trabajos programados en la crontab del sistema puede que no aparezcan en la lista de trabajos cron mostrados cuando se lanza crontab -l.

Por supuesto, los usuarios pueden elegir no usar ninguna crontab del sistema. Si se ha elegido dcron o fcron, no lance crontab /etc/crontab. Si se ha elegido vixie-cron, cronie o bcron, se deben comentar todas las líneas de.

Una forma fácil y rápida de comentar todos los archivos en un fichero es mediante la orden sed. Lance la siguiente orden para comentar todas las líneas en

Dar acceso a cron a usuarios en los que se confía
Para que aquéllos usuarios que no sean root tengan acceso al demonio cron, se debe leer esta sección, de lo contrario se puede proceder con la siguiente,  Planificar trabajos de cron.

Sin importar qué paquete de cron se utilice, si se quiere permitir que un usuario use crontab, primero se tendrá que pertenecer al grupo cron. Por ejemplo, si se quiere agregar el usuario wepy al grupo cron se debe lanzar:

Cuando se utiliza dcron el paso de arriba es el único necesario para que un usuario tenga acceso al crontab. Los usuarios de dcron pueden pasar a la siguiente sección Planificar trabajos de cron, el resto de usuarios tendrán que continuar leyendo.

Si se utiliza fcron, se deben editar los ficheros y. La forma más segura para el sistema es, en primer lugar, denegar a todos los usuarios el acceso en y luego permitir el acceso explícitamente en.

Si un usuario (de nuevo wepy para este ejemplo) quiere poder planificar sus propios trabajos de cron, entonces se le debe añadir a de la siguiente forma:

Si se ha eligido vixie-cron o cronie, entonces simplemente se debe editar el fichero.

Por ejemplo, para permitir acceso al usuario wepy, se añade a de la siguiente forma:

Planificar trabajos de cron
El proceso de editar los archivos crontab es distinto para cada paquete, pero todos soportan el mismo conjunto básico de órdenes: agregar y reemplazar crontabs, modificar crontabs, borrar crontabs y listar los trabajos en los crontabs. La siguiente lista muestra cómo ejecutar estas órdenes para cada paquete.

Antes de poder usar cualquiera de estas órdenes, se necesita comprender la propia crontab. Cada línea en una crontab especifica cinco campos de tiempo en el siguiente orden: los minutos (0-59), las horas (0-23), los días del mes (1-31), los meses (1-12) y los días de la semana (0-7, el lunes es el día 1, el domingo es día 0 y el día 7). Los día de semana y mes se pueden especificar mediante abreviaturas de tres letras (en inglés), como mon, tue, jan, feb, etc. Cada campo también puede especificar un rango de valores (por ejemplo, 1-5 o mon-fri), una lista separada por comas de valores (por ejemplo, 1,2,3 o mon,tue,wed) o un rango de valores con un paso (por ejemplo, 1-6/2 para 1,3,5).

Tal vez suene algo confuso, pero con algunos ejemplos es fácil comprobar que no es tan complicado como parece.

Para poner a prueba lo que se ha expuesto, registraremos paso a paso algunos trabajos cron. En primer lugar crearemos un archivo llamado que tenga el siguiente aspecto:

Ahora se puede añadir esta crontab al sistema con la "nueva orden" de la tabla de arriba

Para verificar los trabajos de cron planificados se utiliza la ''orden listar" apropiada de la tabla de arriba.

Ahora se debería mostrar una lista que refleja el contenido de. Si no es así puede que se haya utilizado una orden incorrecta para actualizar la crontab.

This crontab should echo "I really like cron" every minute of every hour of every day every other month. Obviously a user would only do that if they really liked cron. The crontab will also echo "I like cron a little" at 16:30 every day in January and February. It will also echo "I don't really like cron" at 3:10 on the January 1st.

Si se utiliza anacron, se debe continuar leyendo esta sección, sino se puede proceder con la siguiente sección, sobre cómo editar crontabs.

Los usuarios de anacron querrán modificar. Este fichero contiene cuatro campos: el número de días entre cada ejecución, el retraso en minutos después de cada ejecución, el nombre del trabajo y la orden a lanzar.

For example, to have it run echo "I like anacron" every 5 days, 10 minutes after anacron is started, enter the following:

Anacron exits after all of the jobs in anacrontab have finished. To check to see if these jobs should be performed every day, a cron daemon will be used. The instructions at the end of the next section explain how this should be handled.

Editar crontabs
Being realistic, no user would want their system telling them how much they like cron every minute. As a step forward, remove the previous example crontab using the corresponding remove command from the table above. Use the corresponding list command to view the cron-jobs afterward to make sure it worked.

No cron-jobs should be displayed in the output from crontab -l. If cron jobs are listed, then the remove command failed to remove the crontab; verify the correct remove command for the system's cron package.

Now that we have a clean state, let's put something useful into the root crontab. Most people will want to run updatedb on a weekly basis to make sure that mlocate works properly. To add that to the system's crontab, first edit again so that it looks like the following:

That would make cron run updatedb at 2:22 A.M. on Monday morning every week. Now input the crontab with the proper new command from the table above, and check the list again.

Now let's say emerge --sync should be ran on a daily schedule in order to keep the Portage tree up to date. This could be done by first editing and then using crontab crons.cron as was done in the example above, or by using the proper edit command from the table above. This gives you a way to edit your user's crontab in situ, without depending on external files like.

That should open your user's crontab with an editor. We want to have emerge --sync run every day at 6:30 A.M., so make it look something like this:

Again, check the cron-jobs list as done in the previous examples to make sure the jobs are scheduled. If they are all there, then the system is ready to rock and roll.

Usar cronbase
As mentioned earlier, all of the available cron packages depend on. The cronbase package creates, and a script called. Notice the default file contains something like this:

To avoid going into much detail, assume these commands will effectively run hourly, daily, weekly and monthly scripts. This method of scheduling cron-jobs has some important advantages:


 * Las tareas se ejecutarán incluso si la computadora se apagó cuando estaban programadas para ejecutarse.
 * Es fácil para los mantenedores de paquetes ubicar los guiones en estos lugares.
 * El administrador conoce exactamente donde se guardan las tareas cron y el crontab, facilitándole el proceso de respaldo y recuperación de estas partes de sus sistemas.

Usar anacron
As mentioned earlier, anacron is used on systems not meant to be run continuously (like most of the desktop installations). Its default configuration file,, is usually similar to the following:

The main difference between this and other common crontabs is that with anacron there is no fixed date/hour for the job scheduling, but only the period between every run. When anacron is started, it will check the contents of a set of files in and calculate if the corresponding entry in the configuration file has expired since the last run. If it has, then the command is invoked again.

Como nota final, es importante comentar cualquier entrada que se solape con otro cron instalado en el sistema, como en el siguiente ejemplo con la crontab de vixie-cron:

Si no se hace esto, las partes diarias, semanales y mensuales se lanzarán en momentos distintos tanto por el demonio cron como por anacron, conduciendo a posibles ejecuciones dobles de la tareas.

Notas finales
Recuerde que cada paquete cron es distinto y que la gama de características varía bastante. Consulte las páginas del manual de crontab, fcrontab o anacrontab, dependiendo del demonio cron que se haya utilizado.

¡Buena suerte!

Resolución de problemas
Cuando se tienen problemas para conseguir que cron funcione correctamente, esta lista podría ser útil.

¿Está corriendo cron?
Lance ps ax | grep cron y ¡Asegúrese de que cron se muestra en la lista de procesos!

¿Está funcionado cron?
Intente lo siguiente:

A continuación compruebe si se modifica periodicamente.

¿Están lanzándose sus órdenes?
Al igual que en el caso anterior pero redirija también la salida de errores:

¿Puede cron lanzar su tarea?
Revise los registros de cron en busca de errores, normalmente se encuentran en o en.

¿Hay algún fichero s?
Normalmente cron envía un fichero si hay un problema. Compruebe su correo electrónico y también comprueba la creación de un fichero.

Alternativas a Cron
Algunas empresas de alojamiento de servidores no permiten el acceso a cron, sin embargo puede encontrar un montón de alternativas a cron gratis o de pago:


 * EasyCron