Cómo utilizar «Documentos aquí» en Bash en Linux

Una ventana de terminal en un sistema informático Linux.
Fatmawati Achmad Zaenuri / Shutterstock

Los extraños «documentos aquí» le permiten utilizar la redirección de entrada / salida dentro de los scripts Bash en Linux. Son una excelente manera de automatizar los comandos que necesita para ejecutar en una computadora remota.

Aquí Documentos

Muchos comandos en Linux tienen nombres de dos o tres letras. Esto es en parte lo que da lugar a la idea de que Linux es difícil de aprender y está lleno de comandos arcanos. Pero uno de los nombres más extraños en Linux no es uno de los crípticamente cortos. «Aquí los documentos» no son documentos, y tampoco está muy claro a qué se refiere el «aquí».

Son una construcción relativamente oscura, pero son útiles. Por supuesto, esto es Linux, por lo que hay más de una forma de despellejar a un gato. Algunas de las funciones proporcionadas por estos documentos se pueden reproducir de otras formas. Estos métodos alternativos suelen ser más complicados. En programación y scripting, «más complicado» también significa «más propenso a errores» y que su código es más difícil de mantener.

Donde aquí los documentos realmente sobresalen es en la automatización de comandos que desea enviar a una computadora remota desde una conexión establecida desde dentro de un script. Hacer la conexión es fácil, pero una vez que se ha realizado la conexión, ¿cómo «bombeas» tus comandos desde tu script al shell en la computadora remota? Aquí los documentos le permiten hacer eso de manera muy simple.

Principios básicos de los documentos Here

La representación idiomática de un documento aquí se ve así:

COMMAND << cadena_límite
 .
 .
texto 
datos
variables
.
.
cadena_límite
  • COMANDO : Puede ser cualquier comando de Linux que acepte entradas redirigidas. Tenga en cuenta que el echocomando no acepta entrada redirigida . Si necesita escribir en la pantalla, puede usar el catcomando, que lo hace .
  • << : el operador de redirección.
  • limit_string : esta es una etiqueta. Puede ser lo que quiera siempre que no aparezca en la lista de datos que está redirigiendo al comando. Se utiliza para marcar el final de la lista de texto, datos y variables.
  • Lista de datos : una lista de datos que se enviarán al comando. Puede contener comandos, texto y variables. El contenido de la lista de datos se introduce en el comando una línea a la vez hasta que se encuentra _limit_string.

Probablemente verá ejemplos de aquí documentos que utilizan «EOF» como la cadena de límite. No favorecemos ese enfoque. Funciona, pero «EOF» significa «Fin de archivo». Aparte del raro caso en el que un documento de inicio es lo último en un archivo de secuencia de comandos, «EOF» se está utilizando erróneamente.

Hará que sus scripts sean mucho más legibles si usa una cadena de límite que se refiera a lo que está haciendo. Si está enviando una serie de comandos a una computadora remota a través de Secure Shell (SSH), una cadena de límite llamada algo como «_remote_commands» tendría mucho sentido. No es necesario que los inicie con un carácter de subrayado “ _”. Lo hacemos porque los marca como algo fuera de lo común en su guión.

Relacionado:  Cómo habilitar "FPS Boost" para un juego en Xbox Series X o S

Ejemplos sencillos

Puede utilizar aquí documentos en la línea de comandos y en scripts. Cuando escribe lo siguiente en una ventana de terminal, verá un >mensaje de continuación de línea » » cada vez que presione «Enter». Cuando escribe la cadena de límite «_end_of_text» y presiona «Enter», se pasa la lista de sitios web cat,y se muestran en la ventana del terminal.

gato << _end_of_text 
How-To Geek 
Revisión Geek 
LifeSavvy 
CloudSavvy IT
MindBounce
_end_of_text

Ese no es el ejercicio más valioso, pero demuestra que no se envía nada al comando hasta que se recopila toda la lista de datos y se encuentra la cadena de límite. El catcomando no recibe ninguna entrada hasta que ingresa la cadena de límite «_end_of_text» y presiona la tecla «Enter».

Podemos hacer lo mismo en un guión. Escriba o copie este ejemplo en un editor, guarde el archivo como «heredoc-1.sh» y cierre el editor.

#! / bin / bash

gato << "_end_of_text"
Su nombre de usuario es: $ (whoami)
Su directorio de trabajo actual es: $ PWD
Tu versión de Bash es: $ BASH_VERSION
_end_of_text

A medida que sigue este artículo, cada vez que cree un script, deberá hacerlo ejecutable antes de que se ejecute. En cada caso, use el chmodcomando . Sustituya el nombre del script en cada ejemplo por el nombre del script utilizado aquí.

chmod + x heredoc-1.sh

Este script contiene dos variables de entorno $PWDy $BASH_VERSION. Los nombres de las variables de entorno se reemplazan por sus valores de datos (el directorio de trabajo actual y la versión de Bash) cuando se ejecuta el script.

El script también usa la  sustitución de comandos  en el whoamicomando . El nombre del comando se reemplaza por su propia salida. La salida de todo el script se escribe en la ventana de terminal mediante el comando cat. Ejecutamos el script llamándolo por su nombre:

./heredoc-1.sh

Si modifica la secuencia de comandos y envuelve la cadena de límite en la primera línea del documento aquí entre comillas » "«, la lista de datos se pasa al comando aquí documento literalmente. Los nombres de las variables se muestran en lugar de los valores de las variables y no se realizará la sustitución de comandos.

#! / bin / bash

cat << - "_end_of_text"
Su nombre de usuario es: $ (whoami)
Su directorio de trabajo actual es: $ PWD
Tu versión de Bash es: $ BASH_VERSION
_end_of_text

Manejo de caracteres de la pestaña

De forma predeterminada, los caracteres de tabulación en su lista de datos se conservarán y escribirán en la ventana del terminal. Copie y guarde este ejemplo como «heredoc-2.sh». Hágalo ejecutable usando el chmodcomando. Edite las líneas con sangría para asegurarse de que tengan uno o dos caracteres de tabulación al principio de la línea en lugar de una serie de espacios.

#! / bin / bash

gato << _end_of_text
Su nombre de usuario es: $ (whoami)
  Su directorio de trabajo actual es: $ PWD
    Tu versión de Bash es: $ BASH_VERSION
_end_of_text
./heredoc-2.sh

Las pestañas se escriben en la ventana de la terminal.

Relacionado:  Cómo cambiar los botones de navegación o los gestos en Android

Al agregar un guión » -» al operador de redirección, el documento aquí ignorará los caracteres de tabulación iniciales. Guarde este ejemplo como «heredoc-3.sh» y hágalo ejecutable.

#! / bin / bash

gato << - _end_of_text
Su nombre de usuario es: $ (whoami)
  Su directorio de trabajo actual es: $ PWD
    Tu versión de Bash es: $ BASH_VERSION
_end_of_text
./heredoc-3.sh

Las pestañas se ignoran. Esto puede parecer trivial, pero es una buena forma de lidiar con las pestañas iniciales debido a las secciones sangradas de los scripts.

Los bucles y otras construcciones lógicas suelen tener sangría. Si su documento aquí está contenido en una sección con sangría de un script, el uso de un guión “ -” con el operador de redirección elimina los problemas de formato causados ​​por los caracteres de tabulación iniciales.

#! / bin / bash

si es verdad; luego
  cat << - _limit_string
  Línea 1 con tabulación inicial.
  Línea 2 con tabulación inicial.
  Línea 3 con una pestaña inicial.
  _limit_string
fi

Redirigir a un archivo

La salida del comando utilizado con el documento aquí se puede redirigir a un archivo. Utilice los operadores de redirección >” (crear el archivo) o “ >>” (crear el archivo si no existe, anexarlo si existe)  después de  la cadena de límite en la primera línea del documento aquí.

Este script es «heredoc-4.sh». Redirigirá su salida a un archivo de texto llamado «session.txt».

#! / bin / bash

cat << _end_of_text> session.txt
Su nombre de usuario es: $ (whoami)
Su directorio de trabajo actual es: $ PWD
Tu versión de Bash es: $ BASH_VERSION
_end_of_text
./heredoc-4.sh
gato sesión de texto

Canalizar la salida a otro comando

La salida del comando utilizado en un documento aquí se puede canalizar como entrada a otro comando. Utilice el |operador de tubería » »  después de  la cadena de límite en la primera línea del documento aquí. Vamos a canalizar la salida del comando here document  cat, a  sed. Queremos  sustituir todas las apariciones de la letra «a» con la letra «e».

Nombra este script «heredoc-5.sh».

#! / bin / bash

gato << _end_of_text | sed 's / a / e / g'
Cómo
Para
Gaak
_end_of_text
./heredoc-5.sh

«Gaak» se corrige a «Geek».

Envío de parámetros a una función

El comando que se usa con un documento aquí puede ser una función en el script.

Este script pasa algunos datos del vehículo a una función. La función lee los datos como si los hubiera escrito un usuario. A continuación, se imprimen los valores de las variables. Guarde este script como «heredoc-6.sh».

#! / bin / bash

# la función set_car_details ()
set_car_details ()
{
leer hacer
leer modelo
leer new_used
leer delivery_collect
leer ubicación
leer precio
}

# El documento aquí que pasa los datos a set_car_details ()
set_car_details << _mars_rover_data
NASA
Perseverance Rover
Usado
Recolectar
Marte (largo, lat) 77.451865,18.445161
2,2 mil millones
_mars_rover_data

# Recupera los detalles del vehículo
echo "Make: $ make"
echo "Modelo: $ modelo"
echo "Nuevo o Usado: $ new_used"
echo "Entrega o recogida: $ delivery_collect"
echo "Ubicación: $ ubicación"
echo "Precio \ $: $ precio"
./heredoc-6.sh

Los detalles del vehículo se escriben en la ventana de la terminal.

Relacionado:  El solitario de Microsoft sigue siendo el rey 30 años después

Crear y enviar un correo electrónico

Podemos utilizar un documento aquí para redactar y enviar un correo electrónico. Tenga en cuenta que podemos pasar parámetros al comando delante del operador de redirección. Estamos usando el mailcomando de Linux para enviar un correo electrónico a través del sistema de correo local  a la cuenta de usuario llamada «dave». La -sopción (asunto) nos permite especificar el asunto del correo electrónico.

Este ejemplo forma el script «heredoc-7.sh».

#! / bin / bash

artículo = "Aquí Documentos"

mail -s 'Estado de carga de trabajo' dave << _project_report
Nombre de usuario: $ (whoami)
Ha completado la tarea:
Artículo: $ artículo
_informe del proyecto
./heredoc-7.sh

No hay salida visible de este script. Pero cuando revisamos nuestro correo, vemos que el correo electrónico fue redactado, enviado y entregado.

correo

Uso de documentos aquí con SSH

Aquí los documentos son una forma poderosa y conveniente de ejecutar algunos comandos en una computadora remota una vez que se ha establecido una conexión SSH. Si ha configurado claves SSH entre las dos computadoras, el proceso de inicio de sesión será completamente automático. En este ejemplo rápido y sucio, se le pedirá la contraseña para la cuenta de usuario en la computadora remota.

Este script es «heredoc-8.sh». Vamos a conectarnos a una computadora remota llamada «pc-remota». La cuenta de usuario se llama «dave». Estamos usando la -Topción (deshabilitar la asignación de pseudo-terminal) porque no necesitamos que se nos asigne un pseudo-terminal interactivo.

En la sección «hacer algo de trabajo aquí» del script, podríamos pasar una lista de comandos, y estos se ejecutarían en la computadora remota. Por supuesto, podría simplemente llamar a un script que estaba en la computadora remota. El script remoto podría contener todos los comandos y rutinas que desea ejecutar.

Todo lo que nuestro script, heredoc-8.sh, va a hacer es actualizar un registro de conexión en la computadora remota. La cuenta de usuario y el sello de fecha y hora se registran en un archivo de texto.

#! / bin / bash

ssh -T dave@remote-pc.local << _comandos_remoto

# trabaja un poco aquí

# actualizar el registro de conexión
echo $ USER "-" $ (fecha) >> /home/dave/conn_log/script.log
_remote_commands

Cuando ejecutamos el comando, se nos solicita la contraseña de la cuenta en la computadora remota .

./heredoc-8.sh

Se muestra cierta información sobre la computadora remota y regresamos al símbolo del sistema.

En la computadora remota , podemos usar catpara verificar el registro de conexión:

cat conn_log / script.log

Cada conexión está listada para nosotros.

Nombre extraño, características interesantes

Aquí los documentos son extravagantes pero poderosos, especialmente cuando se usan para enviar comandos a una computadora remota. Sería muy sencillo crear un script de una rutina de respaldo usando rsync. Luego, el script podría conectarse a la computadora remota, verificar el espacio de almacenamiento restante y enviar un correo electrónico de alerta si el espacio se estaba agotando.