Grup 3 - Posada en producció classVRroom dockeritzat (Azure)
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