Getting Started with Docker
Overview
To follow the guides in this section you will need Docker.
You have the option to enable a zrok account on the Docker host and mount it on the container or you can use the provided Docker Compose project files (compose.yml) to enable a separate zrok environment for each project.
This page provides docker and docker compose examples of mounting the host's zrok environment on the container. You'll need to first enable zrok on the Docker host to use this approach.
Permanent Public Share
Let's say you have a compose.yml file that defines a web app known within the project's bridge network as https://toaster:8080 and you want to publish it as a reliable, public site.
- 
Reserve a subdomain by running zrok reserve public --unique-name "toaster" https:toasterpp:8080on the Docker host.
- 
Merge this YAML with compose.ymlor save it in the same directory ascompose.override.ymlto letdocker compose upmerge it for you.services:
 zrok:
 image: openziti/zrok
 restart: unless-stopped
 user: "${UID}"
 volumes:
 - ${HOME}/.zrok:/home/ziggy/.zrok
 environment:
 PFXLOG_NO_JSON: "true"
 command: share reserved "toaster" --headless
The reserved share will be available at https://toaster.share.zrok.io each time the zrok container starts up.
Temporary Public Share
Let's say you have a web server running on the host's private network at https://10.11.12.13:8080. With one additional docker command, you can share the web server publicly as long as the zrok container stays running.
docker run \
    --rm \
    --network=host \
    --volume ~/.zrok:/home/ziggy/.zrok \
    --user "${UID:-1000}:${GID:-1000}" \
    openziti/zrok share public \
        --headless \
        https://10.11.12.13:8080
PowerShell
docker.exe run `
    --rm `
    --network "host" `
    --volume "${env:USERPROFILE}\.zrok:/.zrok" `
    --user "1000" `
    openziti/zrok share public `
        --headless `
        https://10.11.12.13:8080
Command Prompt (batch)
docker.exe run ^
    --rm ^
    --network "host" ^
    --volume "%USERPROFILE%\.zrok:/.zrok" ^
    --user "1000" ^
    openziti/zrok share public ^
        --headless ^
        https://10.11.12.13:8080
Windows Subsystem for Linux (WSL)
docker run \
    --rm \
    --network "host" \
    --volume "/mnt/c/Users/$(powershell.exe -Command 'Write-Output $env:USERNAME' | tr -d '\r')/.zrok:/home/ziggy/.zrok" \
    --user "${UID:-1000}:${GID:-1000}" \
    openziti/zrok share public \
        --headless \
        https://10.11.12.13:8080
The public share URL appears near the beginning of the container's log.
Let's break down those options and arguments.
- --rmdon't save this container because it's providing a temporary public share that's destroyed when the container stops
- --network=hostshares the host's network with the container so that the container can reach the web server directly. This is always necessary when the web server is listening only on the host's loopback interface, e.g.,- https://::1:8080, and may not be strictly necessary if the target is routeable from the default Docker bridge.
- --volume ~/.zrok:/home/ziggy/.zrokmounts the- zrokconfiguration from the Docker host into the container.
- --user "${UID:-1000}:${GID:-1000}"sets the container's user to the current user on the Docker host to avoid permission issues with reading the mounted- zrokconfiguration (defaults to- 1000:1000).
- openziti/zrokis the- zrokDocker image.
- share publicis the- zrokcommand to share the target publicly until zrok exits.
- --headlessruns the- zrokcommand without the interactive terminal UI.
- https://10.11.12.13:8080is the target web server to share.