2016-03-15 16:50:14 +01:00
< p align = "center" >
2017-03-31 06:29:03 +02:00
< img src = "img/traefik.logo.png" alt = "Træfik" title = "Træfik" / >
2016-03-15 16:50:14 +01:00
< / p >
2015-09-22 10:33:37 +02:00
2017-08-26 12:12:44 +02:00
[![Build Status SemaphoreCI ](https://semaphoreci.com/api/v1/containous/traefik/branches/master/shields_badge.svg )](https://semaphoreci.com/containous/traefik)
2016-03-22 17:25:57 +01:00
[![Docs ](https://img.shields.io/badge/docs-current-brightgreen.svg )](https://docs.traefik.io)
2017-09-11 19:10:04 +02:00
[![Go Report Card ](https://goreportcard.com/badge/github.com/containous/traefik )](https://goreportcard.com/report/github.com/containous/traefik)
2016-03-22 17:25:57 +01:00
[![License ](https://img.shields.io/badge/license-MIT-blue.svg )](https://github.com/containous/traefik/blob/master/LICENSE.md)
[![Join the chat at https://traefik.herokuapp.com ](https://img.shields.io/badge/style-register-green.svg?style=social&label=Slack )](https://traefik.herokuapp.com)
[![Twitter ](https://img.shields.io/twitter/follow/traefikproxy.svg?style=social )](https://twitter.com/intent/follow?screen_name=traefikproxy)
2015-09-22 10:33:37 +02:00
2017-04-20 00:18:34 +02:00
Træfik (pronounced like [traffic ](https://speak-ipa.bearbin.net/speak.cgi?speak=%CB%88tr%C3%A6f%C9%AAk )) is a modern HTTP reverse proxy and load balancer made to deploy microservices with ease.
2017-09-01 19:44:03 +02:00
It supports several backends ([Docker ](https://www.docker.com/ ), [Swarm mode ](https://docs.docker.com/engine/swarm/ ), [Kubernetes ](https://kubernetes.io ), [Marathon ](https://mesosphere.github.io/marathon/ ), [Consul ](https://www.consul.io/ ), [Etcd ](https://coreos.com/etcd/ ), [Rancher ](https://rancher.com ), [Amazon ECS ](https://aws.amazon.com/ecs ), and a lot more) to manage its configuration automatically and dynamically.
2016-03-15 16:50:14 +01:00
2016-03-22 17:25:57 +01:00
## Overview
2016-03-15 16:50:14 +01:00
2016-03-22 17:25:57 +01:00
Imagine that you have deployed a bunch of microservices on your infrastructure. You probably used a service registry (like etcd or consul) and/or an orchestrator (swarm, Mesos/Marathon) to manage all these services.
If you want your users to access some of your microservices from the Internet, you will have to use a reverse proxy and configure it using virtual hosts or prefix paths:
2016-03-15 16:50:14 +01:00
2016-03-22 17:25:57 +01:00
- domain `api.domain.com` will point the microservice `api` in your private network
- path `domain.com/web` will point the microservice `web` in your private network
- domain `backoffice.domain.com` will point the microservices `backoffice` in your private network, load-balancing between your multiple instances
2016-03-29 22:25:32 +02:00
2016-03-22 17:25:57 +01:00
But a microservices architecture is dynamic... Services are added, removed, killed or upgraded often, eventually several times a day.
2016-03-29 22:25:32 +02:00
2016-03-22 17:25:57 +01:00
Traditional reverse-proxies are not natively dynamic. You can't change their configuration and hot-reload easily.
2016-03-15 16:50:14 +01:00
2017-03-31 06:29:03 +02:00
Here enters Træfik.
2015-09-22 10:33:37 +02:00
2016-03-22 17:25:57 +01:00
![Architecture ](img/architecture.png )
2015-09-22 10:33:37 +02:00
2017-03-31 06:29:03 +02:00
Træfik can listen to your service registry/orchestrator API, and knows each time a microservice is added, removed, killed or upgraded, and can generate its configuration automatically.
2016-03-22 17:25:57 +01:00
Routes to your services will be created instantly.
2015-09-22 10:33:37 +02:00
2016-03-22 17:25:57 +01:00
Run it and forget it!
2016-10-19 17:21:58 +02:00
2017-08-25 20:40:03 +02:00
## Features
2017-09-11 19:10:04 +02:00
- [It's fast ](/benchmarks )
2017-08-25 20:40:03 +02:00
- No dependency hell, single binary made with go
2017-09-11 19:10:04 +02:00
- [Tiny ](https://microbadger.com/images/traefik ) [official ](https://hub.docker.com/r/_/traefik/ ) docker image
2017-08-25 20:40:03 +02:00
- Rest API
- Hot-reloading of configuration. No need to restart the process
- Circuit breakers, retry
- Round Robin, rebalancer load-balancers
2017-11-08 19:44:03 +05:30
- Metrics (Rest, Prometheus, Datadog, Statsd, InfluxDB)
2017-08-25 20:40:03 +02:00
- Clean AngularJS Web UI
- Websocket, HTTP/2, GRPC ready
- Access Logs (JSON, CLF)
- [Let's Encrypt ](https://letsencrypt.org ) support (Automatic HTTPS with renewal)
- High Availability with cluster mode
## Supported backends
- [Docker ](https://www.docker.com/ ) / [Swarm mode ](https://docs.docker.com/engine/swarm/ )
2017-09-01 19:44:03 +02:00
- [Kubernetes ](https://kubernetes.io )
2017-08-25 20:40:03 +02:00
- [Mesos ](https://github.com/apache/mesos ) / [Marathon ](https://mesosphere.github.io/marathon/ )
- [Rancher ](https://rancher.com ) (API, Metadata)
- [Consul ](https://www.consul.io/ ) / [Etcd ](https://coreos.com/etcd/ ) / [Zookeeper ](https://zookeeper.apache.org ) / [BoltDB ](https://github.com/boltdb/bolt )
- [Eureka ](https://github.com/Netflix/eureka )
- [Amazon ECS ](https://aws.amazon.com/ecs )
- [Amazon DynamoDB ](https://aws.amazon.com/dynamodb )
- File
- Rest API
2015-09-22 10:33:37 +02:00
2016-09-20 14:49:43 +02:00
## Quickstart
2017-03-31 06:29:03 +02:00
You can have a quick look at Træfik in this [Katacoda tutorial ](https://www.katacoda.com/courses/traefik/deploy-load-balancer ) that shows how to load balance requests between multiple Docker containers.
2015-09-22 10:33:37 +02:00
2017-08-11 15:19:36 +02:00
Here is a talk given by [Emile Vauge ](https://github.com/emilevauge ) at [GopherCon 2017 ](https://gophercon.com ).
2017-09-07 03:02:03 -07:00
You will learn Træfik basics in less than 10 minutes.
2015-09-22 10:33:37 +02:00
2017-09-01 19:44:03 +02:00
[![Traefik GopherCon 2017 ](https://img.youtube.com/vi/RgudiksfL-k/0.jpg )](https://www.youtube.com/watch?v=RgudiksfL-k)
2016-11-16 11:48:08 +01:00
2017-08-11 15:19:36 +02:00
Here is a talk given by [Ed Robinson ](https://github.com/errm ) at [ContainerCamp UK ](https://container.camp ) conference.
You will learn fundamental Træfik features and see some demos with Kubernetes.
2016-11-16 11:48:08 +01:00
2017-09-01 19:44:03 +02:00
[![Traefik ContainerCamp UK ](https://img.youtube.com/vi/aFtpIShV60I/0.jpg )](https://www.youtube.com/watch?v=aFtpIShV60I)
2015-09-25 11:44:19 +02:00
2016-03-22 17:25:57 +01:00
## Get it
2015-09-22 10:33:37 +02:00
2016-03-22 17:25:57 +01:00
### Binary
2015-09-22 10:33:37 +02:00
2016-03-22 17:25:57 +01:00
You can grab the latest binary from the [releases ](https://github.com/containous/traefik/releases ) page and just run it with the [sample configuration file ](https://raw.githubusercontent.com/containous/traefik/master/traefik.sample.toml ):
2015-09-22 10:33:37 +02:00
2016-03-22 17:25:57 +01:00
```shell
./traefik -c traefik.toml
2015-09-22 10:33:37 +02:00
```
2016-03-22 17:25:57 +01:00
### Docker
2015-09-22 10:33:37 +02:00
2016-03-22 17:25:57 +01:00
Using the tiny Docker image:
2015-09-22 10:33:37 +02:00
2016-03-22 17:25:57 +01:00
```shell
2016-04-07 15:36:48 +02:00
docker run -d -p 8080:8080 -p 80:80 -v $PWD/traefik.toml:/etc/traefik/traefik.toml traefik
2015-09-22 10:33:37 +02:00
```
2016-03-22 17:25:57 +01:00
## Test it
2015-09-22 21:00:29 +02:00
2017-03-31 06:29:03 +02:00
You can test Træfik easily using [Docker compose ](https://docs.docker.com/compose ), with this `docker-compose.yml` file in a folder named `traefik` :
2015-09-22 10:33:37 +02:00
2016-03-22 17:25:57 +01:00
```yaml
2016-10-19 17:21:58 +02:00
version: '2'
services:
proxy:
image: traefik
command: --web --docker --docker.domain=docker.localhost --logLevel=DEBUG
networks:
- webgateway
ports:
- "80:80"
- "8080:8080"
volumes:
- /var/run/docker.sock:/var/run/docker.sock
- /dev/null:/traefik.toml
networks:
webgateway:
driver: bridge
2015-09-22 10:33:37 +02:00
```
2016-10-19 17:21:58 +02:00
Start it from within the `traefik` folder:
2017-09-05 15:58:03 +02:00
```shell
docker-compose up -d
```
2016-10-19 17:21:58 +02:00
2017-09-05 15:58:03 +02:00
In a browser you may open [http://localhost:8080 ](http://localhost:8080 ) to access Træfik's dashboard and observe the following magic.
2016-10-19 17:21:58 +02:00
Now, create a folder named `test` and create a `docker-compose.yml` in it with this content:
```yaml
version: '2'
services:
whoami:
image: emilevauge/whoami
networks:
- web
labels:
- "traefik.backend=whoami"
- "traefik.frontend.rule=Host:whoami.docker.localhost"
networks:
web:
external:
name: traefik_webgateway
```
Then, start and scale it in the `test` folder:
2017-04-30 20:17:57 +02:00
```shell
2016-03-22 17:25:57 +01:00
docker-compose up -d
2016-10-19 17:21:58 +02:00
docker-compose scale whoami=2
2015-09-22 10:33:37 +02:00
```
2016-10-19 17:21:58 +02:00
Finally, test load-balancing between the two services `test_whoami_1` and `test_whoami_2` :
2015-09-22 10:33:37 +02:00
2017-04-30 20:17:57 +02:00
```shell
2017-09-05 15:58:03 +02:00
curl -H Host:whoami.docker.localhost http://127.0.0.1
```
```yaml
2016-03-22 17:25:57 +01:00
Hostname: ef194d07634a
IP: 127.0.0.1
IP: ::1
IP: 172.17.0.4
IP: fe80::42:acff:fe11:4
GET / HTTP/1.1
Host: 172.17.0.4:80
User-Agent: curl/7.35.0
Accept: */*
Accept-Encoding: gzip
X-Forwarded-For: 172.17.0.1
X-Forwarded-Host: 172.17.0.4:80
X-Forwarded-Proto: http
X-Forwarded-Server: dbb60406010d
2017-09-05 15:58:03 +02:00
```
2016-03-22 17:25:57 +01:00
2017-09-05 15:58:03 +02:00
```shell
curl -H Host:whoami.docker.localhost http://127.0.0.1
```
```yaml
2016-03-22 17:25:57 +01:00
Hostname: 6c3c5df0c79a
IP: 127.0.0.1
IP: ::1
IP: 172.17.0.3
IP: fe80::42:acff:fe11:3
GET / HTTP/1.1
Host: 172.17.0.3:80
User-Agent: curl/7.35.0
Accept: */*
Accept-Encoding: gzip
X-Forwarded-For: 172.17.0.1
X-Forwarded-Host: 172.17.0.3:80
X-Forwarded-Proto: http
X-Forwarded-Server: dbb60406010d
2016-03-08 16:27:12 +01:00
```