bytes.cat

La wiki d'FP d'informàtica

Eines de l'usuari

Eines del lloc


Barra lateral

ASIX Administració de Sistemes Informàtics i Xarxes
Tots els mòduls del cicle
MP01 Implantació de sistemes operatius
Totes les UFs del modul
MP02 Gestió de bases de dades
Totes les UFs del modul
MP03 Programació bàsica
Totes les UFs del modul
MP04 Llenguatges de marques i sistemes de gestió d'informació
Totes les UFs del modul
MP05 Fonaments de maquinari
Totes les UFs del modul
MP06 Administració de sistemes operatius
Totes les UFs del modul
MP07 Planificació i administració de xarxes
Totes les UFs del modul
MP08 Serveis de xarxa i Internet
Totes les UFs del modul
MP09 Implantació d'aplicacions web
Totes les UFs del modul
MP10 Administració de sistemes gestors de bases de dades
Totes les UFs del modul
MP11 Seguretat i alta disponibilitat
Totes les UFs del modul
MP12 Formació i orientació laboral
Totes les UFs del modul
MP13 Empresa i iniciativa emprenedora
Totes les UFs del modul
MP14 Projecte
Totes les UFs del modul
DAM Desenvolupament d’aplicacions multiplataforma
Tots els mòduls del cicle
MP01 Sistemes informàtics
Totes les UFs del modul
MP02 Bases de dades
Totes les UFs del modul
MP03 Programació bàsica
Totes les UFs del modul
MP04 Llenguatges de marques i sistemes de gestió d'informació
Totes les UFs del modul
MP05 Entorns de desenvolupament
Totes les UFs del modul
MP06 Accés a dades
Totes les UFs del modul
MP07 Desenvolupament d’interfícies
Totes les UFs del modul
MP08 Programació multimèdia i dispositius mòbils
Totes les UFs del modul
MP09 Programació de serveis i processos
Totes les UFs del modul
MP10 Sistemes de gestió empresarial
Totes les UFs del modul
MP11 Formació i orientació laboral
Totes les UFs del modul
MP12 Empresa i iniciativa emprenedora
Totes les UFs del modul
MP13 Projecte de síntesi
Totes les UFs del modul
MPDual Mòdul Dual / Projecte
DAW Desenvolupament d’aplicacions web
Tots els mòduls del cicle
MP01 Sistemes informàtics
Totes les UFs del modul
MP02 Bases de dades
Totes les UFs del modul
MP03 Programació
Totes les UFs del modul
MP04 Llenguatge de marques i sistemes de gestió d’informació
Totes les UFs del modul
MP05 Entorns de desenvolupament
Totes les UFs del modul
MP06 Desenvolupament web en entorn client
Totes les UFs del modul
MP07 Desenvolupament web en entorn servidor
Totes les UFs del modul
MP08 Desplegament d'aplicacions web
Totes les UFs del modul
MP09 Disseny d'interfícies web
Totes les UFs del modul
MP10 Formació i Orientació Laboral
Totes les UFs del modul
MP11 Empresa i iniciativa emprenedora
Totes les UFs del modul
MP12 Projecte de síntesi
Totes les UFs del modul
SMX Sistemes Microinformàtics i Xarxes
Tots els mòduls del cicle
MP01 Muntatge i manteniment d’equips
Totes les UFs del modul
MP02 Sistemes Operatius Monolloc
Totes les UFs del modul
MP03 Aplicacions ofimàtiques
Totes les UFs del modul
MP04 Sistemes operatius en xarxa
Totes les UFs del modul
MP05 Xarxes locals
Totes les UFs del modul
MP06 Seguretat informàtica
Totes les UFs del modul
MP07 Serveis de xarxa
Totes les UFs del modul
MP08 Aplicacions Web
Totes les UFs del modul
MP09 Formació i Orientació Laboral
Totes les UFs del modul
MP10 Empresa i iniciativa emprenedora
Totes les UFs del modul
MP11 Anglès
Totes les UFs del modul
MP12 Síntesi
Totes les UFs del modul
CETI Ciberseguretat en Entorns de les Tecnologies de la Informació
Tots els mòduls del cicle
CiberOT Ciberseguretat en Entorns d'Operació
Tots els mòduls del cicle
dockeritzacio_aplicacions_php

Aquesta és una revisió antiga del document


Dockerització d'aplicacions PHP amb connexió a BBDD

Requeriments previs

Per seguir bé aquest article cal tenir coneixements de Docker pràctic i Docker Compose i s'ha de tenir instal·lat al sistema docker i docker-compose

Desplegament d’aplicació en php i mysql

L'objectiu de l'exemple és mostrar pas a pas el desplegament mitjançant docker d'una aplicació PHP amb connexió a BBDD mysql. A mode il·lustratiu es fa servir una pràctica sobre un banc i clients amb comptes que es podria realitzar al mòdul DAW MP07 Desenvolupament web en entorn servidor.

Preparació d'imatges

Per aquest exemple necessitem dues imatges, una per l'aplicació php i l'altre per la BBDD mysql.

Aplicació PHP

Per l'aplicació una opció pot ser agafar com a base una imatge oficial php sobre un servidor apache php on docker Hub i afegir-li els components necessaris mitjançant el DockerFile:

FROM php:7.4-apache
RUN docker-php-ext-install pdo pdo_mysql mysqli
RUN a2enmod rewrite
COPY src/ /var/www/html/
EXPOSE 80

En aquest exemple s'ha optat per la versió 7.4 de php i s'ha afegit a la imatge extensions com PDO o PDO_MYSQL. També s'ha habilitat el mòdul rewrite de l'apache, s'ha copiat el contingut de codi al directori per defecte i s'ha exposat el port 80.

BBDD MySQL

Per la part de la BBDD s'ha optat per una imatge base de mysql sense modificar per simplicitat (Més tard transferirem la BBDD a la imatge).

Configuració del fitxer docker-compose

D'una banda tenim definida l'aplicació amb el nom app on hem optat per construir la imatge amb build i context. L'alternativa seria carregar la imatge pujada a un repositori remot com Docker Hub (opció típica per a producció). En la directiva ports trobem definit extern:intern. En aquest cas, el port intern és el 80 que és el que apache sol fer servir per http i és el que hem exposat al Dockerfile. El port extern, en canvi, està configurat a 82 per evitar conflictes si la nostra màquina està servint alguna cosa pel port 80 (es pot canviar per un port a conveniència). La directiva environment indica les variables d'entorn que necessita la app. En aquest cas: host, user, password i database per a poder comunicar-se amb la BBDD.

docker-compose.yml
  1. version: '3.3'
  2. services:
  3.   app:
  4.   container_name: app_php
  5.   build:
  6.   context: ./
  7.   ports:
  8. - 82:80
  9.   environment:
  10.   MYSQL_HOST: mysql
  11.   MYSQL_USER: root
  12.   MYSQL_PASSWORD: root
  13.   MYSQL_DATABASE: bank
  14.   depends_on:
  15. - mysql
  16.   mysql:
  17.   image: mysql:8.0
  18.   container_name: 'mysql-server-80'
  19.   volumes:
  20. - mysql-data:/var/lib/mysql
  21.   restart: always
  22.   environment:
  23.   MYSQL_ROOT_PASSWORD: root
  24.   MYSQL_DATABASE: bank
  25.   ports:
  26. - "8082:3306"
  27. volumes:
  28. mysql-data:

Pel que fa al servei de BBDD utilitzem la imatge mysql:8.0 del repositori oficial. Definim un volum amb la directiva volumes on enllacem el directori intern de la imatge /var/lib/mysql amb el volum de docker definit més endavant. Definim les variables d'entorn necessàries i definim els ports extern i intern (en aquest cas l'extern es defineix diferent al per defecte per si tenim un servei funcionant en aquest port com en el cas del servei app). Finalment es defineix un volum intern de docker per assegurar la persistència amb volumes mysql-data: (Aquesta directiva ha d'esta al mateix nivell que services i al final del fitxer).

Arrencada dels contenidors

El primer cop hem d'arrencar amb l'argument –build per tal de construir la imatge. Després no caldrà a no ser que fem modificacions a l'aplicació i fos necessari reconstruir la imatge original.

docker-compose up -d --build

Comprovem que els dos contenidors estan arrencats amb docker ps :

docker ps
CONTAINER ID   IMAGE           COMMAND                  CREATED          STATUS         PORTS                                                  NAMES
33cdc1c58ecd   dockerphp_app   "docker-php-entrypoi…"   9 seconds ago    Up 7 seconds   0.0.0.0:82->80/tcp, :::82->80/tcp                      app_php
7e2fbd45531d   mysql:8.0       "docker-entrypoint.s…"   10 seconds ago   Up 8 seconds   33060/tcp, 0.0.0.0:8082->3306/tcp, :::8082->3306/tcp   mysql-server-80

Importar la base de dades

Per importar una base de dades existent hem de copiar un fitxer sql que contingui l'estructura de la BBDD i executar-lo en el contenidor:

docker cp bank.sql mysql-server-80:/bank.sql
docker exec -i mysql-server-80 mysql -u root -proot bank < bank.sql

En el cas d'exemple tenim algunes dades de prova. Podem observar-ho entrant dins del contenidor del servei i consultar la BBDD:

mysql> select * from compte;
+----+--------+-------+--------+
| id | codi   | saldo | client |
+----+--------+-------+--------+
|  1 | BK 100 | 15000 |      1 |
|  2 | BK 101 |   200 |      1 |
|  3 | BK 200 | 18000 |      2 |
+----+--------+-------+--------+
3 rows in set (0.00 sec)
dockeritzacio_aplicacions_php.1657711261.txt.gz · Darrera modificació: 2022/07/13 11:21 per jordi_selga_ruiz