Quick Start

使用Docker的简单用例

quickstart-diagram

Launch Traefik With the Docker Provider

创建一个docker-compose.yml文件,您将在其中定义一个使用官方Traefik映像的reverse-proxy服务:

version: '3'

services:
  reverse-proxy:
    # The official v2.0 Traefik docker image
    image: traefik:v2.0
    # Enables the web UI and tells Traefik to listen to docker
    command: --api.insecure=true --providers.docker
    ports:
      # The HTTP port
      - "80:80"
      # The Web UI (enabled by --api.insecure=true)
      - "8080:8080"
    volumes:
      # So that Traefik can listen to the Docker events
      - /var/run/docker.sock:/var/run/docker.sock

而已. 现在您可以启动Traefik!

使用以下命令启动reverse-proxy

docker-compose up -d reverse-proxy

您可以打开浏览器,然后转到http:// localhost:8080 / api / rawdata来查看Traefik的API原始数据(在步骤2中启动服务后,我们将回到那里).

Traefik Detects New Services and Creates the Route for You

现在我们已经启动并运行了Traefik实例,我们将部署新服务.

编辑docker-compose.yml文件,并在文件末尾添加以下内容.

# ...
  whoami:
    # A container that exposes an API to show its IP address
    image: containous/whoami
    labels:
      - "traefik.http.routers.whoami.rule=Host(`whoami.docker.localhost`)"

上面定义了whoami :一个简单的Web服务,它输出有关部署它的机器的信息(它的IP地址,主机等).

使用以下命令启动whoami服务:

docker-compose up -d whoami

返回浏览器( http:// localhost:8080 / api / rawdata ),查看Traefik已自动检测到新容器并更新了自己的配置.

当Traefik检测到新服务时,它会创建相应的路由,以便您将其称为... 让我们拭目以待! (在这里,我们正在使用curl)

curl -H Host:whoami.docker.localhost http://127.0.0.1

显示以下输出:

Hostname: a656c8ddca6c
IP: 172.27.0.3
#...

More Instances? Traefik Load Balances Them

使用以下命令运行您的whoami服务的更多实例:

docker-compose up -d --scale whoami=2

返回浏览器( http:// localhost:8080 / api / rawdata ),查看Traefik已自动检测到容器的新实例.

最后,通过两次运行以下命令来查看Traefik在服务的两个实例之间的负载平衡:

curl -H Host:whoami.docker.localhost http://127.0.0.1

输出将交替显示以下内容之一:

Hostname: a656c8ddca6c
IP: 172.27.0.3
#...
Hostname: s458f154e1f1
IP: 172.27.0.4
# ...

下一步去哪里?

现在,您已经对Traefik如何自动创建服务路由并进行负载平衡有了基本的了解,是时候深入研究文档并让Traefik为您服务!