services: caddy-proxy: image: docker.io/openvidu/openvidu-caddy-local:main platform: linux/amd64 container_name: caddy-proxy restart: unless-stopped extra_hosts: - host.docker.internal:host-gateway environment: - LAN_DOMAIN=${LAN_DOMAIN:-} - LAN_PRIVATE_IP=${LAN_PRIVATE_IP:-} - LAN_MODE=${LAN_MODE:-false} - USE_HTTPS=${USE_HTTPS:-false} - LIVEKIT_API_KEY=${LIVEKIT_API_KEY:-} - LIVEKIT_API_SECRET=${LIVEKIT_API_SECRET:-} - DASHBOARD_ADMIN_USERNAME=${DASHBOARD_ADMIN_USERNAME:-} - DASHBOARD_ADMIN_PASSWORD=${DASHBOARD_ADMIN_PASSWORD:-} - MINIO_ACCESS_KEY=${MINIO_ACCESS_KEY:-} - MINIO_SECRET_KEY=${MINIO_SECRET_KEY:-} - V2COMPAT_OPENVIDU_SECRET=${LIVEKIT_API_SECRET:-} - MEET_INITIAL_ADMIN_USER=${MEET_INITIAL_ADMIN_USER:-} - MEET_INITIAL_ADMIN_PASSWORD=${MEET_INITIAL_ADMIN_PASSWORD:-} - MEET_INITIAL_API_KEY=${MEET_INITIAL_API_KEY:-} volumes: - ./custom-layout:/var/www/custom-layout ports: - 5443:5443 - 6443:6443 - 7443:7443 - 7880:7880 - 9443:9443 depends_on: setup: condition: service_completed_successfully redis: image: docker.io/redis:7.4.4-alpine platform: linux/amd64 container_name: redis restart: unless-stopped ports: - 6379:6379 volumes: - redis:/data command: > redis-server --bind 0.0.0.0 --requirepass ${REDIS_PASSWORD:-} depends_on: setup: condition: service_completed_successfully minio: image: docker.io/openvidu/minio:2025.5.24-debian-12-r1 platform: linux/amd64 restart: unless-stopped ports: - 9000:9000 environment: - MINIO_ROOT_USER=${MINIO_ACCESS_KEY:-} - MINIO_ROOT_PASSWORD=${MINIO_SECRET_KEY:-} - MINIO_DEFAULT_BUCKETS=openvidu-appdata - MINIO_CONSOLE_SUBPATH=/minio-console - MINIO_BROWSER_REDIRECT_URL=http://localhost:7880/minio-console volumes: - minio-data:/bitnami/minio/data - minio-certs:/certs depends_on: setup: condition: service_completed_successfully mongo: image: docker.io/openvidu/mongodb:8.0.9 platform: linux/amd64 container_name: mongo restart: unless-stopped ports: - 27017:27017 volumes: - mongo-data:/bitnami/mongodb environment: - MONGODB_ROOT_USER=${MONGO_ADMIN_USERNAME:-} - MONGODB_ROOT_PASSWORD=${MONGO_ADMIN_PASSWORD:-} - MONGODB_ADVERTISED_HOSTNAME=mongo - MONGODB_REPLICA_SET_MODE=primary - MONGODB_REPLICA_SET_NAME=rs0 - MONGODB_REPLICA_SET_KEY=devreplicasetkey - EXPERIMENTAL_DOCKER_DESKTOP_FORCE_QEMU=${EXPERIMENTAL_DOCKER_DESKTOP_FORCE_QEMU:-0} depends_on: setup: condition: service_completed_successfully dashboard: image: docker.io/openvidu/openvidu-dashboard:main platform: linux/amd64 container_name: dashboard restart: unless-stopped environment: - SERVER_PORT=5000 - ADMIN_USERNAME=${DASHBOARD_ADMIN_USERNAME:-} - ADMIN_PASSWORD=${DASHBOARD_ADMIN_PASSWORD:-} - DATABASE_URL=mongodb://${MONGO_ADMIN_USERNAME}:${MONGO_ADMIN_PASSWORD}@mongo:27017/?replicaSet=rs0&readPreference=primaryPreferred depends_on: setup: condition: service_completed_successfully openvidu: image: docker.io/openvidu/openvidu-server-pro:main platform: linux/amd64 restart: unless-stopped container_name: openvidu extra_hosts: - host.docker.internal:host-gateway environment: - LAN_MODE=${LAN_MODE:-false} - LAN_PRIVATE_IP=${LAN_PRIVATE_IP:-} - OPENVIDU_DEPLOYMENT_TYPE=local - OPENVIDU_ENVIRONMENT=on_premise ports: - 3478:3478/udp - 7881:7881/tcp - 7900-7999:7900-7999/udp entrypoint: /bin/sh /scripts/entrypoint.sh command: --config /etc/livekit.yaml volumes: - ./livekit.yaml:/etc/livekit.yaml - ./scripts/entrypoint_openvidu.sh:/scripts/entrypoint.sh depends_on: setup: condition: service_completed_successfully ingress: image: docker.io/openvidu/ingress:main platform: linux/amd64 container_name: ingress restart: unless-stopped extra_hosts: - host.docker.internal:host-gateway ports: - 1935:1935 - 8085:8085 - 7895:7895/udp environment: - INGRESS_CONFIG_FILE=/etc/ingress.yaml volumes: - ./ingress.yaml:/etc/ingress.yaml depends_on: setup: condition: service_completed_successfully egress: image: docker.io/livekit/egress:v1.10.0 platform: linux/amd64 restart: unless-stopped container_name: egress extra_hosts: - host.docker.internal:host-gateway environment: - EGRESS_CONFIG_FILE=/etc/egress.yaml volumes: - ./egress.yaml:/etc/egress.yaml - egress-data:/home/egress depends_on: setup: condition: service_completed_successfully openvidu-meet: image: docker.io/openvidu/openvidu-meet:main platform: linux/amd64 container_name: openvidu-meet restart: on-failure ports: - 9080:6080 extra_hosts: - host.docker.internal:host-gateway environment: - USE_HTTPS=${USE_HTTPS:-false} - LAN_MODE=${LAN_MODE:-false} - LAN_DOMAIN=${LAN_DOMAIN:-} - LAN_PRIVATE_IP=${LAN_PRIVATE_IP:-} - SERVER_PORT=6080 - MEET_LOG_LEVEL=${MEET_LOG_LEVEL:-info} - MEET_NAME_ID=openviduMeet-LOCAL - MEET_INITIAL_API_KEY=${MEET_INITIAL_API_KEY:-meet-api-key} - MEET_INITIAL_ADMIN_USER=${MEET_INITIAL_ADMIN_USER:-admin} - MEET_INITIAL_ADMIN_PASSWORD=${MEET_INITIAL_ADMIN_PASSWORD:-admin} - MEET_COOKIE_SECURE=false - MEET_INITIAL_WEBHOOK_ENABLED=true - MEET_INITIAL_WEBHOOK_URL=${MEET_INITIAL_WEBHOOK_URL:-http://host.docker.internal:5080/webhook} - LIVEKIT_URL_PRIVATE=ws://openvidu:7880/ - LIVEKIT_API_KEY=${LIVEKIT_API_KEY} - LIVEKIT_API_SECRET=${LIVEKIT_API_SECRET} - MEET_S3_BUCKET=${MEET_S3_BUCKET:-openvidu-appdata} - MEET_S3_SUBBUCKET=${MEET_S3_SUBBUCKET:-openvidu-meet} - MEET_S3_SERVICE_ENDPOINT=${MEET_S3_SERVICE_ENDPOINT:-http://minio:9000} - MEET_S3_ACCESS_KEY=${MINIO_ACCESS_KEY} - MEET_S3_SECRET_KEY=${MINIO_SECRET_KEY} - MEET_AWS_REGION=${MEET_AWS_REGION:-us-east-1} - MEET_S3_WITH_PATH_STYLE_ACCESS=${MEET_S3_WITH_PATH_STYLE_ACCESS:-true} - MEET_REDIS_HOST=redis - MEET_REDIS_PORT=6379 - MEET_REDIS_PASSWORD=${REDIS_PASSWORD:-} - MEET_REDIS_DB=0 volumes: - ./scripts/entrypoint_openvidu_meet.sh:/scripts/entrypoint.sh - ./scripts/utils.sh:/scripts/utils.sh entrypoint: /bin/sh /scripts/entrypoint.sh depends_on: setup: condition: service_completed_successfully openvidu-v2compatibility: image: docker.io/openvidu/openvidu-v2compatibility:main platform: linux/amd64 restart: unless-stopped container_name: openvidu-v2compatibility entrypoint: /bin/sh /scripts/entrypoint.sh extra_hosts: - host.docker.internal:host-gateway ports: - 4443:4443 environment: - USE_HTTPS=${USE_HTTPS:-false} - LAN_DOMAIN=${LAN_DOMAIN:-} - LAN_MODE=${LAN_MODE:-false} - LAN_PRIVATE_IP=${LAN_PRIVATE_IP:-} - V2COMPAT_OPENVIDU_SHIM_PORT=4443 - V2COMPAT_OPENVIDU_SECRET=${LIVEKIT_API_SECRET:-} - V2COMPAT_LIVEKIT_URL_PRIVATE=ws://openvidu:7880 - V2COMPAT_LIVEKIT_API_KEY=${LIVEKIT_API_KEY:-} - V2COMPAT_LIVEKIT_API_SECRET=${LIVEKIT_API_SECRET:-} - V2COMPAT_OPENVIDU_RECORDING_PATH=/opt/openvidu/recordings - V2COMPAT_OPENVIDU_PRO_RECORDING_STORAGE=local - V2COMPAT_OPENVIDU_PRO_AWS_S3_BUCKET=openvidu-appdata - V2COMPAT_OPENVIDU_PRO_AWS_S3_SERVICE_ENDPOINT=http://minio:9000 - V2COMPAT_OPENVIDU_PRO_AWS_REGION=us-east-1 - V2COMPAT_OPENVIDU_PRO_AWS_ACCESS_KEY=${MINIO_ACCESS_KEY:-} - V2COMPAT_OPENVIDU_PRO_AWS_SECRET_KEY=${MINIO_SECRET_KEY:-} - V2COMPAT_REDIS_HOST=redis - V2COMPAT_REDIS_PORT=6379 - V2COMPAT_REDIS_PASSWORD=${REDIS_PASSWORD:-} - V2COMPAT_REDIS_DB=0 - V2COMPAT_OPENVIDU_WEBHOOK=false - V2COMPAT_OPENVIDU_WEBHOOK_ENDPOINT=http://host.docker.internal:7777/webhook - OPENVIDU_DEPLOYMENT_TYPE=local volumes: - ./recordings:/opt/openvidu/recordings - ./scripts/entrypoint_v2comp.sh:/scripts/entrypoint.sh - ./scripts/utils.sh:/scripts/utils.sh depends_on: setup: condition: service_completed_successfully ready-check: image: docker.io/openvidu/openvidu-operator:main platform: linux/amd64 container_name: ready-check restart: on-failure environment: - MODE=local-ready-check - OPENVIDU_ENVIRONMENT=local - USE_HTTPS=${USE_HTTPS:-false} - LAN_DOMAIN=${LAN_DOMAIN:-} - LAN_MODE=${LAN_MODE:-false} - LAN_PRIVATE_IP=${LAN_PRIVATE_IP:-} - DASHBOARD_ADMIN_USERNAME=${DASHBOARD_ADMIN_USERNAME:-} - DASHBOARD_ADMIN_PASSWORD=${DASHBOARD_ADMIN_PASSWORD:-} - MINIO_ACCESS_KEY=${MINIO_ACCESS_KEY:-} - MINIO_SECRET_KEY=${MINIO_SECRET_KEY:-} - LIVEKIT_API_KEY=${LIVEKIT_API_KEY:-} - LIVEKIT_API_SECRET=${LIVEKIT_API_SECRET:-} - V2COMPAT_OPENVIDU_SECRET=${LIVEKIT_API_SECRET:-} - MEET_INITIAL_ADMIN_USER=${MEET_INITIAL_ADMIN_USER:-} - MEET_INITIAL_ADMIN_PASSWORD=${MEET_INITIAL_ADMIN_PASSWORD:-} - MEET_INITIAL_API_KEY=${MEET_INITIAL_API_KEY:-} depends_on: - openvidu - ingress - egress - dashboard - minio - mongo operator: image: docker.io/openvidu/openvidu-operator:main platform: linux/amd64 container_name: operator restart: unless-stopped volumes: - /var/run/docker.sock:/var/run/docker.sock - agents-config:/agents-config - ./:/deployment environment: - PLATFORM=linux/amd64 - MODE=agent-manager-local - DEPLOYMENT_FILES_DIR=/deployment - AGENTS_CONFIG_DIR=/agents-config - NETWORK_NAME=openvidu-pro - AGENTS_CONFIG_VOLUME=openvidu-pro-agents-config - LIVEKIT_URL=ws://openvidu:7880/ - LIVEKIT_API_KEY=${LIVEKIT_API_KEY:-} - LIVEKIT_API_SECRET=${LIVEKIT_API_SECRET:-} - REDIS_ADDRESS=redis:6379 - REDIS_PASSWORD=${REDIS_PASSWORD:-} depends_on: setup: condition: service_completed_successfully setup: image: docker.io/busybox:1.37.0 platform: linux/amd64 container_name: setup restart: "no" volumes: - minio-data:/minio - mongo-data:/mongo - egress-data:/egress - ./scripts/setup.sh:/scripts/setup.sh environment: - USE_HTTPS=${USE_HTTPS:-false} - LAN_MODE=${LAN_MODE:-false} - LAN_PRIVATE_IP=${LAN_PRIVATE_IP:-} - RUN_WITH_SCRIPT=${RUN_WITH_SCRIPT:-false} user: root command: /bin/sh /scripts/setup.sh volumes: agents-config: name: openvidu-pro-agents-config minio-certs: name: openvidu-pro-minio-certs mongodb-config: name: openvidu-pro-mongodb-config redis: name: openvidu-pro-redis minio-data: name: openvidu-pro-minio-data mongo-data: name: openvidu-pro-mongo-data egress-data: name: openvidu-pro-egress-data networks: default: name: openvidu-pro