Cómo utilizar inventarios estáticos y dinámicos en Ansible - Parte 4


En esta parte 4 de la serie Ansible, explicaremos cómo utilizar el inventario estático y dinámico para definir grupos de hosts en Ansible.

En un Ansible, los hosts o servidores administrados que están controlados por el nodo de control de 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 administrados o servidores remotos.

Los hosts administrados pueden 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áticos y dinámicos.

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 control y configurado 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 que utilizan nombres de host o direcciones IP.

El nombre de un grupo de hosts se incluye entre corchetes, es decir, [nombre de 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.

[group name]

Host A ip_address 
Host B ip_address
Host c ip_address

Con fines ilustrativos, crearemos un archivo de inventario estático.

# mkdir test_lab && cd test_lab
# vim hosts
[webservers]
173.82.115.165

[database_servers]
173.82.220.239

[datacenter:children]
webservers
database_servers

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 bases de datos. Además, hemos creado un grupo adicional llamado centro de datos que incluye un grupo de grupos de hosts indicados por el sufijo ': children' como se ve arriba.

Ansible también permite colocar grupos de hosts bajo un nombre de grupo. En el archivo de inventario anterior, los grupos de servidores web y servidores de bases de datos se han colocado en 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. Se muestra la sintaxis básica para la gestión de inventario.

$ ansible {host-pattern} -i /path/of/inventory/file --list-hosts

Por ejemplo,

$ ansible all -i /root/test_labs/hosts --list-hosts

Alternativamente, puede usar el carácter comodín * para reemplazar el argumento "all" .

$ 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 entra en juego un inventario dinámico. 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.

  • Dynamic inventories do a perfect job of reducing human error as information is gathered using scripts.
  • Minimal effort is required in managing inventories.

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 utiliza para crear un inventario dinámico debe hacerse ejecutable para que Ansible pueda utilizarlo.

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.

  • A list of managed hosts per group
  • A dictionary of variables
  • Hosts and hostvars
{
  "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.