Debrid Media Bridge (DMB) is an All-In-One (AIO) docker image for the unified deployment of Riven Media's, yowmamasita's, iPromKnight's, Nick Craig-Wood's, Michael Stonebraker's, and Dave Page's projects -- Riven, Zurg, Zilean, rclone, PostgreSQL, and pgAdmin 4.
β οΈ IMPORTANT: Docker Desktop CANNOT be used to run DMB. Docker Desktop does not support the mount propagation required for rclone mounts.See the DMB Docs for alternative deployment options to run DMB on Windows through WSL2.
See the DMB Docs for a full list of features and settings.
A prebuilt image is hosted on Docker Hub.
A prebuilt image is hosted on GitHub Container Registry.
Note
The below examples are not exhaustive and are intended to provide a starting point for deployment.
services:
DMB:
container_name: DMB
image: iampuid0/dmb:latest ## Optionally, specify a specific version of DMB w/ image: iampuid0/dmb:2.0.0
stop_grace_period: 30s ## Adjust as need to allow for graceful shutdown of the container
shm_size: 128mb ## Increased for PostgreSQL
stdin_open: true ## docker run -i
tty: true ## docker run -t
volumes:
- /home/username/docker/DMB/config:/config ## Location of configuration files. If a Zurg config.yml and/or Zurg app is placed here, it will be used to override the default configuration and/or app used at startup.
- /home/username/docker/DMB/log:/log ## Location for logs
- /home/username/docker/DMB/Zurg/RD:/zurg/RD ## Location for Zurg RealDebrid active configuration
- /home/username/docker/DMB/Zurg/mnt:/data:shared ## Location for rclone mount to host
- /home/username/docker/DMB/Riven/data:/riven/backend/data ## Location for Riven backend data
- /home/username/docker/DMB/Riven/mnt:/mnt ## Location for Riven symlinks
- /home/username/docker/DMB/PostgreSQL/data:/postgres_data ## Location for PostgreSQL database
- /home/username/docker/DMB/pgAdmin4/data:/pgadmin/data ## Location for pgAdmin 4 data
- /home/username/docker/DMB/Zilean/data:/zilean/app/data ## Location for Zilean data
environment:
- TZ=
- PUID=
- PGID=
- DMB_LOG_LEVEL=INFO
- ZURG_INSTANCES_REALDEBRID_API_KEY=
- RIVEN_FRONTEND_ENV_ORIGIN=http://0.0.0.0:3000 ## See Riven documentation for more details
# network_mode: container:gluetun ## Example to attach to gluetun vpn container if realdebrid blocks IP address
ports:
- "3005:3005" ## DMB Frontend
- "3000:3000" ## Riven Frontend
- "5050:5050" ## pgAdmin 4
devices:
- /dev/fuse:/dev/fuse:rwm
cap_add:
- SYS_ADMIN
security_opt:
- apparmor:unconfined
- no-new-privileges
Note
The Plex server must be started after the rclone mount is available. The below example uses the depends_on
parameter to delay the start of the Plex server until the rclone mount is available. The rclone mount must be shared to the Plex container. The rclone mount location should not be added to the Plex library. The Riven symlink location must be shared to the Plex container and added to the Plex library.
services:
plex:
image: plexinc/pms-docker:latest
container_name: plex
devices:
- /dev/dri:/dev/dri
volumes:
- /home/username/docker/plex/library:/config
- /home/username/docker/plex/transcode:/transcode
- /home/username/docker/DMB/Zurg/mnt:/data ## rclone mount location from DMB must be shared to Plex container. Don't add to plex library
- /home/username/docker/DMB/Riven/mnt:/mnt ## Riven symlink location from DMB must be shared to Plex container. Add to plex library
environment:
- TZ=${TZ}
- PLEX_UID= ## Same as PUID
- PLEX_GID= ## Same as PGID
- PLEX_CLAIM=claimToken ## Need for the first run of Plex - get claimToken here https://www.plex.tv/claim/
ports:
- "32400:32400"
healthcheck:
test: curl --connect-timeout 15 --silent --show-error --fail http://localhost:32400/identity
interval: 1m00s
timeout: 15s
retries: 3
start_period: 1m00s
depends_on: ## Used to delay the startup of plex to ensure the rclone mount is available.
DMB: ## set to the name of the container running rclone
condition: service_healthy
restart: true ## Will automatically restart the plex container if the DMB container restarts
The following table lists the required environment variables used by the container. The environment variables are set via the -e
parameter or via the docker-compose file within the environment:
section or with a .env file saved to the config directory. Value of this parameter is listed as <VARIABLE_NAME>=<Value>
Variables required by DMB:
Variable | Default | Description | Required for DMB |
---|---|---|---|
PUID |
1000 |
Your User ID | βοΈ |
PGID |
1000 |
Your Group ID | βοΈ |
TZ |
(null) |
Your time zone listed as Area/Location |
βοΈ |
ZURG_INSTANCES_REALDEBRID_API_KEY |
(null) |
Enter your Real-Debrid API Token | βοΈ |
RIVEN_FRONTEND_ENV_ORIGIN |
http://0.0.0.0:3000 |
The IP address used to access the DMB frontend. Change this to the IP address of your DMB container. | βοΈ |
See the .env.example
Note
The below examples are default and may be configurable with the use of additional environment variables.
The following table describes the ports used by the container. The mappings are set via the -p
parameter or via the docker-compose file within the ports:
section. Each mapping is specified with the following format: <HOST_PORT>:<CONTAINER_PORT>[:PROTOCOL]
.
Container port | Protocol | Description |
---|---|---|
3005 |
TCP | DMB frontend - a web UI is accessible at the assigned port |
3000 |
TCP | Riven frontend - A web UI is accessible at the assigned port |
8080 |
TCP | Riven backend - The API is accessible at the assigned port |
5432 |
TCP | PostgreSQL - The SQL server is accessible at the assigned port |
5050 |
TCP | pgAdmin 4 - A web UI is accessible at the assigned port |
8182 |
TCP | Zilean - The API and Web Ui (/swagger/index.html) is accessible at the assigned port |
9090 |
TCP | Zurg - A web UI is accessible at the assigned port |
The following table describes the data volumes used by the container. The mappings
are set via the -v
parameter or via the docker-compose file within the volumes:
section. Each mapping is specified with the following
format: <HOST_DIR>:<CONTAINER_DIR>[:PERMISSIONS]
.
Container path | Permissions | Description |
---|---|---|
/config |
rw | This is where the application stores the rclone.conf, and any files needing persistence. CAUTION: rclone.conf is overwritten upon start/restart of the container. Do NOT use an existing rclone.conf file if you have other rclone services |
/log |
rw | This is where the application stores its log files |
/data |
shared | This is where rclone will be mounted. |
/zurg/RD |
rw | This is where Zurg will store the active configuration and data for RealDebrid. Not required when only utilizing Riven |
/riven/data |
rw | This is where Riven will store its data. Not required when only utilizing Zurg |
/riven/mnt |
rw | This is where Riven will set its symlinks. Not required when only utilizing Zurg |
/postgres_data |
rw | This is where PostgreSQL will store its data. Not required when only utilizing Zurg |
/pgadmin/data |
rw | This is where pgAdmin 4 will store its data. Not required when only utilizing Zurg |
See the DMB roadmap for a list of planned features and enhancements.
- The repo contains a devcontainer for use with vscode.
- Bind mounts will need to be populated with content from this repo
DMB allows for the simultaneous or individual deployment of any of the services
For additional details on deployment, see the DMB Docs
- For questions related to DMB, see the GitHub discussions
- or create a new issue if you find a bug or have an idea for an improvement.
- or join the DMB discord server
- For questions related to Riven, see the GitHub discussions
- or create a new issue if you find a bug or have an idea for an improvement.
- or join the Riven discord server
π» Buy Riven Media a beer/coffee? :)
If you enjoy the underlying projects and want to buy Riven Media a beer/coffee, feel free to use the GitHub sponsor link
π» Buy yowmamasita a beer/coffee? :)
If you enjoy the underlying projects and want to buy yowmamasita a beer/coffee, feel free to use the GitHub sponsor link
π» Buy Nick Craig-Wood a beer/coffee? :)
If you enjoy the underlying projects and want to buy Nick Craig-Wood a beer/coffee, feel free to use the website's sponsor links
π» Buy PostgreSQL a beer/coffee? :)
If you enjoy the underlying projects and want to buy PostgreSQL a beer/coffee, feel free to use the sponsor link