![Comportamiento de privacidad digital que puede poner en riesgo la privacidad de su familia](/f/f9a0dd287dba797859f5b695ef75d0b9.png?width=100&height=100)
En esto Parte 4 de Serie Ansible, explicaremos cómo utilizar el inventario estático y dinámico para definir grupos de hosts en Ansible.
En un Ansible, hosts gestionados o servidores controlados por el Nodo de control Ansible se definen en un archivo de inventario de host como se explica en. Un archivo de inventario de host es un archivo de texto que consta de nombres de host o Direcciones IP de hosts gestionados o servidores remotos.
Hosts administrados puede enumerarse como entradas individuales o categorizarse bajo un nombre de grupo como veremos más adelante. En Ansible, hay dos tipos de archivos de inventario: Estático y Dinámica.
Echemos un vistazo a cada uno de estos y veamos cómo podemos gestionarlos. A estas alturas, asumimos que ya ha instalado Ansible en su nodo de controly configuró la conexión SSH sin contraseña a sus hosts administrados.
En Ansible, un archivo de inventario estático es un archivo de texto sin formato que contiene una lista de hosts administrados declarados en un grupo de hosts utilizando nombres de host o direcciones IP.
El nombre de un grupo de hosts se incluye entre corchetes, es decir, [Nombre del grupo]
. Las entradas del host administrado se enumeran más adelante debajo del nombre del grupo, cada una en su propia línea. Como se mencionó anteriormente, los hosts se enumeran utilizando nombres de host o direcciones IP.
[Nombre del grupo] Host A ip_address Host B ip_address. Host c dirección_ip.
Con fines ilustrativos, crearemos un archivo de inventario estático.
# mkdir test_lab && cd test_lab. # hosts vim.
Archivo de inventario estático
[servidores web] 173.82.115.165 [database_servers] 173.82.220.239 [centro de datos: niños] servidores web. servidores_de_basedatos.
Guarda el archivo y cierra.
Como puede ver en el archivo de inventario anterior, hemos creado 2 grupos de hosts: servidores web y servidores_de_basedatos. Además, hemos creado un grupo adicional llamado centro de datos que incluye un grupo de grupos de anfitriones denotado por ': niños'
sufijo como se ve arriba.
Ansible también permite colocar grupos de hosts bajo un nombre de grupo. En el archivo de inventario de arriba, el servidores web y servidores_de_basedatos grupos se han colocado bajo el centro de datos.
NOTA: No es obligatorio colocar hosts administrados en un grupo de hosts. Simplemente puede enumerarlos usando sus nombres de host o direcciones IP, por ejemplo.
173.82.202.239. 172.82.115.165. load_balancer.pnl.com.
Usemos ahora algunos comandos de Ansible para hacer referencia al archivo de inventario del host. La sintaxis básica para la gestión de inventario es la que se muestra.
$ ansible {patrón-host} -i / ruta / de / inventario / archivo --list-hosts.
Por ejemplo,
$ ansible all -i / root / test_labs / hosts --list-hosts.
Alternativamente, puede usar el carácter comodín *
para reemplazar 'todos'
argumento.
$ ansible * -i / root / test_labs / hosts --list-hosts.
Para enumerar los hosts en un grupo, especifique el grupo de hosts en el lugar de host-pattern.
$ ansible webservers -i / root / test_labs / hosts --list-hosts.
En una configuración, especialmente una configuración en la nube como AWS donde el archivo de inventario cambia constantemente a medida que agrega o da de baja servidores, controlar los hosts definidos en el archivo de inventario se convierte en un verdadero desafío. Se vuelve inconveniente volver al archivo de host y actualizar la lista de hosts con sus direcciones IP.
Y aquí es donde un inventario dinámico viene a jugar. Entonces, ¿qué es un inventario dinámico? Un inventario dinámico es un script escrito en Python, PHP o cualquier otro lenguaje de programación. Resulta útil en entornos de nube como AWS, donde las direcciones IP cambian una vez que un servidor virtual se detiene y se vuelve a iniciar.
Ansible ya ha desarrollado scripts de inventario para plataformas de nube pública como Google Compute Engine, instancia Amazon EC2, OpenStack, RackSpace, cobbler, entre otras.
Puede escribir su propio inventario dinámico personalizado en un lenguaje de programación de su elección. El inventario debe devolver un formato en JSON cuando se pasen las opciones adecuadas.
Un script que se usa para crear un inventario dinámico debe hacerse ejecutable para que Ansible pueda usarlo.
Para recuperar información sobre los hosts dentro de un script de inventario dinámico, simplemente ejecútelo.
# ./script --list
Como se señaló anteriormente, la salida debe estar en JSON en el formato siguiente.
{"webservers": {"hosts": ["webserver1.example.com", "webserver2.example.com"], "vars": {}}, "database_servers": {"hosts": ["mysql_db1", "mysql_db2"], "vars": {}}, "_meta": {"hostvars": {"mysql_db2": {}, "webserver2.example.com": {}, "webserver1.example.com": { }, "mysql_db1": {} } } }
En este artículo, hemos demostrado cómo crear inventarios tanto estáticos como dinámicos. En resumen, un archivo de inventario estático es un archivo de texto sin formato que contiene una lista de hosts administrados o nodos remotos cuyos números y direcciones IP permanecen bastante constantes.
Por otro lado, un archivo de host dinámico sigue cambiando a medida que agrega nuevos hosts o retira los antiguos. Las direcciones IP de los hosts también son dinámicas a medida que detiene e inicia nuevos sistemas host. Esperamos que este tutorial le haya resultado informativo.