Cómo añadir una tarea programada en el crontab de GNU Linux Red Hat. La añadiremos en el crontab del sistema para que se ejecute para todos los usuarios. También mostramos un ejemplo de script GNU Linux que permite hacer un export de la base de datos de Oracle Database y transferirla mediante FTP a otro equipo.
- Añadir una tarea programada en el crontab de GNU Linux Red Hat.
- Ejemplo de contenido de ficheros de script de GNU Linux.
- Tecnologías empleadas.
Añadir una tarea programada en el crontab de GNU Linux Red Hat
Os explicamos cómo añadir una tarea programada en el crontab de Linux Red Hat (válido para cualquier otra distribución GNU Linux como Ubuntu ó Fedora). La añadiremos en el crontab del sistema para que se ejecute para todos los usuarios.
1. Nos conectamos a Linux como superusuario (root), en nuestro caso hemos utilizado PuTTY para la conexión en modo consola remota. Lógicamente también lo podemos hacer desde el propio equipo iniciando una sesión:
2. Modificaremos el fichero crontab que se encuentra en la carpeta /etc, con lo cual accederemos a esta carpeta con el comando:
1 |
cd /etc |
Para comprobar que el fichero existe ejecutaremos:
1 |
ls -lah crontab |
Como resultado mostrará:
1 |
-rw-r--r-- 1 root root 553 jul 27 12:32 crontab |
Si queremos visualizar el contenido del fichero ejecutaremos el siguiente comando:
1 |
cat crontab |
Un ejemplo de contenido de este fichero podría ser:
1 |
SHELL=/bin/bash<br>PATH=/sbin:/bin:/usr/sbin:/usr/bin<br>MAILTO=root<br>HOME=/<br><span class="Estilo1"># run-parts<br>01 * * * * root run-parts /etc/cron.hourly<br>02 4 * * * root run-parts /etc/cron.daily<br>22 4 * * 0 root run-parts /etc/cron.weekly<br>42 4 1 * * root run-parts /etc/cron.monthly<br>30 15 * * * /oracle/export_oracle.sh<br>00 18 * * * /oracle/rman.sh >> /oracle/rman.out 2 >>/oracle/rman.err<br>00 14 * * 6 /oracle/rman_semanal.sh >> /oracle/rman_semanal.out 2>> /oracle/rman_semanal.err</span> |
Que indica lo siguiente:
- Todos los días a las 15:30 se ejecutará el fichero «export_oracle.sh».
- Todos los días a las 18:30 se ejecutará el fichero «rman.sh», redireccionando la salida al fichero «rman.out» y la salida de errores al fichero «rman.err».
- Sólo los sábados, a las 14:00 se ejecutará el fichero «rman_semanal.sh», redireccionando la salida al fichero «rman_semanal.out» y la salida de errores al fichero «rman_semanal.err».
Para añadir, eliminar o modificar alguna tarea programada editaremos el fichero «crontab», para ello utilizaremos el editor de ficheros de texto «vi» (se puede utilizar cualquier otro, como «nano»):
1 |
vi crontab |
Pulsaremos «a» para editar, a continuación añadiremos, modificaremos o eliminaremos la línea correspondiente a la tarea que queramos añadir, modificar o eliminar, siguiendo el formato adecuado (tal como se muestra en el ejemplo anterior) y guardaremos los cambios pulsando la tecla escape, a continuación «:wq» e INTRO.
Para garantizar que los cambios se han guardado correctamente volveremos a visualizar el contenido con el comando:
1 |
cat crontab |
En nuestro caso hemos modificado la hora de ejecución de una de las tareas existentes y hemos añadido una nueva tarea que se ejecutará sólo los miércoles:
1 |
SHELL=/bin/bash<br>PATH=/sbin:/bin:/usr/sbin:/usr/bin<br>MAILTO=root<br>HOME=/<br><span class="Estilo1"># run-parts<br>01 * * * * root run-parts /etc/cron.hourly<br>02 4 * * * root run-parts /etc/cron.daily<br>22 4 * * 0 root run-parts /etc/cron.weekly<br>42 4 1 * * root run-parts /etc/cron.monthly<br>30 15 * * * /oracle/export_oracle.sh<br>00 20 * * * /oracle/rman.sh >> /oracle/rman.out 2 >>/oracle/rman.err<br>00 14 * * 6 /oracle/rman_semanal.sh >> /oracle/rman_semanal.out 2>> /oracle/rman_semanal.err<br>00 03 * * 3 /oracle/manual.sh >> /oracle/manual.out 2>> /oracle/manual.err</span> |
Ejemplo de contenido de ficheros de script de GNU Linux
Un ejemplo del contenido de alguno de los ficheros de script que se ejecutan con el programador de tareas podría ser:
- export_oracle.sh:
1 2 3 4 |
<span class="Estilo1">export NLS_LANG=AMERICAN_AMERICA.WE8MSWIN1252 exp system/contraseña_system file=/copia_bd_export/bd.dmp log=/copia_bd_export/bd.log full=y ftp -n -u < /oracle/ftp.in > /oracle/ftp.out df -h > /oracle/espaciodisco.log</span> |
Este script de ejemplo realiza un exportación completa de la base de datos de Oracle Database completa a la carpeta «copia_bd_export» y al fichero «bd.dmp». También envía, mediante FTP, este fichero a otro equipo de la red, utilizando el fichero «ftp.in» con el siguiente contenido:
1 |
<span class="Estilo1">open 192.168.1.125 <br>user Administrador contraseña_administrador <br>bin<br>prompt<br>lcd /copia_bd_export<br>mput bd.dmp<br>bye</span> |
((se conecta por ftp al equipo 192.168.1.125, inicia sesión y transfiere el fichero bd.dmp))
Por último, ejecutamos el comando df -h que devuelve el espacio libre y ocupado de las unidades del equipo y lo redirigimos al fichero espaciodisco.log.
Tecnologías empleadas
- GNU Linux Red Hat.
- Oracle Database 11g.
- Servidor FTP de Windows.