Usando SaltStack con pilares en Ubuntu 17.04

Si bien SaltStack es una gran herramienta para ejecutar operaciones en muchos servidores simultáneamente, también admite ajustes preestablecidos de configuración definidos por host almacenados en un archivo único que se denomina "pilar". En esta guía, escribiremos una pequeña fórmula de SaltStack para instalar Nginx y automatizar la implementación de hosts virtuales mediante pilares.

Requisitos

  • Vultr instancia ejecutando Ubuntu 17.04 (maestro)
  • Dos instancias de Vultr que ejecutan Ubuntu 17.04 (minions)

Configurar maestro

Si recién está comenzando y aún no configuró su maestro SaltStack, consulte este artículo que explica cómo comenzar con SaltStack.

Fórmula

Comenzamos con la creación de la carpeta para nuestra fórmula que contiene los archivos necesarios para las operaciones de SaltStack en nuestros secuaces.

mkdir -p /srv/salt/nginx

Después de crear la carpeta, podemos continuar escribiendo el init.slsarchivo, que es una parte esencial de cada fórmula:

nginx:
  pkg:
    - installed

/etc/nginx/sites-enabled/virtualhosts.conf:
    file.managed:
        - source: salt://nginx/files/virtualhosts.jinja
        - template: jinja
        - user: root
        - group: root
        - mode: 655

  cmd:
    - run
    - names:
        - service nginx restart

Como probablemente haya notado, SaltStack utiliza el motor de plantillas Jinja para generar archivos de configuración dinámica. Esto proporciona una amplia gama de posibilidades dentro de nuestros archivos de plantilla de configuración, como acceder al código nativo de Python o establecer variables y similares. El siguiente paso consiste en crear la plantilla para nuestro virtualhosts.confarchivo, mientras que primero debemos crear la carpeta:

mkdir -p /srv/salt/nginx/files

Una vez que se crea la carpeta, podemos continuar escribiendo el virtualhosts.jinjaarchivo:

{% for vhost in pillar['vhosts'] %}
server {
    listen {{ vhost['listenPort'] }};
    server_name {{ vhost['serverName'] }};
    root {{ vhost['documentRoot'] }};
    index {%- for index in vhost['indexFiles'] -%}{{ index }}{%- endfor -%};
    location / {
        try_files $uri $uri/ =404;
    }
}
{% endfor %}

Pilar

Después de crear la fórmula, podemos continuar y configurar nuestra base de Pilar:

mkdir -p /srv/pillar/

Cualquier referencia para hosts que coincidan con un archivo de pilar en particular se escriben en el top.slsarchivo dentro del directorio que acabamos de crear. En nuestro ejemplo, asumimos que existen dos secuaces con el nombre de host nginxwww1y nginxwww2que les asignaremos ambos archivos de pilar únicos:

base:
  'id:nginxwww1':
    - match: grain
    - nginxwww1
  'id:nginxwww2':
    - match: grain
    - nginxwww2

A continuación, continuaremos creando un archivo pilar nginxwww1mientras que crearemos un vhost escuchando en el puerto 81 para el dominio example.com, siendo la raíz del documento /var/www/example_com/y los archivos de índice index.shtml:

vhosts:
    -
      listenPort: '81'
      serverName: 'example.com'
      documentRoot: '/var/www/example_com'
      indexFiles:
        - index.shtml

Continuaremos creando un archivo pilar nginxwww2mientras que crearemos un vhost escuchando en el puerto 82 para el dominio example2.com, siendo la raíz del documento /var/www/example2_com/y los archivos de índice index.jsy index.css:

vhosts:
    -
      listenPort: '82'
      serverName: 'example2.com'
      documentRoot: '/var/www/example2_com'
      indexFiles:
        - index.js
        - index.css

Nota: los archivos de pilares se almacenan en/srv/pillar/

Desplegando

Ahora podemos completar nuestro primer intento con pilares actualizándolos en nuestros secuaces:

salt '*' saltutil.refresh_pillar

Luego, podemos ejecutar la fórmula SaltStack:

salt '*' state.sls nginx

Confirmando

Una vez que la fórmula SaltStack se ha ejecutado y completado sin ningún error, debemos ser capaces de ver nginxla escucha en el puerto 81de nginxwww1y en el puerto 82en nginxwww2modo de confirmación.

Conclusión

Esta fórmula de SaltStack, bastante ligera pero potente, puede ampliarse aún más para agregar soporte para HTTPS, posiblemente con una integración de Let's Encrypt, soporte para backends CGI o PHP y todo lo que puede hacer manualmente también. Esta guía debería haberle dado una idea básica de las fórmulas y pilares de SaltStack utilizados para la implementación de archivos de configuración. ¡Feliz automatización!

Dejar un comentario

ZPanel y Sentora en CentOS 6 x64

ZPanel y Sentora en CentOS 6 x64

ZPanel, un panel de control de alojamiento web popular, se bifurcó en 2014 a un nuevo proyecto llamado Sentora. Aprende a instalar Sentora en tu servidor con este tutorial.

Cómo instalar Vtiger CRM Open Source Edition en CentOS 7

Cómo instalar Vtiger CRM Open Source Edition en CentOS 7

Aprende cómo instalar Vtiger CRM, una aplicación de gestión de relaciones con el cliente, en CentOS 7 para aumentar tus ventas y mejorar el servicio al cliente.

Cómo instalar el servidor Counter-Strike 1.6 en Linux

Cómo instalar el servidor Counter-Strike 1.6 en Linux

Esta guía completa le mostrará cómo configurar un servidor Counter-Strike 1.6 en Linux, optimizando el rendimiento y la seguridad para el mejor juego. Aprende los pasos más recientes aquí.

¿Puede la IA luchar con un número cada vez mayor de ataques de ransomware?

¿Puede la IA luchar con un número cada vez mayor de ataques de ransomware?

Los ataques de ransomware van en aumento, pero ¿puede la IA ayudar a lidiar con el último virus informático? ¿Es la IA la respuesta? Lea aquí, sepa que la IA es una bendición o una perdición

ReactOS: ¿Es este el futuro de Windows?

ReactOS: ¿Es este el futuro de Windows?

ReactOS, un sistema operativo de código abierto y gratuito, está aquí con la última versión. ¿Puede satisfacer las necesidades de los usuarios de Windows de hoy en día y acabar con Microsoft? Averigüemos más sobre este estilo antiguo, pero una experiencia de sistema operativo más nueva.

Manténgase conectado a través de la aplicación de escritorio WhatsApp 24 * 7

Manténgase conectado a través de la aplicación de escritorio WhatsApp 24 * 7

Whatsapp finalmente lanzó la aplicación de escritorio para usuarios de Mac y Windows. Ahora puede acceder a Whatsapp desde Windows o Mac fácilmente. Disponible para Windows 8+ y Mac OS 10.9+

¿Cómo puede la IA llevar la automatización de procesos al siguiente nivel?

¿Cómo puede la IA llevar la automatización de procesos al siguiente nivel?

Lea esto para saber cómo la Inteligencia Artificial se está volviendo popular entre las empresas de pequeña escala y cómo está aumentando las probabilidades de hacerlas crecer y dar ventaja a sus competidores.

La actualización complementaria de macOS Catalina 10.15.4 está causando más problemas que resolver

La actualización complementaria de macOS Catalina 10.15.4 está causando más problemas que resolver

Recientemente, Apple lanzó macOS Catalina 10.15.4, una actualización complementaria para solucionar problemas, pero parece que la actualización está causando más problemas que conducen al bloqueo de las máquinas Mac. Lee este artículo para obtener más información

13 Herramientas comerciales de extracción de datos de Big Data

13 Herramientas comerciales de extracción de datos de Big Data

13 Herramientas comerciales de extracción de datos de Big Data

¿Qué es un sistema de archivos de diario y cómo funciona?

¿Qué es un sistema de archivos de diario y cómo funciona?

Nuestra computadora almacena todos los datos de una manera organizada conocida como sistema de archivos de diario. Es un método eficiente que permite a la computadora buscar y mostrar archivos tan pronto como presiona buscar.