A menudo, al escribir secuencias de comandos de Bash, deberá finalizar la secuencia de comandos cuando se cumpla una determinada condición o tomar medidas en función del código de salida de un comando.
En este artículo, cubriremos el exit
comando incorporado de Bash y los estados de salida de los comandos ejecutados.
Estado de salida
Cada comando de shell devuelve un código de salida cuando termina, ya sea con éxito o sin éxito.
Por convención, un código de salida de cero indica que el comando se completó correctamente y un código distinto de cero significa que se encontró un error.
La variable especial $?
devuelve el estado de salida del último comando ejecutado:
date &> /dev/null
echo $?
El date
comando se completó con éxito y el código de salida es cero:
0
Si intenta ejecutar ls
en un directorio que no existe, el código de salida será distinto de cero:
ls /nonexisting_dir &> /dev/null
echo $?
2
El código de estado se puede utilizar para averiguar por qué falló el comando. La página del manual de cada comando incluye información sobre los códigos de salida.
Al ejecutar una canalización de varios comandos, el estado de salida de la canalización es el del último comando:
sudo tcpdump -n -l | tee file.out
echo $?
En el ejemplo anterior echo $?
imprimirá el código de salida del tee
comando.
exit
Comando bash
El exit
comando sale del shell con un estado de N
. Tiene la siguiente sintaxis:
exit N
Si N
no se proporciona, el código de estado de salida es el del último comando ejecutado.
Cuando se usa en scripts de shell, el valor proporcionado como argumento del exit
comando se devuelve al shell como un código de salida.
Ejemplos
El estado de salida de los comandos se puede usar en comandos condicionales como if
. En el siguiente ejemplo grep
, saldrá con cero (lo que significa verdadero en scripts de shell) si la "cadena de búsqueda" se encuentra en filename
:
if grep -q "search-string" filename then
echo "String found."
else
echo "String not found."
fi
Al ejecutar una lista de comandos separados por &&
(AND) u ||
(OR), el estado de salida del comando determina si se ejecutará el siguiente comando de la lista. Aquí, el mkdir
comando se ejecutará solo si cd
devuelve cero:
cd /opt/code && mkdir project
Si un script termina exit
sin especificar un parámetro, el código de salida del script es el del último comando ejecutado en el script.
#!/bin/bash
echo "doing stuff..."
exit
Usar solo exit
es lo mismo que exit $?
u omitir el exit
.
Aquí hay un ejemplo que muestra cómo terminar el script si lo invoca un usuario no root:
#!/bin/bash
if [[ "$(whoami)" != root ]]; then
echo "Only user root can run this script."
exit 1
fi
echo "doing stuff..."
exit 0
Si ejecuta el script como root, el código de salida será cero. De lo contrario, el script saldrá con el estado 1
.
Conclusión
Cada comando de shell devuelve un código de salida cuando termina. El exit
comando se usa para salir de un shell con un estado dado.
Si tiene alguna pregunta o comentario, no dude en dejar un comentario.
0 Comentarios