Implementación de Microservicios con Docker Compose

Clase 25 de 34Curso de Docker Avanzado

Resumen

¿Qué es Docker Compose y por qué es importante?

Cuando nos adentramos en el mundo de los microservicios y la orquestación de contenedores, Docker Compose surge como una herramienta indispensable. Nos permite manejar múltiples contenedores de forma eficiente y organizada. Con Docker Compose, no solo es posible desplegar un contenedor, sino gestionar y publicar conjuntamente docenas de ellos a través de configuraciones centralizadas en un archivo .yaml. Este enfoque simplifica el manejo de los microservicios y es una excelente introducción para quienes desean familiarizarse con conceptos más complejos en la orquestación de contenedores.

¿Cómo configurar Docker Compose?

Creación de la estructura de carpetas y archivos

El primer paso consiste en crear la estructura de carpetas adecuada para nuestro proyecto. Siguiendo las mejores prácticas demostradas, se puede crear una nueva carpeta, por ejemplo, llamada Compose. Dentro de esta carpeta, podemos copiar previamente la estructura de carpetas utilizada en un ejercicio anterior, como la que se utilizó en la clase de balanceadores de cargas, para agilizar el proceso.

$ mkdir Compose
$ cp -r /path/to/balance-load-exercise/* Compose/

Asegúrate de eliminar cualquier archivo copiado que no sea necesario para el nuevo setup.

Creación del archivo docker-compose.yml

Es crucial crear un archivo docker-compose.yml en la raíz de nuestra carpeta. Este archivo determinará cómo se despliegan y configuran nuestros contenedores. Al igual que un Dockerfile, debe estar correctamente nombrado para que Docker lo identifique.

version: '3'
services:
  proxy:
    build: ./proxy
    ports:
      - "8080:80"
    networks:
      - red_balance

  sitio1:
    build: ./site1
    networks:
      - red_balance

  sitio2:
    build: ./site2
    networks:
      - red_balance

  sitio3:
    build: ./site3
    networks:
      - red_balance

networks:
  red_balance:
    driver: bridge

Descripción de los servicios

En el archivo de configuración, cada bloque bajo services representa un contenedor que deseamos desplegar. Por ejemplo, proxy se origina desde su respectiva carpeta y necesita varios puertos para la comunicación entre el Docker host y el contenedor. Los sitios (sitio1, sitio2, sitio3) tienen definidos sus contextos de compilación.

Gestión de redes

Definir una red dentro del archivo docker-compose.yml nos ofrece una administración centralizada de las conexiones entre contenedores. En este caso, red_balance se define como un puente que conecta todos los servicios.

¿Cómo desplegar y construir con Docker Compose?

La magia de Docker Compose reside en su simplicidad para construir y desplegar contenedores. Con un simple comando, podemos gestionar toda la infraestructura necesaria.

Construcción de imágenes

Usamos el siguiente comando para construir las imágenes de nuestros contenedores antes de desplegarlas. Esto asegura que todo esté listo y optimizado para el despliegue.

$ docker-compose build

Despliegue de servicios

Luego de construir las imágenes, podemos desplegar los servicios con un simple comando. El entorno de ejecución se prepara instantáneamente sin necesidad de configuraciones adicionales.

$ docker-compose up

Con esta acción, todos los contenedores definidos en el archivo se iniciarán, y podrás accesarlos, por ejemplo, navegando a http://localhost:8080.

¿Por qué utilizar Docker Compose?

Docker Compose elimina la necesidad de ejecutar múltiples comandos en la terminal al gestionar contenedores. Toda la configuración queda contenida en un archivo y puede ser desplegada con poco esfuerzo. A través de un archivo .yaml, ofrece control exhaustivo sobre qué se desplegará y cómo se hará, permitiéndonos personalizar cada aspecto del entorno de ejecución.

En conclusión, Docker Compose es una herramienta poderosa para cualquier desarrollador que trabaje con contenedores. Facilita el manejo de ambientes complejos, fomenta la reutilización de configuraciones, y allana el camino hacia una orquestación contingente de microservicios. Despliega, ajusta y prueba en cuestión de segundos, y verás cómo tu flujo de trabajo se simplifica continuamente.