Ací es mostren les diferències entre la revisió seleccionada i la versió actual de la pàgina.
Ambdós costats versió prèvia Revisió prèvia Següent revisió | Revisió prèvia Ultima revisió Ambdós costats nova versio | ||
docker_swarm_stacks [2021/12/04 20:50] enrique_mieza_sanchez [Wordpress escalable] |
docker_swarm_stacks [2023/11/14 18:33] enric_mieza_sanchez [Sticky sessions] spoiler |
||
---|---|---|---|
Línia 7: | Línia 7: | ||
{{ docker-swarm-3.png }} | {{ docker-swarm-3.png }} | ||
- | {{tag> #Ceti #CetiMp03 #Ciber #CiberMp03 docker swarm stack contenidors traefik load_balancer DevOps}} | + | {{tag> |
\\ | \\ | ||
Línia 14: | Línia 14: | ||
Anem a posar en marxa una xarxa amb dos serveis: | Anem a posar en marxa una xarxa amb dos serveis: | ||
- | * whoami: container que mostra la IP i algunes dades internes per a fer proves. | + | |
- | * traefik: conegut load balancer per gestionar el balanceig de càrrega. | + | |
- | Podràs visualitzar 2 frontends | + | |
+ | <WRAP tip> | ||
+ | [[https:// | ||
+ | |||
+ | {{ traefik-architecture.png? | ||
+ | </ | ||
+ | |||
+ | |||
+ | <WRAP info> | ||
+ | Podràs visualitzar 2 webs (l' | ||
* 10.100.199.200: | * 10.100.199.200: | ||
- | * 10.100.199.200 : port 80 on podràs veure el frontend de traefik, però de moment ens mostra un '' | + | * 10.100.199.200 : port 80 on podràs veure el //frontend// de traefik, però de moment ens mostra un '' |
- | * Si volem veure la web, caldrà que configureu l' | + | |
+ | * OJU perquè el ''/ | ||
+ | * Ara sí que podem visualitzar la web de '' | ||
+ | </ | ||
<file yaml whoami.stack.yml> | <file yaml whoami.stack.yml> | ||
Línia 63: | Línia 75: | ||
</ | </ | ||
- | Per posar en marxa el // | + | Per posar en marxa el // |
- | docker stack deploy --compose-file whoami.stack.yml | + | docker stack deploy --compose-file whoami.stack.yml |
- | docker stack deploy -c whoami.stack.yml | + | docker stack deploy -c whoami.stack.yml |
- | docker | + | |
+ | I ara, escalem el servei '' | ||
+ | docker | ||
docker stack ls | docker stack ls | ||
Línia 79: | Línia 93: | ||
* Quan refresques t' | * Quan refresques t' | ||
* Canvia la IP si accedeixes a la web via '' | * Canvia la IP si accedeixes a la web via '' | ||
+ | * **ULL SPOILER ;) amb el '' | ||
* Què creus que significa el paràmetre //sticky// i perquè creus que funciona al //browser// però no amb '' | * Què creus que significa el paràmetre //sticky// i perquè creus que funciona al //browser// però no amb '' | ||
Línia 85: | Línia 100: | ||
\\ | \\ | ||
- | ===== Wordpress | + | ===== Wordpress |
+ | Anem a fer una implementació de Wordpress amb Docker Swarm seguint l' | ||
+ | |||
+ | {{ wordpress_swarm.png? | ||
<WRAP todo> | <WRAP todo> | ||
Elabora un //stack// per allotjar una configuració de Wordpress. | Elabora un //stack// per allotjar una configuració de Wordpress. | ||
- | * Tingues en compte que **la BD cal que estigui fixa al mateix node**, ja que **els volums NO es comparteixen entre màquines**. Busca quina restricció ens ho permet realitzar. | + | |
+ | Tingues en compte que **la BD cal que estigui fixa al mateix node**, ja que **els volums NO es comparteixen entre màquines**. Busca quina restricció ens ho permet realitzar. | ||
+ | |||
+ | Com a //load balancer// pots optar entre fer servir el propi de Docker Swarm (no cal crear cap servei específic, el mateix sistema ho facilita) o bé pots afegir un //load balancer// propi com //traefik// (en aquest cas sí que cal crear un servei, tens un exemple en l' | ||
* Escala a, al menys, 3 instàncies del contenidor wp. | * Escala a, al menys, 3 instàncies del contenidor wp. | ||
* Instal·la el Wordpress i entra al panell d' | * Instal·la el Wordpress i entra al panell d' | ||
Línia 123: | Línia 145: | ||
- mysql_password | - mysql_password | ||
- external: true | - external: true | ||
+ | |||
+ | \\ | ||
+ | |||
+ | ===== Gluster Filesystem ===== | ||
+ | Per tal de facilitar la interoperativitat dels nodes en un Swarm es pot utilitzar un sistema d' | ||
+ | |||
+ | Tens aquí algunes referències per instal·lar-lo: | ||
+ | * https:// | ||
+ | * [[https:// | ||
+ | |||
+ | \\ | ||
+ | |||