--- title: "Traefik Docker Documentation" description: "Learn how to use Docker Compose to expose a service with Traefik Proxy." --- # Docker Compose example In this section, you will learn how to use [Docker Compose](https://docs.docker.com/compose/ "Link to Docker Compose") to expose a service using the Docker provider. ## Setup Create a `docker-compose.yml` file with the following content: ```yaml --8<-- "content/user-guides/docker-compose/basic-example/docker-compose.yml" ``` ??? Networking The Traefik container has to be attached to the same network as the containers to be exposed. If no networks are specified in the Docker Compose file, Docker creates a default one that allows Traefik to reach the containers defined in the same file. You can [customize the network](https://docs.docker.com/compose/networking/#specify-custom-networks "Link to docs about custom networks with Docker Compose") as described in the example below. You can use a [pre-existing network](https://docs.docker.com/compose/networking/#use-a-pre-existing-network "Link to Docker Compose networking docs") too. ```yaml version: "3.3" networks: traefiknet: {} services: traefik: image: "traefik:v3.0" ... networks: - traefiknet whoami: image: "traefik/whoami" ... networks: - traefiknet ``` Replace `whoami.localhost` by your **own domain** within the `traefik.http.routers.whoami.rule` label of the `whoami` service. Now run `docker-compose up -d` within the folder where you created the previous file. This will start Docker Compose in background mode. !!! info "This can take a moment" Docker Compose will now create and start the services declared in the `docker-compose.yml`. Wait a bit and visit `http://your_own_domain` to confirm everything went fine. You should see the output of the whoami service. It should be similar to the following example: ```text Hostname: d7f919e54651 IP: 127.0.0.1 IP: 192.168.64.2 GET / HTTP/1.1 Host: whoami.localhost User-Agent: curl/7.52.1 Accept: */* Accept-Encoding: gzip X-Forwarded-For: 192.168.64.1 X-Forwarded-Host: whoami.localhost X-Forwarded-Port: 80 X-Forwarded-Proto: http X-Forwarded-Server: 7f0c797dbc51 X-Real-Ip: 192.168.64.1 ``` ## Details Let's break it down and go through it, step-by-step. You use [whoami](https://github.com/traefik/whoami "Link to the GitHub repo of whoami"), a tiny Go server that prints OS information and HTTP request to output as service container. Second, you define an entry point, along with the exposure of the matching port within Docker Compose, which allows to "open and accept" HTTP traffic: ```yaml command: # Traefik will listen to incoming request on the port 80 (HTTP) - "--entrypoints.web.address=:80" ports: - "80:80" ``` Third, you expose the Traefik API to be able to check the configuration if needed: ```yaml command: # Traefik will listen on port 8080 by default for API request. - "--api.insecure=true" ports: - "8080:8080" ``` !!! Note If you are working on a remote server, you can use the following command to display configuration (require `curl` & `jq`): ```bash curl -s 127.0.0.1:8080/api/rawdata | jq . ``` Fourth, you allow Traefik to gather configuration from Docker: ```yaml traefik: command: # Enabling Docker provider - "--providers.docker=true" # Do not expose containers unless explicitly told so - "--providers.docker.exposedbydefault=false" volumes: - "/var/run/docker.sock:/var/run/docker.sock:ro" whoami: labels: # Explicitly tell Traefik to expose this container - "traefik.enable=true" # The domain the service will respond to - "traefik.http.routers.whoami.rule=Host(`whoami.localhost`)" # Allow request only from the predefined entry point named "web" - "traefik.http.routers.whoami.entrypoints=web" ``` {!traefik-for-business-applications.md!}