2015-09-15 00:03:53 +02:00
![Træfɪ k ](http://traefik.github.io/traefik.logo.svg "Træfɪ k" )
2015-09-22 10:33:37 +02:00
___
2015-09-13 19:34:05 +02:00
2015-10-28 11:39:24 +01:00
[![Circle CI ](https://circleci.com/gh/emilevauge/traefik.svg?style=shield&circle-token=:circle-token )](https://circleci.com/gh/emilevauge/traefik)
2015-09-15 00:03:53 +02:00
[![License ](https://img.shields.io/badge/license-MIT-blue.svg )](https://github.com/EmileVauge/traefik/blob/master/LICENSE.md)
2015-10-28 11:39:24 +01:00
[![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)
2015-09-22 16:07:49 +02:00
2015-09-14 11:41:50 +02:00
2015-09-14 11:14:37 +02:00
Træfɪ k is a modern HTTP reverse proxy and load balancer made to deploy microservices with ease.
2015-10-03 16:51:14 +02:00
It supports several backends ([Docker :whale: ](https://www.docker.com/ ), [Mesos/Marathon ](https://mesosphere.github.io/marathon/ ), [Consul ](https://consul.io/ ), [Etcd ](https://coreos.com/etcd/ ), [Zookeeper ](https://zookeeper.apache.org ), [BoltDB ](https://github.com/boltdb/bolt ), Rest API, file...) to manage its configuration automatically and dynamically.
2015-09-13 19:34:05 +02:00
2015-09-14 11:01:47 +02:00
2015-10-05 23:22:12 +02:00
## Features
- No dependency hell, single binary made with go
- Simple json Rest API
- Simple TOML file configuration
- Multiple backends supported: Docker, Mesos/Marathon, Consul, Etcd, and more to come
- Watchers for backends, can listen change in backends to apply a new configuration automatically
- Hot-reloading of configuration. No need to restart the process
- Graceful shutdown http connections during hot-reloads
- Circuit breakers on backends
- Round Robin, rebalancer load-balancers
- Rest Metrics
- Tiny docker image included
- SSL backends support
- SSL frontend support
2015-10-13 18:05:50 +02:00
- Clean AngularJS Web UI
- Websocket support
2015-10-05 23:22:12 +02:00
## Demo
2015-09-28 18:25:41 +02:00
Here is a demo of Træfɪ k using Docker backend, showing a load-balancing between two servers, hot reloading of configuration, and graceful shutdown.
[![asciicast ](https://asciinema.org/a/4tcyde7riou5vxulo6my3mtko.png )](https://asciinema.org/a/4tcyde7riou5vxulo6my3mtko)
2015-10-13 18:05:50 +02:00
## Web UI
You can access to a simple HTML frontend of Træfik.
![Web UI Providers ](docs/img/web.frontend.png )
![Web UI Health ](docs/img/traefik-health.png )
2015-10-05 23:22:12 +02:00
## Plumbing
2015-09-13 19:34:05 +02:00
2015-10-05 23:22:12 +02:00
- [Oxy ](https://github.com/mailgun/oxy/ ): an awsome proxy library made by Mailgun guys
- [Gorilla mux ](https://github.com/gorilla/mux ): famous request router
- [Negroni ](https://github.com/codegangsta/negroni ): web middlewares made simple
- [Manners ](https://github.com/mailgun/manners ): graceful shutdown of http.Handler servers
2015-09-13 19:34:05 +02:00
2015-10-05 23:22:12 +02:00
## Quick start
2015-09-13 19:34:05 +02:00
2015-10-05 23:22:12 +02:00
- The simple way: grab the latest binary from the [releases ](https://github.com/emilevauge/traefik/releases ) page and just run it with the [sample configuration file ](https://raw.githubusercontent.com/EmileVauge/traefik/master/traefik.sample.toml ):
2015-09-13 19:34:05 +02:00
2015-10-05 23:22:12 +02:00
```shell
2015-09-14 14:38:21 +02:00
./traefik traefik.toml
2015-09-13 19:34:05 +02:00
```
2015-09-14 14:38:21 +02:00
2015-10-05 23:22:12 +02:00
- Use the tiny Docker image:
2015-09-13 19:34:05 +02:00
2015-10-05 23:22:12 +02:00
```shell
2015-09-15 00:03:53 +02:00
docker run -d -p 8080:8080 -p 80:80 -v $PWD/traefik.toml:/traefik.toml emilevauge/traefik
2015-09-13 19:34:05 +02:00
```
2015-10-05 23:22:12 +02:00
- From sources:
2015-09-22 10:50:33 +02:00
2015-10-05 23:22:12 +02:00
```shell
2015-09-22 10:50:33 +02:00
git clone https://github.com/EmileVauge/traefik
```
2015-10-05 23:22:12 +02:00
## Documentation
2015-09-22 10:33:37 +02:00
You can find the complete documentation [here ](docs/index.md ).
2015-09-22 12:03:15 +02:00
2015-10-05 23:22:12 +02:00
## Benchmarks
2015-09-26 14:42:56 +02:00
Refer to the [benchmarks section ](docs/index.md#benchmarks ) in the documentation.
2015-10-05 23:22:12 +02:00
## Contributing
2015-09-22 12:03:15 +02:00
2015-10-05 23:22:12 +02:00
### Building
2015-09-22 12:03:15 +02:00
2015-10-13 22:57:10 +02:00
You need either [Docker ](https://github.com/docker/docker ) and `make` , or `go` and `glide` in order to build traefik.
2015-09-22 12:03:15 +02:00
2015-10-13 22:57:10 +02:00
#### Setting up your `go` environment
- You need `go` v1.5
- You need to set `export GO15VENDOREXPERIMENT=1` environment variable
2015-11-01 23:00:21 +01:00
- You need `go-bindata` to be able to use `go generate` command (needed to build) : `go get github.com/jteeuwen/go-bindata/...` .
2015-10-13 22:57:10 +02:00
- If you clone Træfɪ k into something like `~/go/src/github.com/traefik` , your `GOPATH` variable will have to be set to `~/go` : export `GOPATH=~/go` .
#### Using `Docker` and `Makefile`
2015-09-22 12:03:15 +02:00
2015-10-05 23:22:12 +02:00
You need to run the `binary` target. This will create binaries for
2015-10-13 22:57:10 +02:00
linux platform in the `dist` folder.
2015-09-22 12:03:15 +02:00
```bash
$ make binary
2015-10-13 22:57:10 +02:00
docker build -t "traefik-dev:no-more-godep-ever" -f build.Dockerfile .
Sending build context to Docker daemon 295.3 MB
Step 0 : FROM golang:1.5
---> 8c6473912976
Step 1 : RUN go get github.com/Masterminds/glide
[...]
docker run --rm -v "/var/run/docker.sock:/var/run/docker.sock" -it -e OS_ARCH_ARG -e OS_PLATFORM_ARG -e TESTFLAGS -v "/home/emile/dev/go/src/github.com/emilevauge/traefik/"dist":/go/src/github.com/emilevauge/traefik/"dist"" "traefik-dev:no-more-godep-ever" ./script/make.sh generate binary
2015-09-22 12:03:15 +02:00
---> Making bundle: generate (in .)
removed 'gen.go'
---> Making bundle: binary (in .)
$ ls dist/
2015-10-13 22:57:10 +02:00
traefik*
2015-09-22 12:03:15 +02:00
```
2015-10-13 22:57:10 +02:00
#### Using `glide`
2015-09-22 12:03:15 +02:00
2015-10-13 22:57:10 +02:00
The idea behind `glide` is the following :
2015-09-22 12:03:15 +02:00
2015-10-13 22:57:10 +02:00
- when checkout(ing) a project, **run `glide up`** to install
2015-09-22 12:03:15 +02:00
(`go get …` ) the dependencies in the `GOPATH` .
2015-10-13 22:57:10 +02:00
- if you need another dependency, import and use it in
the source, and **run `glide get github.com/Masterminds/cookoo`** to save it in
`vendor` and add it to your `glide.yaml` .
2015-09-22 12:03:15 +02:00
```bash
2015-10-13 22:57:10 +02:00
$ glide up --update-vendored
# generate
$ go generate
2015-09-22 12:03:15 +02:00
# Simple go build
2015-10-13 22:57:10 +02:00
$ go build
2015-09-22 12:03:15 +02:00
# Using gox to build multiple platform
2015-10-13 22:57:10 +02:00
$ gox "linux darwin" "386 amd64 arm" \
2015-09-22 12:03:15 +02:00
-output="dist/traefik_{{.OS}}-{{.Arch}}"
# run other commands like tests
2015-10-13 22:57:10 +02:00
$ go test ./...
2015-09-22 12:03:15 +02:00
ok _/home/vincent/src/github/vdemeester/traefik 0.004s
```
2015-10-05 23:22:12 +02:00
### Tests
2015-09-22 12:03:15 +02:00
You can run unit tests using the `test-unit` target and the
integration test using the `test-integration` target.
```bash
$ make test-unit
docker build -t "traefik-dev:your-feature-branch" -f build.Dockerfile .
# […]
docker run --rm -it -e OS_ARCH_ARG -e OS_PLATFORM_ARG -e TESTFLAGS -v "/home/vincent/src/github/vdemeester/traefik/dist:/go/src/github.com/emilevauge/traefik/dist" "traefik-dev:your-feature-branch" ./script/make.sh generate test-unit
---> Making bundle: generate (in .)
removed 'gen.go'
---> Making bundle: test-unit (in .)
+ go test -cover -coverprofile=cover.out .
ok github.com/emilevauge/traefik 0.005s coverage: 4.1% of statements
Test success
```