Ús de SaltStack amb pilars a Ubuntu 17.04

Tot i que SaltStack és una eina fantàstica per executar operacions en molts servidors simultàniament, també admet els valors predefinits de configuració definits per host emmagatzemats en un fitxer únic que s'anomenen "pilar". En aquesta guia, escriurem una petita fórmula de SaltStack per instal·lar Nginx i automatitzar el desplegament d'amfitrions virtuals mitjançant pilars.

Requisits

  • Instància Vultr amb Ubuntu 17.04 (master)
  • Dues instàncies de Vultr amb Ubuntu 17.04 (minions)

Configuració del mestre

Si tot just esteu començant i encara no heu configurat el vostre mestre SaltStack, consulteu aquest article que explica com començar amb SaltStack.

Fórmula

Comencem per crear la carpeta per a la nostra fórmula que conté els fitxers necessaris per a les operacions de SaltStack als nostres minions.

mkdir -p /srv/salt/nginx

Després de crear la carpeta, podem continuar escrivint el init.slsfitxer que és una part essencial 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

Com probablement heu notat, SaltStack utilitza el motor de plantilles Jinja per generar fitxers de configuració dinàmics. Això ofereix una àmplia gamma de possibilitats als nostres fitxers de plantilla de configuració, com ara accedir al codi natiu de Python o configurar variables i similars. El següent pas consisteix a crear la plantilla per al nostre virtualhosts.conffitxer, mentre que primer hem de crear la carpeta:

mkdir -p /srv/salt/nginx/files

Un cop creada la carpeta, podem continuar escrivint el virtualhosts.jinjafitxer:

{% 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

Després de crear la fórmula, podem continuar i configurar la nostra base de pilars:

mkdir -p /srv/pillar/

Qualsevol referència d'amfitrions que coincideixi amb un fitxer pilar concret s'escriu al top.slsfitxer dins del directori que acabem de crear. En el nostre exemple, suposem que existeixen dos minions amb el nom d'amfitrió nginxwww1i, nginxwww2mentre que els assignarem tots dos fitxers de pilar únics:

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

A continuació, continuarem amb la creació d'un fitxer pilar, nginxwww1mentre que crearem un vhost que escolta el port 81 per al domini example.com, sent l'arrel del document /var/www/example_com/i els fitxers d'índex index.shtml:

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

Continuarem amb la creació d'un fitxer pilar, nginxwww2mentre que crearem un vhost que escolti al port 82 per al domini example2.com, sent l'arrel del document /var/www/example2_com/i els fitxers d'índex index.jsi index.css:

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

Nota: els fitxers Pillar s'emmagatzemen dins/srv/pillar/

Desplegant

Ara podem completar el nostre primer intent amb pilars actualitzant-los als nostres minions:

salt '*' saltutil.refresh_pillar

Després, podem executar la fórmula de SaltStack:

salt '*' state.sls nginx

Confirmant

Un cop s'ha executat la fórmula SaltStack i s'ha completat sense cap error, hauríem de poder veure l' nginxescolta al port 81activat nginxwww1i al port 82activat nginxwww2com a confirmació.

Conclusió

Aquesta fórmula de SaltStack bastant lleugera però ja potent es pot ampliar encara més per afegir suport per a HTTPS, possiblement amb una integració de Let's Encrypt, suport per a backends CGI o PHP i tot el que també podeu fer manualment. Aquesta guia hauria d'haver-vos donat una idea bàsica de les fórmules i els pilars de SaltStack utilitzats per al desplegament dels fitxers de configuració. Feliç automatització!

Deixa un comentari

The Rise of Machines: Real World Applications of AI

The Rise of Machines: Real World Applications of AI

La Intel·ligència Artificial no està en el futur, és aquí mateix en el present. En aquest bloc Llegiu com les aplicacions d'Intel·ligència Artificial han afectat diversos sectors.

Atacs DDOS: una breu visió general

Atacs DDOS: una breu visió general

També ets víctima d'atacs DDOS i estàs confós sobre els mètodes de prevenció? Llegiu aquest article per resoldre les vostres consultes.

Us heu preguntat mai com guanyen diners els pirates informàtics?

Us heu preguntat mai com guanyen diners els pirates informàtics?

Potser haureu sentit que els pirates informàtics guanyen molts diners, però us heu preguntat mai com guanyen aquest tipus de diners? anem a discutir.

Invents revolucionaris de Google que us facilitaran la vida.

Invents revolucionaris de Google que us facilitaran la vida.

Vols veure els invents revolucionaris de Google i com aquests invents van canviar la vida de tots els éssers humans actuals? A continuació, llegiu al bloc per veure els invents de Google.

Divendres essencial: què va passar amb els cotxes impulsats per IA?

Divendres essencial: què va passar amb els cotxes impulsats per IA?

El concepte de cotxes autònoms per sortir a les carreteres amb l'ajuda de la intel·ligència artificial és un somni que tenim des de fa temps. Però malgrat les diverses promeses, no es veuen enlloc. Llegeix aquest blog per saber-ne més...

Singularitat tecnològica: un futur llunyà de la civilització humana?

Singularitat tecnològica: un futur llunyà de la civilització humana?

A mesura que la ciència evoluciona a un ritme ràpid, fent-se càrrec de molts dels nostres esforços, també augmenten els riscos de sotmetre'ns a una singularitat inexplicable. Llegeix, què pot significar per a nosaltres la singularitat.

Funcionalitats de les capes darquitectura de referència de Big Data

Funcionalitats de les capes darquitectura de referència de Big Data

Llegeix el blog per conèixer de la manera més senzilla les diferents capes de l'Arquitectura Big Data i les seves funcionalitats.

Evolució de lemmagatzematge de dades – Infografia

Evolució de lemmagatzematge de dades – Infografia

Els mètodes d'emmagatzematge de les dades que han anat evolucionant poden ser des del naixement de les dades. Aquest bloc tracta l'evolució de l'emmagatzematge de dades a partir d'una infografia.

6 avantatges sorprenents de tenir dispositius domèstics intel·ligents a les nostres vides

6 avantatges sorprenents de tenir dispositius domèstics intel·ligents a les nostres vides

En aquest món digital, els dispositius domèstics intel·ligents s'han convertit en una part crucial de les vides. A continuació, es mostren alguns avantatges sorprenents dels dispositius domèstics intel·ligents sobre com fan que la nostra vida valgui la pena i sigui més senzilla.

Lactualització del suplement de macOS Catalina 10.15.4 està causant més problemes que no pas solucions

Lactualització del suplement de macOS Catalina 10.15.4 està causant més problemes que no pas solucions

Recentment, Apple va llançar macOS Catalina 10.15.4, una actualització de suplements per solucionar problemes, però sembla que l'actualització està causant més problemes que provoquen el bloqueig de les màquines Mac. Llegiu aquest article per obtenir més informació