Cada proceso en Linux produce tres flujos de datos, stdin, stdout y stderr:
- stdin : Toma la entrada del usuario a través del teclado
- stdout : Muestra la salida en la pantalla
- stderr : Muestra información de error en la pantalla
Cada flujo de datos tiene una identificación numérica:
Id numérico | Nombre |
0 | stdin |
1 | stdout |
2 | stderr |
Expliquemos la redirección un poco más con detalle:
Cómo redirigir la salida estándar y el error estándar en Bash:
Para redirigir la salida estándar del comando, usaremos 1 con un operador de redirección que sea mayor que el signo>:
$ls 1>stdout.txtEl comando anterior creará un archivo y colocará la salida estándar del comando ls en el archivo stdout.txt.
Para leer el archivo stdout.txt, use:
$gatostdout.txt
También podemos redirigir el error estándar a un archivo usando el comando:
$gatomyfile.txt2>stderr.txt
Para ver el archivo stderr.txt, use:
$gatostderr.txt
Asegúrese de que el uso de 2 sea mayor que el signo>. Dado que no hay un archivo myfile.txt en el directorio, el comando cat dará un error que se agregará al archivo stderr.txt.
Estas salidas estándar también se pueden redirigir con un solo comando, use:
$ls 1>stdout.txt2>stderr.txt
La salida del comando ls se escribirá en el stdout.txt archivo, pero el stderr.txt permanecerá vacío porque no habrá error.
Ahora hagámoslo con stderr.txt:
$gatomyfile.txt1>stdout.txt2>stderr.txt
Utilice el comando mencionado a continuación para leer stderr.txt.
$gatostderr.txt
Y, por supuesto, stdout.txt estará vacío.
Conclusión :
El comando de Linux al ejecutarse proporciona una salida estándar que podría ser una salida exitosa o una salida de error. Generalmente, estas salidas no se pueden redirigir utilizando operadores de redirección; necesitamos usar identificadores numéricos específicos con el signo>. En esta guía, aprendimos cómo usar estas teclas numéricas para redirigir la salida estándar a un archivo con ejemplos.