Grup 3 - Posada en producció classVRroom dockeritzat (Azure)

De Wiket
Salta a la navegació Salta a la cerca

Tornar a Projecte IETI Cloud - Grup 3.

Tasca

25. Posada en producció de classVRroom dockertizat sobre cloud extern (Azure).

Informe

Reestructuració del projecte

De cara a poder aixecar i mantenir els serveis còmodament un cop integrem el projecte classVRroom, hem de reestructurar el projecte per tenir els diversos serveis separats però connectats al reverse proxy mitjançant una xarxa addicional.

En primer lloc ens encarregarem de compartimentalitzar el nostre reverse proxy ja que la resta de serveis depenen d'aquest. La nova estructura partira d'un directori services on podrem trobar subdirectoris per cada grup de serveis.

services
├── .secrets
│   ├── mysql_root_password
│   └── mysql_wp_password
├── apache
│   ├── Dockerfile
│   ├── docker-compose.yml
│   ├── sites
│   │   ├── classroom.grup3ieti.tk.conf
│   │   ├── default.conf
│   │   ├── default.ssl.conf
│   │   └── wordpress.grup3ieti.tk.conf
│   └── start.sh
├── classVRroom
│   └── NYI
└── higiene-postural
    └── docker-compose.yml

Un cop tenim aquesta estructura determinada, haurem de modificar el nostre docker-compose.yml, on entre d'altres afegirem una xarxa especifica a la que es podran connectar la resta de serveis.

 1 version: "3.3"
 2 
 3 services:
 4    proxy:
 5      build: .
 6      image: local/apache-proxy:v1
 7      restart: unless-stopped
 8      volumes:
 9        - /etc/letsencrypt:/opt/ssl
10        - /etc/timezone:/etc/timezone:ro
11        - /etc/localtime:/etc/localtime:ro
12      ports:
13        - "80:80"
14        - "443:443"
15      networks:
16        - proxy_services
17 
18 networks:
19   proxy_services:
20     external: true

Per tal de fer visibles els nostres serveis per part del proxy, hem d'afegir-los a la xarxa proxy_services. El docker-compose.yml del nostre WordPress quedarà doncs de la següent manera.

 1 version: "3.3"
 2 
 3 services:
 4    db:
 5      image: mysql:5.7
 6      restart: unless-stopped
 7      volumes:
 8        - db:/var/lib/mysql
 9      environment:
10        MYSQL_ROOT_PASSWORD_FILE: /run/secrets/mysql_root_password
11        MYSQL_DATABASE: wordpress
12        MYSQL_USER: wpadmin
13        MYSQL_PASSWORD_FILE: /run/secrets/mysql_wp_password
14      secrets:
15        - mysql_root_password
16        - mysql_wp_password
17 
18    wp:
19      depends_on:
20        - db
21      image: wordpress:5.9.2
22      restart: unless-stopped
23      volumes:
24       - wp:/var/www/html
25      environment:
26        WORDPRESS_DB_HOST: db:3306
27        WORDPRESS_DB_USER: wpadmin
28        WORDPRESS_DB_NAME: wordpress
29        WORDPRESS_DB_PASSWORD_FILE: /run/secrets/mysql_wp_password
30        WORDPRESS_CONFIG_EXTRA: |
31         /* Disable automatic updates */
32         define('AUTOMATIC_UPDATE_DISABLED', true );
33         define('WP_AUTO_UPDATE_CORE', false);
34      secrets:
35        - mysql_wp_password
36      networks:
37        - proxy_services
38 
39 secrets:
40    mysql_wp_password:
41      file: ../.secrets/mysql_wp_password
42    mysql_root_password:
43      file: ../.secrets/mysql_root_password
44 
45 volumes:
46     db:
47     wp:
48 
49 networks:
50   proxy_services:
51     external: true

Com hem declarat la xarxa com externa, tots els docker-compose.yml s'intentaran connectar a una xarxa preexistent anomenada proxy_services, per tal d'enllestir aquesta xarxa hem de crear-la específicament dins del nostre Docker.

docker network create proxy_services

Referències