CursosEmpresasBlogLiveConfPrecios

Docker-compose como herramienta de desarrollo

Clase 22 de 25 • Fundamentos de Docker 2018

Clase anteriorSiguiente clase

Contenido del curso

Introducción

  • 1
    Qué aprenderás sobre Docker

    Qué aprenderás sobre Docker

    03:11 min
  • 2
    Problemáticas del desarrollo de software profesional

    Problemáticas del desarrollo de software profesional

    06:49 min
  • 3
    Qué es Docker: containarization vs virtualization

    Qué es Docker: containarization vs virtualization

    00:00 min

Primeros pasos

  • 4
    Cómo instalar Docker

    Cómo instalar Docker

    10:13 min
  • 5
    Primeros pasos: Hola mundo y Docker Engine

    Primeros pasos: Hola mundo y Docker Engine

    03:44 min
  • 6
    Contenedores

    Contenedores

    04:54 min

Aprendiendo a usar los contenedores

  • 7
    Explorar el estado de docker

    Explorar el estado de docker

    08:42 min
  • 8
    El modo interactivo

    El modo interactivo

    08:04 min
  • 9
    Ciclo de vida de un contenedor

    Ciclo de vida de un contenedor

    07:34 min
  • 10
    Exponiendo contenedores al mundo exterior

    Exponiendo contenedores al mundo exterior

    08:20 min
  • 11
    Datos en Docker

    Datos en Docker

    10:34 min
  • 12
    Datos con Docker: Volumes

    Datos con Docker: Volumes

    08:51 min

Imágenes

  • 13
    Conceptos fundamentales de Docker: imágenes

    Conceptos fundamentales de Docker: imágenes

    09:54 min
  • 14
    Construyendo nuestras propias imágenes

    Construyendo nuestras propias imágenes

    09:34 min
  • 15
    Comprendiendo el sistema de capas

    Comprendiendo el sistema de capas

    07:54 min

Desarrollando con Docker

  • 16
    Usando docker para desarrollar aplicaciones

    Usando docker para desarrollar aplicaciones

    06:57 min
  • 17
    Reto

    Reto

    00:31 min
  • 18
    Entendiendo el cache de layers para estructurar correctamente tus imágenes

    Entendiendo el cache de layers para estructurar correctamente tus imágenes

    09:16 min
  • 19
    Docker networking: colaboración entre contenedores

    Docker networking: colaboración entre contenedores

    08:21 min

Docker compose

  • 20
    Docker-compose: la herramienta todo-en-uno

    Docker-compose: la herramienta todo-en-uno

    08:38 min
  • 21
    Trabajando con docker-compose

    Trabajando con docker-compose

    06:41 min
  • 22
    Docker-compose como herramienta de desarrollo

    Docker-compose como herramienta de desarrollo

    Viendo ahora

Docker Avanzado

  • 23
    Conceptos para imágenes productivas

    Conceptos para imágenes productivas

    11:17 min
  • 24
    Manejando docker desde un contenedor

    Manejando docker desde un contenedor

    09:41 min

Cierre

  • 25
    Cierre del curso

    Cierre del curso

    01:19 min
Tomar examen

Escuelas

  • Desarrollo Web
    • Fundamentos del Desarrollo Web Profesional
    • Diseño y Desarrollo Frontend
    • Desarrollo Frontend con JavaScript
    • Desarrollo Frontend con Vue.js
    • Desarrollo Frontend con Angular
    • Desarrollo Frontend con React.js
    • Desarrollo Backend con Node.js
    • Desarrollo Backend con Python
    • Desarrollo Backend con Java
    • Desarrollo Backend con PHP
    • Desarrollo Backend con Ruby
    • Bases de Datos para Web
    • Seguridad Web & API
    • Testing Automatizado y QA para Web
    • Arquitecturas Web Modernas y Escalabilidad
    • DevOps y Cloud para Desarrolladores Web
  • English Academy
    • Inglés Básico A1
    • Inglés Básico A2
    • Inglés Intermedio B1
    • Inglés Intermedio Alto B2
    • Inglés Avanzado C1
    • Inglés para Propósitos Específicos
    • Inglés de Negocios
  • Marketing Digital
    • Fundamentos de Marketing Digital
    • Marketing de Contenidos y Redacción Persuasiva
    • SEO y Posicionamiento Web
    • Social Media Marketing y Community Management
    • Publicidad Digital y Paid Media
    • Analítica Digital y Optimización (CRO)
    • Estrategia de Marketing y Growth
    • Marketing de Marca y Comunicación Estratégica
    • Marketing para E-commerce
    • Marketing B2B
    • Inteligencia Artificial Aplicada al Marketing
    • Automatización del Marketing
    • Marca Personal y Marketing Freelance
    • Ventas y Experiencia del Cliente
    • Creación de Contenido para Redes Sociales
  • Inteligencia Artificial y Data Science
    • Fundamentos de Data Science y AI
    • Análisis y Visualización de Datos
    • Machine Learning y Deep Learning
    • Data Engineer
    • Inteligencia Artificial para la Productividad
    • Desarrollo de Aplicaciones con IA
    • AI Software Engineer
  • Ciberseguridad
    • Fundamentos de Ciberseguridad
    • Hacking Ético y Pentesting (Red Team)
    • Análisis de Malware e Ingeniería Forense
    • Seguridad Defensiva y Cumplimiento (Blue Team)
    • Ciberseguridad Estratégica
  • Liderazgo y Habilidades Blandas
    • Fundamentos de Habilidades Profesionales
    • Liderazgo y Gestión de Equipos
    • Comunicación Avanzada y Oratoria
    • Negociación y Resolución de Conflictos
    • Inteligencia Emocional y Autogestión
    • Productividad y Herramientas Digitales
    • Gestión de Proyectos y Metodologías Ágiles
    • Desarrollo de Carrera y Marca Personal
    • Diversidad, Inclusión y Entorno Laboral Saludable
    • Filosofía y Estrategia para Líderes
  • Diseño de Producto y UX
    • Fundamentos de Diseño UX/UI
    • Investigación de Usuarios (UX Research)
    • Arquitectura de Información y Usabilidad
    • Diseño de Interfaces y Prototipado (UI Design)
    • Sistemas de Diseño y DesignOps
    • Redacción UX (UX Writing)
    • Creatividad e Innovación en Diseño
    • Diseño Accesible e Inclusivo
    • Diseño Asistido por Inteligencia Artificial
    • Gestión de Producto y Liderazgo en Diseño
    • Diseño de Interacciones Emergentes (VUI/VR)
    • Desarrollo Web para Diseñadores
    • Diseño y Prototipado No-Code
  • Contenido Audiovisual
    • Fundamentos de Producción Audiovisual
    • Producción de Video para Plataformas Digitales
    • Producción de Audio y Podcast
    • Fotografía y Diseño Gráfico para Contenido Digital
    • Motion Graphics y Animación
    • Contenido Interactivo y Realidad Aumentada
    • Estrategia, Marketing y Monetización de Contenidos
  • Desarrollo Móvil
    • Fundamentos de Desarrollo Móvil
    • Desarrollo Nativo Android con Kotlin
    • Desarrollo Nativo iOS con Swift
    • Desarrollo Multiplataforma con React Native
    • Desarrollo Multiplataforma con Flutter
    • Arquitectura y Patrones de Diseño Móvil
    • Integración de APIs y Persistencia Móvil
    • Testing y Despliegue en Móvil
    • Diseño UX/UI para Móviles
  • Diseño Gráfico y Arte Digital
    • Fundamentos del Diseño Gráfico y Digital
    • Diseño de Identidad Visual y Branding
    • Ilustración Digital y Arte Conceptual
    • Diseño Editorial y de Empaques
    • Motion Graphics y Animación 3D
    • Diseño Gráfico Asistido por Inteligencia Artificial
    • Creatividad e Innovación en Diseño
  • Programación
    • Fundamentos de Programación e Ingeniería de Software
    • Herramientas de IA para el trabajo
    • Matemáticas para Programación
    • Programación con Python
    • Programación con JavaScript
    • Programación con TypeScript
    • Programación Orientada a Objetos con Java
    • Desarrollo con C# y .NET
    • Programación con PHP
    • Programación con Go y Rust
    • Programación Móvil con Swift y Kotlin
    • Programación con C y C++
    • Administración Básica de Servidores Linux
  • Negocios
    • Fundamentos de Negocios y Emprendimiento
    • Estrategia y Crecimiento Empresarial
    • Finanzas Personales y Corporativas
    • Inversión en Mercados Financieros
    • Ventas, CRM y Experiencia del Cliente
    • Operaciones, Logística y E-commerce
    • Gestión de Proyectos y Metodologías Ágiles
    • Aspectos Legales y Cumplimiento
    • Habilidades Directivas y Crecimiento Profesional
    • Diversidad e Inclusión en el Entorno Laboral
    • Herramientas Digitales y Automatización para Negocios
  • Blockchain y Web3
    • Fundamentos de Blockchain y Web3
    • Desarrollo de Smart Contracts y dApps
    • Finanzas Descentralizadas (DeFi)
    • NFTs y Economía de Creadores
    • Seguridad Blockchain
    • Ecosistemas Blockchain Alternativos (No-EVM)
    • Producto, Marketing y Legal en Web3
  • Recursos Humanos
    • Fundamentos y Cultura Organizacional en RRHH
    • Atracción y Selección de Talento
    • Cultura y Employee Experience
    • Gestión y Desarrollo de Talento
    • Desarrollo y Evaluación de Liderazgo
    • Diversidad, Equidad e Inclusión
    • AI y Automatización en Recursos Humanos
    • Tecnología y Automatización en RRHH
  • Finanzas e Inversiones
    • Fundamentos de Finanzas Personales y Corporativas
    • Análisis y Valoración Financiera
    • Inversión y Mercados de Capitales
    • Finanzas Descentralizadas (DeFi) y Criptoactivos
    • Finanzas y Estrategia para Startups
    • Inteligencia Artificial Aplicada a Finanzas
    • Domina Excel
    • Financial Analyst
    • Conseguir trabajo en Finanzas e Inversiones
  • Startups
    • Fundamentos y Validación de Ideas
    • Estrategia de Negocio y Product-Market Fit
    • Desarrollo de Producto y Operaciones Lean
    • Finanzas, Legal y Fundraising
    • Marketing, Ventas y Growth para Startups
    • Cultura, Talento y Liderazgo
    • Finanzas y Operaciones en Ecommerce
    • Startups Web3 y Blockchain
    • Startups con Impacto Social
    • Expansión y Ecosistema Startup
  • Cloud Computing y DevOps
    • Fundamentos de Cloud y DevOps
    • Administración de Servidores Linux
    • Contenerización y Orquestación
    • Infraestructura como Código (IaC) y CI/CD
    • Amazon Web Services
    • Microsoft Azure
    • Serverless y Observabilidad
    • Certificaciones Cloud (Preparación)
    • Plataforma Cloud GCP

Platzi y comunidad

  • Platzi Business
  • Live Classes
  • Lanzamientos
  • Executive Program
  • Trabaja con nosotros
  • Podcast

Recursos

  • Manual de Marca

Soporte

  • Preguntas Frecuentes
  • Contáctanos

Legal

  • Términos y Condiciones
  • Privacidad
  • Tyc promociones
Reconocimientos
Reconocimientos
Logo reconocimientoTop 40 Mejores EdTech del mundo · 2024
Logo reconocimientoPrimera Startup Latina admitida en YC · 2014
Logo reconocimientoPrimera Startup EdTech · 2018
Logo reconocimientoCEO Ganador Medalla por la Educación T4 & HP · 2024
Logo reconocimientoCEO Mejor Emprendedor del año · 2024
De LATAM conpara el mundo
YoutubeInstagramLinkedInTikTokFacebookX (Twitter)Threads
        José Antonio Arias Rodríguez

        José Antonio Arias Rodríguez

        student•
        hace 7 años

        Eso se resuelve usando un contenedor para el balanceo, por ejemplo haproxy

          José Antonio Arias Rodríguez

          José Antonio Arias Rodríguez

          student•
          hace 7 años

          Esta seria la solución al reto

          version: "3" services: app: build: . environment: MONGO_URL: "mongodb://db:27017/test" depends_on: - db db: image: mongo lb: image: dockercloud/haproxy links: - app ports: - '80:80' volumes: - /var/run/docker.sock:/var/run/docker.sock
          Iván Toro

          Iván Toro

          student•
          hace 7 años

          Genial.

        Pedro Roberto Capriles Morales

        Pedro Roberto Capriles Morales

        student•
        hace 7 años

        Para el reto del load balance, se agrega nuevo servicio en este caso se nombre “proxy” y se utiliza la imagen “dockercloud/haproxy” se tomo en cuenta ejemplo de implementación del mismo donde se expone el puerto 80.

        version: "3" services: app: build: . environment: MONGO_URL: "mongodb://db:27017/test" depends_on: - db ports: - "3000-3010:3000" volumes: - ".:/usr/src" - "/usr/src/node_modules" db: image: mongo proxy: image: dockercloud/haproxy ports: - "80:80" depends_on: - app links: - app expose: - "80" volumes: - /var/run/docker.sock:/var/run/docker.sock
        Ariel Jacob

        Ariel Jacob

        student•
        hace 6 años

        que genial es DOCKER y este profe explica de 10!

          Augusto Gonzalez

          Augusto Gonzalez

          student•
          hace 6 años

          +1

        Kevin Costa

        Kevin Costa

        student•
        hace 7 años
        version: "3" services: app: image: platziapp environment: MONGO_URL: "mongodb://db:27017/test" depends_on: - db ports: - "3000-3010:3000" volumes: - .:/Users/kevin/src # esto no me lo toques - /Users/kevin/src/node_modules db: image: mongo lb: image: dockercloud/haproxy links: - app ports: - '4000-4010:80' volumes: - /var/run/docker.sock:/var/run/docker.sock
        Edgar de Jesus Mendoza Ortegon

        Edgar de Jesus Mendoza Ortegon

        student•
        hace 6 años

        imagen del balanceador de carga https://hub.docker.com/r/jwilder/nginx-proxy

        url del ejemplo : http://167.71.102.229/

        Abajo el docker-compose.yml

        version: "3" services: app: build : . environment: MONGO_URL: "mongodb://db:27017/test" VIRTUAL_HOST: 167.71.102.229 depends_on: - db ports: - "3000" volumes: - .:/usr/src - /usr/src/node_modules db: image: mongo nginx: image: jwilder/nginx-proxy ports: - "80:80" volumes: - "/var/run/docker.sock:/tmp/docker.sock:ro"
          Luis Fernando Pedroza Taborda

          Luis Fernando Pedroza Taborda

          student•
          hace 6 años

          Edgar, buen aporte para saber mas sobre la imagen del balanceador de carga

          Gonzalo Amador Hernández

          Gonzalo Amador Hernández

          student•
          hace 5 años

          Eres un Crack!!!!

        Belen ST

        Belen ST

        student•
        hace 6 años

        Para resolver el reto me guié utilizando este tutorial. Quedando el docker-compose.yml de la siguiente manera.

        version: "3" services: app: build: . environment: MONGO_URL: "mongodb://db:27017/test" depends_on: - db expose: - "3000" volumes: - .:/usr/src - /usr/src/node_modules db: image: mongo nginx: image: nginx:latest volumes: - ./nginx.conf:/etc/nginx/nginx.conf:ro depends_on: - app ports: - "4000:4000"

        y además agregué el archivo ** nginx.conf ** en el proyecto

        user nginx; events { worker_connections 1000; } http { server { listen 4000; location / { proxy_pass http://app:3000; } } }

        finalmente agregué unas lineas de logs para validar por que aplicación estaba ingresando el request y ejecuté el comando compose up junto con la flag de scale para crear los 4 nodes

        docker-compose up -d --scale app=4
          Cesar Gonzalez Leyba

          Cesar Gonzalez Leyba

          student•
          hace 6 años

          Gracias por el aporte! Muy interesante articulo

          Gonzalo Amador Hernández

          Gonzalo Amador Hernández

          student•
          hace 5 años

          wow!!!! super increible!!!!

        Rodolfo Carmona

        Rodolfo Carmona

        student•
        hace 6 años

        Docker es un monstruo! un gran docente! hasta ahora el cursos que más he disfrutado :D

        Jonathan Jose Silva Ramos

        Jonathan Jose Silva Ramos

        student•
        hace 7 años

        Un loadbalancer super fácil de configurar

        ingresen a localhost:8080 para ver el dashboard

        version: "3" services: app: build: . environment: MONGO_URL: "mongodb://db:27017/test" depends_on: - db ports: - "3000-3010:3000" volumes: - .:/usr/src/ - /usr/src/node_modules labels: #- "traefik.backend=machine-echo" - "traefik.frontend.rule=Host:app.localhost" db: image: mongo lb: image: traefik command: --web --docker --docker.domain=docker.localhost --logLevel=DEBUG ports: - "80:80" - "8080:8080" - "443:443" volumes: - /var/run/docker.sock:/var/run/docker.sock - /dev/null:/traefik.toml
          Mario Garcia

          Mario Garcia

          student•
          hace 7 años

          Hola josilva. yo tengo docker corriendo en otra maquina con ip 192.168.0.100 y mi maquina esta en el 192.168.0.55 y puedo ver el dashboard en http://192.168.0.100:8080 pero no puedo ver la app en el http://192.168.0.100:80

        Antonio Luis Gil Rodríguez

        Antonio Luis Gil Rodríguez

        student•
        hace 6 años

        Con el archivo .dockerignore se puede conseguir lo mismo que se hizo para ignorar la carpeta node_modules?

        Luis Fernando Bustos Ramírez

        Luis Fernando Bustos Ramírez

        student•
        hace 6 años

        Como dicen los demás compañeros debemos de usar nginx, pueden consultar la información de un ejemplo aqui

        pero en resumen se tiene que crear un archivo llamado nginx.conf con los siguientes datos

        user nginx; events { worker_connections 1000; } http { server { listen 4000; location / { proxy_pass http://app:3000; } } }

        y modificamos nuestro docker-compose.yml de la siguiente manera

        version: "3" services: db: image: mongo app: build: . #image: platziapp environment: MONGO_URL: "mongodb://db:27017/test" depends_on: - db #ports: # - "3000-3010:3000" expose: - "3000" volumes: - .:/usr/src - /usr/src/node_modules nginx: image: nginx:latest volumes: - ./nginx.conf:/etc/nginx/nginx.conf:ro depends_on: - app ports: - "4000:4000"
        Paul Cortes

        Paul Cortes

        student•
        hace 6 años

        Escalar contenedores

        para escalar los contenedores para que hayan mas para atender las solicitudes se puede usar el comando:

        docker-compose scale [nombre_contenedor]=[cantidad_contenedores] docker-compose scale app=4

        al momento de ejecutar esto si no esta preparado el archivo de docker-compose.yaml nos dara error porque ya se estan usando los puertos de la maquina local, porque intenta asignar el mismo que ya esta en uso:

        imagen_puertos_ocupados_al_escalar.png

        version: "3" services: app: build: . environment: MONGO_URL: "mongodb://db:27017/test" depends_on: - db ports: - "3000-3010:3000" volumes: - .:/usr/src - /usr/src/node_modules db: image: mongo

        agregando un rango de puertos a usar de la maquina local en:

        ports: - "3000-3010:3000"
        Diego Joel Requejo Torero

        Diego Joel Requejo Torero

        student•
        hace 6 años

        Utilicé un hapropxy como load-balancer, el docker compose quedó así:

        version: "3" services: lb: image: dockercloud/haproxy links: - app ports: - 80:80 app: #image: platziapp build: . environment: MONGO_URL: "mongodb://db:27017/test" depends_on: - db ports: - 3000-3010:3000 volumes: - .:/usr/src - /usr/src/node_modules db: image: mongo

        Referencia: acá

        William Schnaider Torres Bermon

        William Schnaider Torres Bermon

        student•
        hace 6 años

        El comando docker-compose scale se encuentra deprecado según la documentación. Se recomienda usar:

        docker-compose up --scale [name_service]=[num]
        Wilson Fernando Antury Torres

        Wilson Fernando Antury Torres

        student•
        hace 6 años

        Veamos si entiendo, yo podría crear una imagen para mi contenedor con todo mi ambiente de trabajo para desarrollar aplicaciones web, por ejemplo, nodejs, webpack, terminal, express, react, nodemon, python, y todo lo que necesite, sin necesidad de tenerlo en una computadora localmente. Lo que quiero saber es que si llego a una computadora sin un ambiente de trabajo configurado, solo con instalar docker e iniciar mi contenedor con la imagen de mi repositorio, podría desarrollar sin problemas? está bien éste enfoque con respecto al de tener todo localmente? Gracias.

          Anthony Farias

          Anthony Farias

          student•
          hace 6 años

          Eso es correcto. Con docker creas tus propias imagenes y las corres en cualquier lugar que tenga docker.

          Wilson Fernando Antury Torres

          Wilson Fernando Antury Torres

          student•
          hace 6 años

          Hola anthony-farias, gracias por la respuesta. Entonces debería iniciar cada proyecto en un contenedor, verdad? Esto se hace comunmente en la industria?

        Luis Fernando Bustos Ramírez

        Luis Fernando Bustos Ramírez

        student•
        hace 6 años

        😭 Es tan hermoso

        Jesus Manuel Herrera Miramontes

        Jesus Manuel Herrera Miramontes

        company_admin•
        hace 6 años

        docker-compose scale app=4

        Manuel Andres Santizo Avila

        Manuel Andres Santizo Avila

        student•
        hace 7 años

        Podríamos utilizar un Service Discovery como Consul donde los contenedores se registren para que puedan ser encontrados no?

          Guido Vilariño

          Guido Vilariño

          teacher•
          hace 7 años

          Se puede usar Consul, claro; todo depende de tu setup. Para correr dentro de la misma máquina, docker-compose y docker networking suele ser lo más simple. Para esquemas de múltiples computadoras, lo más sencillo es usar Docker Swarm.

          Si quieres usar tu propio key/value store y planificador de contenedores, suele usarse mucho la combinación Consul + Nomad, ambos de HashiCorp

        Cristian Camilo Perez Cardona

        Cristian Camilo Perez Cardona

        student•
        hace 6 años

        Mi nginx.config

        upstream node-app { server app_1:3000; server app_2:3000; server app_3:3000; server app_4:3000; } server { listen 80; location / { proxy_pass http://node-app; } }

        Solo utilizando los alias de las diferentes apps, todas en el puerto 3000. DONE

        Víctor A. Echeverría

        Víctor A. Echeverría

        student•
        hace 6 años

        Buenas noches @gvilariño, al parecer lo logré con nginx configurado como balanceador, aunque tengo una duda: Para que el contenedor de balanceo no se conecte al host por medio de la red, se debería configurar en el nginx.conf las ips asignadas por docker a cada contenedor escalado en vez de localhost ??

        docker'compose.yml

        version: "3.8" services: connect_mongo: build: . environment: MONGO_URL: "mongodb://dbmongo:27017/test" depends_on: - dbmongo ports: - "3000-3010:3000" volumes: - .:/usr/src/ - /usr/src/node_modules networks: - app_net balancer: image: nginx:latest depends_on: - connect_mongo ports: - "8005:8005" volumes: - /home/vecheverria/Development/Docker/Nginx/:/etc/nginx/:ro network_mode: "host" dbmongo: image: mongo networks: - app_net networks: app_net: ipam: driver: default config: - subnet: "172.16.238.0/24"

        nginx.conf

        user nginx; worker_processes 1; error_log /var/log/nginx/error.log warn; pid /var/run/nginx.pid; events { worker_connections 1024; } http { upstream connect_mongo { server localhost:3000; server localhost:3001; server localhost:3002; server localhost:3003; } server { listen 8005; location / { proxy_pass http://connect_mongo; } } }
        Coneccion.jpg
        Jorge Humberto Nemogá Pinzón

        Jorge Humberto Nemogá Pinzón

        student•
        hace 6 años

        Con el archivo .dockerignore se puede conseguir lo mismo que se hizo para ignorar la carpeta node_modules?