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 el examen del curso
    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 5 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 5 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?

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