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!



Leave a Comment

Cómo instalar Foreman en Ubuntu 16.04 LTS

Cómo instalar Foreman en Ubuntu 16.04 LTS

¿Usando un sistema diferente? Foreman es una herramienta gratuita y de código abierto que lo ayuda con la configuración y administración de servidores físicos y virtuales. Forema

Creating Snapshots With Packer

Creating Snapshots With Packer

What is Packer? Packer is a server imaging tool developed by HashiCorp. Server imaging; or alternatively, immutable infrastructure; is a popular alternativ

Comenzando con SaltStack en Ubuntu 17.04

Comenzando con SaltStack en Ubuntu 17.04

SaltStack es un programa de administración de configuración basado en Python que está optimizado para la automatización de archivos de configuración, implementaciones y cualquier otra cosa

Cómo instalar SaltStack en CentOS 7

Cómo instalar SaltStack en CentOS 7

SaltStack, o Salt, es una solución de gestión de configuración de código abierto popular que se puede utilizar para implementar ejecución remota, gestión de configuración, bacalao

Vultr Load Balancers

Vultr Load Balancers

What is a Load Balancer Load Balancers sit in front of your application and distribute incoming traffic across multiple instances of your application. Fo

Uso de Chef-solo para configurar una aplicación Django en Ubuntu

Uso de Chef-solo para configurar una aplicación Django en Ubuntu

Hay muchas formas de automatizar el proceso de configuración y configuración de una caja. Por alguna razón, si todo nuestro sistema en este punto comprende solo

How to Install and Configure Ansible on CentOS 7 for Use With Windows Server

How to Install and Configure Ansible on CentOS 7 for Use With Windows Server

Using a Different System? Ansible is an open source tool for automating tasks. It manages the configuration of your Linux and Windows servers. It work

How to Install Strider CD on Ubuntu 18.04

How to Install Strider CD on Ubuntu 18.04

Introduction Strider CD is an open source continuous deployment platform. The application is written in Node.js and uses MongoDB as a storage backend. Stride

Cómo instalar y configurar Concourse CI en CentOS 7

Cómo instalar y configurar Concourse CI en CentOS 7

¿Usando un sistema diferente? Introducción Continuous Integration es una práctica de desarrollo de software DevOps que permite a los desarrolladores fusionar frecuentemente

Cómo instalar y configurar GoCD en CentOS 7

Cómo instalar y configurar GoCD en CentOS 7

¿Usando un sistema diferente? GoCD es un sistema de automatización y entrega continua de código abierto. Le permite modelar flujos de trabajo complejos utilizando su paralelo

How to Install and Configure Concourse CI on Ubuntu 16.04

How to Install and Configure Concourse CI on Ubuntu 16.04

Using a Different System? Introduction Continuous Integration is a DevOps software development practice which enables the developers to frequently merge th

Cómo instalar y configurar Ansible en Debian 9 para usar con Windows Server

Cómo instalar y configurar Ansible en Debian 9 para usar con Windows Server

¿Usando un sistema diferente? Ansible es una herramienta de código abierto para automatizar tareas. Gestiona la configuración de sus servidores Linux y Windows. Funciona

Cómo instalar Jenkins en CentOS 7

Cómo instalar Jenkins en CentOS 7

Jenkins es una herramienta popular de CI de código abierto (integración continua) que se usa ampliamente para el desarrollo, implementación y automatización de proyectos. Este artículo será

Using Chocolatey Package Manager on Windows

Using Chocolatey Package Manager on Windows

Introduction Chocolatey brings package management that makes administering software and dependencies easy on Linux, to Windows. You can quickly and easil

Cómo instalar Foreman en CentOS 7

Cómo instalar Foreman en CentOS 7

¿Usando un sistema diferente? Foreman es una herramienta gratuita y de código abierto que lo ayuda con la configuración y administración de servidores físicos y virtuales. Forema

How to Install Drone CI on Ubuntu 18.04

How to Install Drone CI on Ubuntu 18.04

Introduction Drone is an automated, continuous testing and delivery platform which runs on your own infrastructure. Drone supports any language, service o

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.