Server weight zero

This commit is contained in:
Ludovic Fernandez 2018-04-11 16:30:04 +02:00 committed by Traefiker Bot
parent edbcd01fbc
commit 8168d2fdc1
84 changed files with 378 additions and 273 deletions

7
Gopkg.lock generated
View file

@ -263,8 +263,8 @@
[[projects]] [[projects]]
name = "github.com/containous/traefik-extra-service-fabric" name = "github.com/containous/traefik-extra-service-fabric"
packages = ["."] packages = ["."]
revision = "29a6d70ad0f15175efbaa5fd93d8afdd8b373b93" revision = "503022efdc178146d598911092af75690510a80c"
version = "v1.1.1" version = "v1.1.3"
[[projects]] [[projects]]
name = "github.com/coreos/bbolt" name = "github.com/coreos/bbolt"
@ -761,6 +761,7 @@
version = "v1.3.7" version = "v1.3.7"
[[projects]] [[projects]]
branch = "master"
name = "github.com/jjcollinge/servicefabric" name = "github.com/jjcollinge/servicefabric"
packages = ["."] packages = ["."]
revision = "8eebe170fa1ba25d3dfb928b3f86a7313b13b9fe" revision = "8eebe170fa1ba25d3dfb928b3f86a7313b13b9fe"
@ -1674,6 +1675,6 @@
[solve-meta] [solve-meta]
analyzer-name = "dep" analyzer-name = "dep"
analyzer-version = 1 analyzer-version = 1
inputs-digest = "37f92cc9416b1449e9fe4fd1b02d999af8d9887617424db7cb334060cd362e5c" inputs-digest = "c441208e9bf330e85e2939b383515f58a4957286960b43c444e6f512d1ff94ee"
solver-name = "gps-cdcl" solver-name = "gps-cdcl"
solver-version = 1 solver-version = 1

View file

@ -66,7 +66,7 @@
[[constraint]] [[constraint]]
name = "github.com/containous/traefik-extra-service-fabric" name = "github.com/containous/traefik-extra-service-fabric"
version = "1.1.1" version = "1.1.3"
[[constraint]] [[constraint]]
name = "github.com/coreos/go-systemd" name = "github.com/coreos/go-systemd"

View file

@ -35,6 +35,7 @@ import (
"github.com/coreos/go-systemd/daemon" "github.com/coreos/go-systemd/daemon"
"github.com/ogier/pflag" "github.com/ogier/pflag"
"github.com/sirupsen/logrus" "github.com/sirupsen/logrus"
"github.com/vulcand/oxy/roundrobin"
) )
func main() { func main() {
@ -155,6 +156,10 @@ func runCmd(globalConfiguration *configuration.GlobalConfiguration, configFile s
http.DefaultTransport.(*http.Transport).Proxy = http.ProxyFromEnvironment http.DefaultTransport.(*http.Transport).Proxy = http.ProxyFromEnvironment
if globalConfiguration.AllowMinWeightZero {
roundrobin.SetDefaultWeight(0)
}
globalConfiguration.SetEffectiveConfiguration(configFile) globalConfiguration.SetEffectiveConfiguration(configFile)
globalConfiguration.ValidateConfiguration() globalConfiguration.ValidateConfiguration()

View file

@ -78,6 +78,7 @@ type GlobalConfiguration struct {
HealthCheck *HealthCheckConfig `description:"Health check parameters" export:"true"` HealthCheck *HealthCheckConfig `description:"Health check parameters" export:"true"`
RespondingTimeouts *RespondingTimeouts `description:"Timeouts for incoming requests to the Traefik instance" export:"true"` RespondingTimeouts *RespondingTimeouts `description:"Timeouts for incoming requests to the Traefik instance" export:"true"`
ForwardingTimeouts *ForwardingTimeouts `description:"Timeouts for requests forwarded to the backend servers" export:"true"` ForwardingTimeouts *ForwardingTimeouts `description:"Timeouts for requests forwarded to the backend servers" export:"true"`
AllowMinWeightZero bool `description:"Allow weight to take 0 as minimum real value." export:"true"` // Deprecated
Web *WebCompatibility `description:"(Deprecated) Enable Web backend with default settings" export:"true"` // Deprecated Web *WebCompatibility `description:"(Deprecated) Enable Web backend with default settings" export:"true"` // Deprecated
Docker *docker.Provider `description:"Enable Docker backend with default settings" export:"true"` Docker *docker.Provider `description:"Enable Docker backend with default settings" export:"true"`
File *file.Provider `description:"Enable File backend with default settings" export:"true"` File *file.Provider `description:"Enable File backend with default settings" export:"true"`

View file

@ -69,6 +69,15 @@
# Default: ["http"] # Default: ["http"]
# #
# defaultEntryPoints = ["http", "https"] # defaultEntryPoints = ["http", "https"]
# Allow the use of 0 as server weight.
# - false: a weight 0 means internally a weight of 1.
# - true: a weight 0 means internally a weight of 0 (a server with a weight of 0 is removed from the available servers).
#
# Optional
# Default: false
#
# AllowMinWeightZero = true
``` ```
- `graceTimeOut`: Duration to give active requests a chance to finish before Traefik stops. - `graceTimeOut`: Duration to give active requests a chance to finish before Traefik stops.

View file

@ -29,10 +29,13 @@ entryPoint = "api"
method = "drr" method = "drr"
[backends.backend.servers.server1] [backends.backend.servers.server1]
url = "http://127.0.0.1:8081" url = "http://127.0.0.1:8081"
weight = 1
[backends.backend.servers.server2] [backends.backend.servers.server2]
url = "http://127.0.0.1:8082" url = "http://127.0.0.1:8082"
weight = 1
[backends.backend.servers.server3] [backends.backend.servers.server3]
url = "http://127.0.0.1:8083" url = "http://127.0.0.1:8083"
weight = 1
[frontends] [frontends]
[frontends.frontend] [frontends.frontend]
backend = "backend" backend = "backend"

View file

@ -27,18 +27,24 @@ entryPoint = "api"
[backends.backend1] [backends.backend1]
[backends.backend1.servers.server1] [backends.backend1.servers.server1]
url = "http://127.0.0.1:8081" url = "http://127.0.0.1:8081"
weight = 1
[backends.backend2] [backends.backend2]
[backends.backend2.LoadBalancer] [backends.backend2.LoadBalancer]
method = "drr" method = "drr"
[backends.backend2.servers.server1] [backends.backend2.servers.server1]
url = "http://127.0.0.1:8082" url = "http://127.0.0.1:8082"
weight = 1
[backends.backend2.servers.server2] [backends.backend2.servers.server2]
url = "http://127.0.0.1:8083" url = "http://127.0.0.1:8083"
weight = 1
[frontends] [frontends]
[frontends.frontend1] [frontends.frontend1]
backend = "backend1" backend = "backend1"
[frontends.frontend1.routes.test_1] [frontends.frontend1.routes.test_1]
rule = "Path: /test1" rule = "Path: /test1"
[frontends.frontend2] [frontends.frontend2]
backend = "backend2" backend = "backend2"
passHostHeader = true passHostHeader = true

View file

@ -26,6 +26,7 @@ caServer = "http://{{.BoulderHost}}:4001/directory"
[backends.backend] [backends.backend]
[backends.backend.servers.server1] [backends.backend.servers.server1]
url = "http://127.0.0.1:9010" url = "http://127.0.0.1:9010"
weight = 1
[frontends] [frontends]

View file

@ -28,6 +28,7 @@ path="/traefik"
[backends.backend] [backends.backend]
[backends.backend.servers.server1] [backends.backend.servers.server1]
url = "http://127.0.0.1:9010" url = "http://127.0.0.1:9010"
weight = 1
[frontends] [frontends]
[frontends.frontend] [frontends.frontend]

View file

@ -28,6 +28,7 @@ entryPoint="http"
[backends.backend] [backends.backend]
[backends.backend.servers.server1] [backends.backend.servers.server1]
url = "http://127.0.0.1:9010" url = "http://127.0.0.1:9010"
weight = 1
[frontends] [frontends]

View file

@ -2,6 +2,7 @@
[backends.backend] [backends.backend]
[backends.backend.servers.server1] [backends.backend.servers.server1]
url = "http://127.0.0.1:9010" url = "http://127.0.0.1:9010"
weight = 1
[frontends] [frontends]
[frontends.frontend] [frontends.frontend]

View file

@ -26,6 +26,7 @@ caServer = "http://{{.BoulderHost}}:4001/directory"
[backends.backend] [backends.backend]
[backends.backend.servers.server1] [backends.backend.servers.server1]
url = "http://127.0.0.1:9010" url = "http://127.0.0.1:9010"
weight = 1
[frontends] [frontends]

View file

@ -25,6 +25,7 @@ caServer = "http://wrongurl:4001/directory"
[backends.backend] [backends.backend]
[backends.backend.servers.server1] [backends.backend.servers.server1]
url = "http://127.0.0.1:9010" url = "http://127.0.0.1:9010"
weight = 1
[frontends] [frontends]

View file

@ -11,17 +11,20 @@ logLevel = "DEBUG"
[backends.backend1] [backends.backend1]
[backends.backend1.servers.server1] [backends.backend1.servers.server1]
url = "http://{{.Server1}}:8989474" url = "http://{{.Server1}}:8989474"
weight = 1
[backends.error] [backends.error]
[backends.error.servers.error] [backends.error.servers.error]
url = "http://{{.Server2}}:80" url = "http://{{.Server2}}:80"
weight = 1
[frontends] [frontends]
[frontends.frontend1] [frontends.frontend1]
passHostHeader = true passHostHeader = true
backend = "backend1" backend = "backend1"
[frontends.frontend1.routes.test_1] [frontends.frontend1.routes.test_1]
rule = "Host:test.local" rule = "Host:test.local"
[frontends.frontend1.errors] [frontends.frontend1.errors]
[frontends.frontend1.errors.networks] [frontends.frontend1.errors.networks]
status = ["500-502", "503-599"] status = ["500-502", "503-599"]
backend = "error" backend = "error"
query = "/50x.html" query = "/50x.html"

View file

@ -11,17 +11,20 @@ logLevel = "DEBUG"
[backends.backend1] [backends.backend1]
[backends.backend1.servers.server1] [backends.backend1.servers.server1]
url = "http://{{.Server1}}:80" url = "http://{{.Server1}}:80"
weight = 1
[backends.error] [backends.error]
[backends.error.servers.error] [backends.error.servers.error]
url = "http://{{.Server2}}:80" url = "http://{{.Server2}}:80"
weight = 1
[frontends] [frontends]
[frontends.frontend1] [frontends.frontend1]
passHostHeader = true passHostHeader = true
backend = "backend1" backend = "backend1"
[frontends.frontend1.routes.test_1] [frontends.frontend1.routes.test_1]
rule = "Host:test.local" rule = "Host:test.local"
[frontends.frontend1.errors] [frontends.frontend1.errors]
[frontends.frontend1.errors.networks] [frontends.frontend1.errors.networks]
status = ["500-502", "503-599"] status = ["500-502", "503-599"]
backend = "error" backend = "error"
query = "/50x.html" query = "/50x.html"

View file

@ -3,6 +3,7 @@
[backends.backend1] [backends.backend1]
[backends.backend1.servers.server1] [backends.backend1.servers.server1]
url = "http://172.17.0.2:80" url = "http://172.17.0.2:80"
weight = 1
[frontends] [frontends]
[frontends.frontend1] [frontends.frontend1]

View file

@ -3,6 +3,7 @@
[backends.backend2] [backends.backend2]
[backends.backend2.servers.server1] [backends.backend2.servers.server1]
url = "http://172.17.0.2:80" url = "http://172.17.0.2:80"
weight = 1
[frontends] [frontends]
[frontends.frontend2] [frontends.frontend2]

View file

@ -19,6 +19,7 @@ rootCAs = [ """{{ .CertContent }}""" ]
[backends.backend1] [backends.backend1]
[backends.backend1.servers.server1] [backends.backend1.servers.server1]
url = "https://127.0.0.1:{{ .GRPCServerPort }}" url = "https://127.0.0.1:{{ .GRPCServerPort }}"
weight = 1
[frontends] [frontends]

View file

@ -19,6 +19,7 @@ insecureSkipVerify = true
[backends.backend1] [backends.backend1]
[backends.backend1.servers.server1] [backends.backend1.servers.server1]
url = "https://127.0.0.1:{{ .GRPCServerPort }}" url = "https://127.0.0.1:{{ .GRPCServerPort }}"
weight = 1
[frontends] [frontends]

View file

@ -20,8 +20,10 @@ logLevel = "DEBUG"
interval = "1s" interval = "1s"
[backends.backend1.servers.server1] [backends.backend1.servers.server1]
url = "http://{{.Server1}}:80" url = "http://{{.Server1}}:80"
weight = 1
[backends.backend1.servers.server2] [backends.backend1.servers.server2]
url = "http://{{.Server2}}:80" url = "http://{{.Server2}}:80"
weight = 1
[frontends] [frontends]
[frontends.frontend1] [frontends.frontend1]

View file

@ -20,8 +20,10 @@ logLevel = "DEBUG"
interval = "1s" interval = "1s"
[backends.backend1.servers.server1] [backends.backend1.servers.server1]
url = "http://{{.Server1}}:80" url = "http://{{.Server1}}:80"
weight = 1
[backends.backend1.servers.server2] [backends.backend1.servers.server2]
url = "http://{{.Server2}}:80" url = "http://{{.Server2}}:80"
weight = 1
[frontends] [frontends]
[frontends.frontend1] [frontends.frontend1]

View file

@ -17,6 +17,7 @@ logLevel = "DEBUG"
interval = "1s" interval = "1s"
[backends.backend1.servers.server1] [backends.backend1.servers.server1]
url = "http://{{.Server1}}:81" url = "http://{{.Server1}}:81"
weight = 1
[frontends] [frontends]
[frontends.frontend1] [frontends.frontend1]

View file

@ -16,8 +16,10 @@ logLevel = "DEBUG"
interval = "1s" interval = "1s"
[backends.backend1.servers.server1] [backends.backend1.servers.server1]
url = "http://{{.Server1}}:80" url = "http://{{.Server1}}:80"
weight = 1
[backends.backend1.servers.server2] [backends.backend1.servers.server2]
url = "http://{{.Server2}}:80" url = "http://{{.Server2}}:80"
weight = 1
[frontends] [frontends]
[frontends.frontend1] [frontends.frontend1]

View file

@ -24,9 +24,11 @@ defaultEntryPoints = ["https"]
[backends.backend1] [backends.backend1]
[backends.backend1.servers.server1] [backends.backend1.servers.server1]
url = "http://127.0.0.1:9010" url = "http://127.0.0.1:9010"
weight = 1
[backends.backend2] [backends.backend2]
[backends.backend2.servers.server1] [backends.backend2.servers.server1]
url = "http://127.0.0.1:9020" url = "http://127.0.0.1:9020"
weight = 1
[frontends] [frontends]
[frontends.frontend1] [frontends.frontend1]

View file

@ -23,9 +23,11 @@ defaultEntryPoints = ["https"]
[backends.backend1] [backends.backend1]
[backends.backend1.servers.server1] [backends.backend1.servers.server1]
url = "http://127.0.0.1:9010" url = "http://127.0.0.1:9010"
weight = 1
[backends.backend2] [backends.backend2]
[backends.backend2.servers.server1] [backends.backend2.servers.server1]
url = "http://127.0.0.1:9020" url = "http://127.0.0.1:9020"
weight = 1
[frontends] [frontends]
[frontends.frontend1] [frontends.frontend1]

View file

@ -24,9 +24,11 @@ defaultEntryPoints = ["https"]
[backends.backend1] [backends.backend1]
[backends.backend1.servers.server1] [backends.backend1.servers.server1]
url = "http://127.0.0.1:9010" url = "http://127.0.0.1:9010"
weight = 1
[backends.backend2] [backends.backend2]
[backends.backend2.servers.server1] [backends.backend2.servers.server1]
url = "http://127.0.0.1:9020" url = "http://127.0.0.1:9020"
weight = 1
[frontends] [frontends]
[frontends.frontend1] [frontends.frontend1]

View file

@ -2,9 +2,11 @@
[backends.backend1] [backends.backend1]
[backends.backend1.servers.server1] [backends.backend1.servers.server1]
url = "http://127.0.0.1:9010" url = "http://127.0.0.1:9010"
weight = 1
[backends.backend2] [backends.backend2]
[backends.backend2.servers.server1] [backends.backend2.servers.server1]
url = "http://127.0.0.1:9020" url = "http://127.0.0.1:9020"
weight = 1
[frontends] [frontends]
[frontends.frontend1] [frontends.frontend1]

View file

@ -21,9 +21,11 @@ defaultEntryPoints = ["https"]
[backends.backend1] [backends.backend1]
[backends.backend1.servers.server1] [backends.backend1.servers.server1]
url = "http://127.0.0.1:9010" url = "http://127.0.0.1:9010"
weight = 1
[backends.backend2] [backends.backend2]
[backends.backend2.servers.server1] [backends.backend2.servers.server1]
url = "http://127.0.0.1:9020" url = "http://127.0.0.1:9020"
weight = 1
[frontends] [frontends]
[frontends.frontend1] [frontends.frontend1]

View file

@ -32,6 +32,7 @@ fblo6RBxUQ==
[backends.backend1] [backends.backend1]
[backends.backend1.servers.server1] [backends.backend1.servers.server1]
url = "{{ .BackendHost }}" url = "{{ .BackendHost }}"
weight = 1
[frontends] [frontends]
[frontends.frontend1] [frontends.frontend1]

View file

@ -17,6 +17,8 @@ rootCAs = [ "fixtures/https/rootcas/local.crt"]
[backends.backend1] [backends.backend1]
[backends.backend1.servers.server1] [backends.backend1.servers.server1]
url = "{{ .BackendHost }}" url = "{{ .BackendHost }}"
weight = 1
[frontends] [frontends]
[frontends.frontend1] [frontends.frontend1]
backend = "backend1" backend = "backend1"

View file

@ -27,12 +27,14 @@ entryPoint = "api"
################################################################ ################################################################
# rules # rules
################################################################ ################################################################
[backends] [backends]
[backends.backend1] [backends.backend1]
[backends.backend1.servers.server1] [backends.backend1.servers.server1]
url = "http://127.0.0.1:8081" url = "http://127.0.0.1:8081"
[frontends] weight = 1
[frontends.frontend1]
backend = "backend1" [frontends]
[frontends.frontend1.routes.test_1] [frontends.frontend1]
rule = "Path: /test1" backend = "backend1"
[frontends.frontend1.routes.test_1]
rule = "Path: /test1"

View file

@ -19,7 +19,9 @@ exposedByDefault = false
backend = "backend-test" backend = "backend-test"
[frontends.frontend-1.routes.test_1] [frontends.frontend-1.routes.test_1]
rule = "PathPrefix:/file" rule = "PathPrefix:/file"
[backends] [backends]
[backends.backend-test] [backends.backend-test]
[backends.backend-test.servers.website] [backends.backend-test.servers.website]
url = "http://{{ .IP }}" url = "http://{{ .IP }}"
weight = 1

View file

@ -11,16 +11,16 @@ defaultEntryPoints = ["http", "https"]
[acme] [acme]
email = "test@traefik.io" email = "test@traefik.io"
storage = "/tmp/acme.json" storage = "/tmp/acme.json"
entryPoint = "https" entryPoint = "https"
onDemand = {{.OnDemand}} onDemand = {{.OnDemand}}
onHostRule = {{.OnHostRule}} onHostRule = {{.OnHostRule}}
caServer = "http://{{.BoulderHost}}:4001/directory" caServer = "http://{{.BoulderHost}}:4001/directory"
[acme.httpChallenge] [acme.httpChallenge]
entryPoint="http" entryPoint="http"
[[acme.domains]] [[acme.domains]]
main = "traefik.acme.wtf" main = "traefik.acme.wtf"
[api] [api]
@ -31,6 +31,7 @@ main = "traefik.acme.wtf"
[backends.backend] [backends.backend]
[backends.backend.servers.server1] [backends.backend.servers.server1]
url = "http://127.0.0.1:9010" url = "http://127.0.0.1:9010"
weight = 1
[frontends] [frontends]
[frontends.frontend] [frontends.frontend]

View file

@ -11,17 +11,17 @@ defaultEntryPoints = ["http", "https"]
[acme] [acme]
email = "test@traefik.io" email = "test@traefik.io"
storage = "/tmp/acme.json" storage = "/tmp/acme.json"
entryPoint = "https" entryPoint = "https"
onDemand = false onDemand = false
onHostRule = false onHostRule = false
caServer = "http://{{.BoulderHost}}:4001/directory" caServer = "http://{{.BoulderHost}}:4001/directory"
[acme.httpChallenge] [acme.httpChallenge]
entryPoint="http" entryPoint="http"
[[acme.domains]] [[acme.domains]]
main = "acme.wtf" main = "acme.wtf"
sans = [ "traefik.acme.wtf" ] sans = [ "traefik.acme.wtf" ]
[api] [api]
@ -32,6 +32,7 @@ sans = [ "traefik.acme.wtf" ]
[backends.backend] [backends.backend]
[backends.backend.servers.server1] [backends.backend.servers.server1]
url = "http://127.0.0.1:9010" url = "http://127.0.0.1:9010"
weight = 1
[frontends] [frontends]
[frontends.frontend] [frontends.frontend]

View file

@ -11,14 +11,14 @@ defaultEntryPoints = ["http", "https"]
[acme] [acme]
email = "test@traefik.io" email = "test@traefik.io"
storage = "/tmp/acme.json" storage = "/tmp/acme.jsonl"
entryPoint = "https" entryPoint = "https"
onDemand = {{.OnDemand}} onDemand = {{.OnDemand}}
onHostRule = {{.OnHostRule}} onHostRule = {{.OnHostRule}}
caServer = "http://{{.BoulderHost}}:4001/directory" caServer = "http://{{.BoulderHost}}:4001/directory"
[acme.httpChallenge] [acme.httpChallenge]
entryPoint="http" entryPoint="http"
[api] [api]
@ -28,6 +28,7 @@ entryPoint="http"
[backends.backend] [backends.backend]
[backends.backend.servers.server1] [backends.backend.servers.server1]
url = "http://127.0.0.1:9010" url = "http://127.0.0.1:9010"
weight = 1
[frontends] [frontends]
[frontends.frontend] [frontends.frontend]

View file

@ -2,22 +2,23 @@ logLevel = "DEBUG"
defaultEntryPoints = ["http"] defaultEntryPoints = ["http"]
[entryPoints] [entryPoints]
[entryPoints.http] [entryPoints.http]
address = ":8000" address = ":8000"
[entryPoints.http.proxyProtocol] [entryPoints.http.proxyProtocol]
trustedIPs = ["{{.HaproxyIP}}"] trustedIPs = ["{{.HaproxyIP}}"]
[api] [api]
[file] [file]
[backends] [backends]
[backends.backend1] [backends.backend1]
[backends.backend1.servers.server1] [backends.backend1.servers.server1]
url = "http://{{.WhoamiIP}}" url = "http://{{.WhoamiIP}}"
weight = 1
[frontends] [frontends]
[frontends.frontend1] [frontends.frontend1]
backend = "backend1" backend = "backend1"
[frontends.frontend1.routes.test_1] [frontends.frontend1.routes.test_1]
rule = "Path:/whoami" rule = "Path:/whoami"

View file

@ -2,22 +2,23 @@ logLevel = "DEBUG"
defaultEntryPoints = ["http"] defaultEntryPoints = ["http"]
[entryPoints] [entryPoints]
[entryPoints.http] [entryPoints.http]
address = ":8000" address = ":8000"
[entryPoints.http.proxyProtocol] [entryPoints.http.proxyProtocol]
trustedIPs = ["1.2.3.4"] trustedIPs = ["1.2.3.4"]
[api] [api]
[file] [file]
[backends] [backends]
[backends.backend1] [backends.backend1]
[backends.backend1.servers.server1] [backends.backend1.servers.server1]
url = "http://{{.WhoamiIP}}" url = "http://{{.WhoamiIP}}"
weight = 1
[frontends] [frontends]
[frontends.frontend1] [frontends.frontend1]
backend = "backend1" backend = "backend1"
[frontends.frontend1.routes.test_1] [frontends.frontend1.routes.test_1]
rule = "Path:/whoami" rule = "Path:/whoami"

View file

@ -12,19 +12,21 @@ logLevel = "DEBUG"
[backends.backend1] [backends.backend1]
[backends.backend1.servers.server1] [backends.backend1.servers.server1]
url = "http://{{.Server1}}:80" url = "http://{{.Server1}}:80"
weight = 1
[frontends] [frontends]
[frontends.frontend1] [frontends.frontend1]
passHostHeader = true passHostHeader = true
backend = "backend1" backend = "backend1"
[frontends.frontend1.routes.test_1] [frontends.frontend1.routes.test_1]
rule = "Path:/" rule = "Path:/"
[frontends.frontend1.ratelimit] [frontends.frontend1.ratelimit]
extractorfunc = "client.ip" extractorfunc = "client.ip"
[frontends.frontend1.ratelimit.rateset.rateset1] [frontends.frontend1.ratelimit.rateset.rateset1]
period = "60s" period = "60s"
average = 4 average = 4
burst = 5 burst = 5
[frontends.frontend1.ratelimit.rateset.rateset2] [frontends.frontend1.ratelimit.rateset.rateset2]
period = "3s" period = "3s"
average = 1 average = 1
burst = 2 burst = 2

View file

@ -17,6 +17,7 @@ logLevel = "DEBUG"
[backends.backend] [backends.backend]
[backends.backend.servers.server] [backends.backend.servers.server]
url = "{{.Server}}" url = "{{.Server}}"
weight = 1
[frontends] [frontends]
[frontends.frontend] [frontends.frontend]

View file

@ -15,8 +15,10 @@ logLevel = "DEBUG"
[backends.backend1] [backends.backend1]
[backends.backend1.servers.server1] [backends.backend1.servers.server1]
url = "http://{{.WhoamiEndpoint}}:8080" # not valid url = "http://{{.WhoamiEndpoint}}:8080" # not valid
weight = 1
[backends.backend1.servers.server2] [backends.backend1.servers.server2]
url = "http://{{.WhoamiEndpoint}}:80" url = "http://{{.WhoamiEndpoint}}:80"
weight = 1
[frontends] [frontends]
[frontends.frontend1] [frontends.frontend1]

View file

@ -5,26 +5,29 @@ debug=true
address = ":8000" address = ":8000"
[api] [api]
[file] [file]
[backends]
[backends.backend1] [backends]
[backends.backend1.servers.server1] [backends.backend1]
url = "{{ .Server1 }}" [backends.backend1.servers.server1]
url = "{{ .Server1 }}"
weight = 1
[backends.backend2] [backends.backend2]
[backends.backend2.servers.server1] [backends.backend2.servers.server1]
url = "{{ .Server2 }}" url = "{{ .Server2 }}"
weight = 1
[frontends] [frontends]
[frontends.frontend1] [frontends.frontend1]
entrypoints=["http"] entrypoints=["http"]
backend = "backend1"
[frontends.frontend1.routes.test_1]
rule = "PathPrefix:/whoami"
backend = "backend1" [frontends.frontend2]
[frontends.frontend1.routes.test_1] backend = "backend2"
rule = "PathPrefix:/whoami" entrypoints=["traefik"]
[frontends.frontend2.routes.test_1]
[frontends.frontend2] rule = "PathPrefix:/whoami"
backend = "backend2"
entrypoints=["traefik"]
[frontends.frontend2.routes.test_1]
rule = "PathPrefix:/whoami"

View file

@ -22,9 +22,11 @@ responseHeaderTimeout = "300ms"
# Non-routable IP address that should always deliver a dial timeout. # Non-routable IP address that should always deliver a dial timeout.
# See: https://stackoverflow.com/questions/100841/artificially-create-a-connection-timeout-error#answer-904609 # See: https://stackoverflow.com/questions/100841/artificially-create-a-connection-timeout-error#answer-904609
url = "http://50.255.255.1" url = "http://50.255.255.1"
weight = 1
[backends.backend2] [backends.backend2]
[backends.backend2.servers.server2] [backends.backend2.servers.server2]
url = "http://{{.TimeoutEndpoint}}:9000" url = "http://{{.TimeoutEndpoint}}:9000"
weight = 1
[frontends] [frontends]
[frontends.frontend1] [frontends.frontend1]

View file

@ -6,32 +6,38 @@ debug = true
[api] [api]
[entryPoints] [entryPoints]
[entryPoints.http] [entryPoints.http]
address = ":8000" address = ":8000"
[tracing] [tracing]
backend = "{{.TracingBackend}}" backend = "{{.TracingBackend}}"
servicename = "tracing" servicename = "tracing"
[tracing.zipkin] [tracing.zipkin]
httpEndpoint = "http://{{.ZipkinIP}}:9411/api/v1/spans" httpEndpoint = "http://{{.ZipkinIP}}:9411/api/v1/spans"
debug = true debug = true
[tracing.jaeger] [tracing.jaeger]
samplingType = "const" samplingType = "const"
samplingParam = 1.0 samplingParam = 1.0
[retry] [retry]
attempts = 3 attempts = 3
[file] [file]
[backends] [backends]
[backends.backend1] [backends.backend1]
[backends.backend1.servers.server-ratelimit] [backends.backend1.servers.server-ratelimit]
url = "http://{{.WhoAmiIP}}:{{.WhoAmiPort}}" url = "http://{{.WhoAmiIP}}:{{.WhoAmiPort}}"
weight = 1
[backends.backend2] [backends.backend2]
[backends.backend2.servers.server-retry] [backends.backend2.servers.server-retry]
url = "http://{{.WhoAmiIP}}:{{.WhoAmiPort}}" url = "http://{{.WhoAmiIP}}:{{.WhoAmiPort}}"
weight = 1
[backends.backend3] [backends.backend3]
[backends.backend3.servers.server-auth] [backends.backend3.servers.server-auth]
url = "http://{{.WhoAmiIP}}:{{.WhoAmiPort}}" url = "http://{{.WhoAmiIP}}:{{.WhoAmiPort}}"
weight = 1
[frontends] [frontends]
[frontends.frontend1] [frontends.frontend1]
passHostHeader = true passHostHeader = true

View file

@ -6,7 +6,6 @@ logLevel = "DEBUG"
[entryPoints.http] [entryPoints.http]
address = ":8000" address = ":8000"
[api] [api]
[file] [file]
@ -15,6 +14,7 @@ logLevel = "DEBUG"
[backends.backend1] [backends.backend1]
[backends.backend1.servers.server1] [backends.backend1.servers.server1]
url = "{{ .WebsocketServer }}" url = "{{ .WebsocketServer }}"
weight = 1
[frontends] [frontends]
[frontends.frontend1] [frontends.frontend1]

View file

@ -19,6 +19,7 @@ insecureSkipVerify=true
[backends.backend1] [backends.backend1]
[backends.backend1.servers.server1] [backends.backend1.servers.server1]
url = "{{ .WebsocketServer }}" url = "{{ .WebsocketServer }}"
weight = 1
[frontends] [frontends]
[frontends.frontend1] [frontends.frontend1]

View file

@ -39,8 +39,8 @@ func (p *Provider) buildConfigurationV2(catalog []catalogUpdate) *types.Configur
"getFrontendRule": p.getFrontendRule, "getFrontendRule": p.getFrontendRule,
"getBasicAuth": label.GetFuncSliceString(label.TraefikFrontendAuthBasic), "getBasicAuth": label.GetFuncSliceString(label.TraefikFrontendAuthBasic),
"getFrontEndEntryPoints": label.GetFuncSliceString(label.TraefikFrontendEntryPoints), "getFrontEndEntryPoints": label.GetFuncSliceString(label.TraefikFrontendEntryPoints),
"getPriority": label.GetFuncInt(label.TraefikFrontendPriority, label.DefaultFrontendPriorityInt), "getPriority": label.GetFuncInt(label.TraefikFrontendPriority, label.DefaultFrontendPriority),
"getPassHostHeader": label.GetFuncBool(label.TraefikFrontendPassHostHeader, label.DefaultPassHostHeaderBool), "getPassHostHeader": label.GetFuncBool(label.TraefikFrontendPassHostHeader, label.DefaultPassHostHeader),
"getPassTLSCert": label.GetFuncBool(label.TraefikFrontendPassTLSCert, label.DefaultPassTLSCert), "getPassTLSCert": label.GetFuncBool(label.TraefikFrontendPassTLSCert, label.DefaultPassTLSCert),
"getWhiteList": label.GetWhiteList, "getWhiteList": label.GetWhiteList,
"getRedirect": label.GetRedirect, "getRedirect": label.GetRedirect,
@ -192,7 +192,7 @@ func getServerName(node *api.ServiceEntry, index int) string {
} }
func (p *Provider) getWeight(tags []string) int { func (p *Provider) getWeight(tags []string) int {
weight := p.getIntAttribute(label.SuffixWeight, tags, label.DefaultWeightInt) weight := p.getIntAttribute(label.SuffixWeight, tags, label.DefaultWeight)
// Deprecated // Deprecated
deprecatedWeightTag := "backend." + label.SuffixWeight deprecatedWeightTag := "backend." + label.SuffixWeight
@ -200,7 +200,7 @@ func (p *Provider) getWeight(tags []string) int {
log.Warnf("Deprecated configuration found: %s. Please use %s.", log.Warnf("Deprecated configuration found: %s. Please use %s.",
p.getPrefixedName(deprecatedWeightTag), p.getPrefixedName(label.SuffixWeight)) p.getPrefixedName(deprecatedWeightTag), p.getPrefixedName(label.SuffixWeight))
weight = p.getIntAttribute(deprecatedWeightTag, tags, label.DefaultWeightInt) weight = p.getIntAttribute(deprecatedWeightTag, tags, label.DefaultWeight)
} }
return weight return weight

View file

@ -36,8 +36,8 @@ func (p *Provider) buildConfigurationV1(catalog []catalogUpdate) *types.Configur
"getFrontendRule": p.getFrontendRuleV1, "getFrontendRule": p.getFrontendRuleV1,
"getBasicAuth": p.getFuncSliceAttribute(label.SuffixFrontendAuthBasic), "getBasicAuth": p.getFuncSliceAttribute(label.SuffixFrontendAuthBasic),
"getEntryPoints": getEntryPointsV1, "getEntryPoints": getEntryPointsV1,
"getPriority": p.getFuncIntAttribute(label.SuffixFrontendPriority, label.DefaultFrontendPriorityInt), "getPriority": p.getFuncIntAttribute(label.SuffixFrontendPriority, label.DefaultFrontendPriority),
"getPassHostHeader": p.getFuncBoolAttribute(label.SuffixFrontendPassHostHeader, label.DefaultPassHostHeaderBool), "getPassHostHeader": p.getFuncBoolAttribute(label.SuffixFrontendPassHostHeader, label.DefaultPassHostHeader),
"getPassTLSCert": p.getFuncBoolAttribute(label.SuffixFrontendPassTLSCert, label.DefaultPassTLSCert), "getPassTLSCert": p.getFuncBoolAttribute(label.SuffixFrontendPassTLSCert, label.DefaultPassTLSCert),
} }

View file

@ -40,8 +40,8 @@ func (p *Provider) buildConfigurationV2(containersInspected []dockerData) *types
// Frontend functions // Frontend functions
"getBackendName": getBackendName, "getBackendName": getBackendName,
"getPriority": label.GetFuncInt(label.TraefikFrontendPriority, label.DefaultFrontendPriorityInt), "getPriority": label.GetFuncInt(label.TraefikFrontendPriority, label.DefaultFrontendPriority),
"getPassHostHeader": label.GetFuncBool(label.TraefikFrontendPassHostHeader, label.DefaultPassHostHeaderBool), "getPassHostHeader": label.GetFuncBool(label.TraefikFrontendPassHostHeader, label.DefaultPassHostHeader),
"getPassTLSCert": label.GetFuncBool(label.TraefikFrontendPassTLSCert, label.DefaultPassTLSCert), "getPassTLSCert": label.GetFuncBool(label.TraefikFrontendPassTLSCert, label.DefaultPassTLSCert),
"getEntryPoints": label.GetFuncSliceString(label.TraefikFrontendEntryPoints), "getEntryPoints": label.GetFuncSliceString(label.TraefikFrontendEntryPoints),
"getBasicAuth": label.GetFuncSliceString(label.TraefikFrontendAuthBasic), "getBasicAuth": label.GetFuncSliceString(label.TraefikFrontendAuthBasic),
@ -318,7 +318,7 @@ func (p *Provider) getServers(containers []dockerData) map[string]types.Server {
servers[provider.Normalize(serverName)] = types.Server{ servers[provider.Normalize(serverName)] = types.Server{
URL: fmt.Sprintf("%s://%s:%s", protocol, ip, port), URL: fmt.Sprintf("%s://%s:%s", protocol, ip, port),
Weight: label.GetIntValue(container.SegmentLabels, label.TraefikWeight, label.DefaultWeightInt), Weight: label.GetIntValue(container.SegmentLabels, label.TraefikWeight, label.DefaultWeight),
} }
} }

View file

@ -57,7 +57,7 @@ func TestDockerBuildConfiguration(t *testing.T) {
Servers: map[string]types.Server{ Servers: map[string]types.Server{
"server-test": { "server-test": {
URL: "http://127.0.0.1:80", URL: "http://127.0.0.1:80",
Weight: 0, Weight: label.DefaultWeight,
}, },
}, },
CircuitBreaker: nil, CircuitBreaker: nil,

View file

@ -59,7 +59,7 @@ func TestSwarmBuildConfiguration(t *testing.T) {
Servers: map[string]types.Server{ Servers: map[string]types.Server{
"server-test": { "server-test": {
URL: "http://127.0.0.1:80", URL: "http://127.0.0.1:80",
Weight: 0, Weight: label.DefaultWeight,
}, },
}, },
}, },

View file

@ -59,7 +59,7 @@ func TestSegmentBuildConfiguration(t *testing.T) {
Servers: map[string]types.Server{ Servers: map[string]types.Server{
"server-sauternes-foo-0": { "server-sauternes-foo-0": {
URL: "http://127.0.0.1:2503", URL: "http://127.0.0.1:2503",
Weight: 0, Weight: label.DefaultWeight,
}, },
}, },
CircuitBreaker: nil, CircuitBreaker: nil,

View file

@ -21,7 +21,7 @@ func (p *Provider) buildConfigurationV1(containersInspected []dockerData) *types
// Backend functions // Backend functions
"getIPAddress": p.getIPAddress, "getIPAddress": p.getIPAddress,
"getPort": getPortV1, "getPort": getPortV1,
"getWeight": getFuncIntLabelV1(label.TraefikWeight, label.DefaultWeightInt), "getWeight": getFuncIntLabelV1(label.TraefikWeight, label.DefaultWeight),
"getProtocol": getFuncStringLabelV1(label.TraefikProtocol, label.DefaultProtocol), "getProtocol": getFuncStringLabelV1(label.TraefikProtocol, label.DefaultProtocol),
"hasCircuitBreakerLabel": hasFuncV1(label.TraefikBackendCircuitBreakerExpression), "hasCircuitBreakerLabel": hasFuncV1(label.TraefikBackendCircuitBreakerExpression),
@ -38,8 +38,8 @@ func (p *Provider) buildConfigurationV1(containersInspected []dockerData) *types
// Frontend functions // Frontend functions
"getBackend": getBackendNameV1, "getBackend": getBackendNameV1,
"getBackendName": getBackendNameV1, "getBackendName": getBackendNameV1,
"getPriority": getFuncIntLabelV1(label.TraefikFrontendPriority, label.DefaultFrontendPriorityInt), "getPriority": getFuncIntLabelV1(label.TraefikFrontendPriority, label.DefaultFrontendPriority),
"getPassHostHeader": getFuncBoolLabelV1(label.TraefikFrontendPassHostHeader, label.DefaultPassHostHeaderBool), "getPassHostHeader": getFuncBoolLabelV1(label.TraefikFrontendPassHostHeader, label.DefaultPassHostHeader),
"getPassTLSCert": getFuncBoolLabelV1(label.TraefikFrontendPassTLSCert, label.DefaultPassTLSCert), "getPassTLSCert": getFuncBoolLabelV1(label.TraefikFrontendPassTLSCert, label.DefaultPassTLSCert),
"getEntryPoints": getFuncSliceStringLabelV1(label.TraefikFrontendEntryPoints), "getEntryPoints": getFuncSliceStringLabelV1(label.TraefikFrontendEntryPoints),
"getBasicAuth": getFuncSliceStringLabelV1(label.TraefikFrontendAuthBasic), "getBasicAuth": getFuncSliceStringLabelV1(label.TraefikFrontendAuthBasic),
@ -100,15 +100,15 @@ func (p *Provider) buildConfigurationV1(containersInspected []dockerData) *types
// Services - Backend server functions // Services - Backend server functions
"getServicePort": getServicePortV1, "getServicePort": getServicePortV1,
"getServiceProtocol": getFuncServiceStringLabelV1(label.SuffixProtocol, label.DefaultProtocol), "getServiceProtocol": getFuncServiceStringLabelV1(label.SuffixProtocol, label.DefaultProtocol),
"getServiceWeight": getFuncServiceStringLabelV1(label.SuffixWeight, label.DefaultWeight), "getServiceWeight": getFuncServiceIntLabelV1(label.SuffixWeight, label.DefaultWeight),
// Services - Frontend functions // Services - Frontend functions
"getServiceEntryPoints": getFuncServiceSliceStringLabelV1(label.SuffixFrontendEntryPoints), "getServiceEntryPoints": getFuncServiceSliceStringLabelV1(label.SuffixFrontendEntryPoints),
"getServiceWhitelistSourceRange": getFuncServiceSliceStringLabelV1(label.SuffixFrontendWhiteListSourceRange), "getServiceWhitelistSourceRange": getFuncServiceSliceStringLabelV1(label.SuffixFrontendWhiteListSourceRange),
"getServiceBasicAuth": getFuncServiceSliceStringLabelV1(label.SuffixFrontendAuthBasic), "getServiceBasicAuth": getFuncServiceSliceStringLabelV1(label.SuffixFrontendAuthBasic),
"getServiceFrontendRule": p.getServiceFrontendRuleV1, "getServiceFrontendRule": p.getServiceFrontendRuleV1,
"getServicePassHostHeader": getFuncServiceBoolLabelV1(label.SuffixFrontendPassHostHeader, label.DefaultPassHostHeaderBool), "getServicePassHostHeader": getFuncServiceBoolLabelV1(label.SuffixFrontendPassHostHeader, label.DefaultPassHostHeader),
"getServicePassTLSCert": getFuncServiceBoolLabelV1(label.SuffixFrontendPassTLSCert, label.DefaultPassTLSCert), "getServicePassTLSCert": getFuncServiceBoolLabelV1(label.SuffixFrontendPassTLSCert, label.DefaultPassTLSCert),
"getServicePriority": getFuncServiceIntLabelV1(label.SuffixFrontendPriority, label.DefaultFrontendPriorityInt), "getServicePriority": getFuncServiceIntLabelV1(label.SuffixFrontendPriority, label.DefaultFrontendPriority),
"hasServiceRedirect": hasServiceRedirectV1, "hasServiceRedirect": hasServiceRedirectV1,
"getServiceRedirectEntryPoint": getFuncServiceStringLabelV1(label.SuffixFrontendRedirectEntryPoint, ""), "getServiceRedirectEntryPoint": getFuncServiceStringLabelV1(label.SuffixFrontendRedirectEntryPoint, ""),
"getServiceRedirectReplacement": getFuncServiceStringLabelV1(label.SuffixFrontendRedirectReplacement, ""), "getServiceRedirectReplacement": getFuncServiceStringLabelV1(label.SuffixFrontendRedirectReplacement, ""),

View file

@ -56,7 +56,7 @@ func TestDockerBuildConfigurationV1(t *testing.T) {
Servers: map[string]types.Server{ Servers: map[string]types.Server{
"server-test": { "server-test": {
URL: "http://127.0.0.1:80", URL: "http://127.0.0.1:80",
Weight: 0, Weight: label.DefaultWeight,
}, },
}, },
CircuitBreaker: nil, CircuitBreaker: nil,
@ -584,17 +584,17 @@ func TestDockerGetFuncStringLabelV1(t *testing.T) {
}{ }{
{ {
container: containerJSON(), container: containerJSON(),
labelName: label.TraefikWeight, labelName: label.TraefikProtocol,
defaultValue: label.DefaultWeight, defaultValue: label.DefaultProtocol,
expected: "0", expected: "http",
}, },
{ {
container: containerJSON(labels(map[string]string{ container: containerJSON(labels(map[string]string{
label.TraefikWeight: "10", label.TraefikProtocol: "https",
})), })),
labelName: label.TraefikWeight, labelName: label.TraefikProtocol,
defaultValue: label.DefaultWeight, defaultValue: label.DefaultProtocol,
expected: "10", expected: "https",
}, },
} }

View file

@ -57,7 +57,7 @@ func TestSwarmBuildConfigurationV1(t *testing.T) {
Servers: map[string]types.Server{ Servers: map[string]types.Server{
"server-test": { "server-test": {
URL: "http://127.0.0.1:80", URL: "http://127.0.0.1:80",
Weight: 0, Weight: label.DefaultWeight,
}, },
}, },
}, },
@ -420,19 +420,19 @@ func TestSwarmGetFuncStringLabelV1(t *testing.T) {
}{ }{
{ {
service: swarmService(), service: swarmService(),
labelName: label.TraefikWeight, labelName: label.TraefikProtocol,
defaultValue: label.DefaultWeight, defaultValue: label.DefaultProtocol,
networks: map[string]*docker.NetworkResource{}, networks: map[string]*docker.NetworkResource{},
expected: "0", expected: "http",
}, },
{ {
service: swarmService(serviceLabels(map[string]string{ service: swarmService(serviceLabels(map[string]string{
label.TraefikWeight: "10", label.TraefikProtocol: "https",
})), })),
labelName: label.TraefikWeight, labelName: label.TraefikProtocol,
defaultValue: label.DefaultWeight, defaultValue: label.DefaultProtocol,
networks: map[string]*docker.NetworkResource{}, networks: map[string]*docker.NetworkResource{},
expected: "10", expected: "https",
}, },
} }

View file

@ -59,7 +59,7 @@ func TestDockerServiceBuildConfigurationV1(t *testing.T) {
Servers: map[string]types.Server{ Servers: map[string]types.Server{
"service-0": { "service-0": {
URL: "http://127.0.0.1:2503", URL: "http://127.0.0.1:2503",
Weight: 0, Weight: label.DefaultWeight,
}, },
}, },
CircuitBreaker: nil, CircuitBreaker: nil,
@ -272,25 +272,25 @@ func TestDockerGetFuncServiceStringLabelV1(t *testing.T) {
}{ }{
{ {
container: containerJSON(), container: containerJSON(),
suffixLabel: label.SuffixWeight, suffixLabel: label.SuffixProtocol,
defaultValue: label.DefaultWeight, defaultValue: label.DefaultProtocol,
expected: "0", expected: "http",
}, },
{ {
container: containerJSON(labels(map[string]string{ container: containerJSON(labels(map[string]string{
label.TraefikWeight: "200", label.TraefikProtocol: "https",
})), })),
suffixLabel: label.SuffixWeight, suffixLabel: label.SuffixProtocol,
defaultValue: label.DefaultWeight, defaultValue: label.DefaultProtocol,
expected: "200", expected: "https",
}, },
{ {
container: containerJSON(labels(map[string]string{ container: containerJSON(labels(map[string]string{
"traefik.myservice.weight": "31337", label.Prefix + "myservice." + label.SuffixProtocol: "https",
})), })),
suffixLabel: label.SuffixWeight, suffixLabel: label.SuffixProtocol,
defaultValue: label.DefaultWeight, defaultValue: label.DefaultProtocol,
expected: "31337", expected: "https",
}, },
} }

View file

@ -42,9 +42,9 @@ func (p *Provider) buildConfigurationV2(instances []ecsInstance) (*types.Configu
// Frontend functions // Frontend functions
"filterFrontends": filterFrontends, "filterFrontends": filterFrontends,
"getFrontendRule": p.getFrontendRule, "getFrontendRule": p.getFrontendRule,
"getPassHostHeader": label.GetFuncBool(label.TraefikFrontendPassHostHeader, label.DefaultPassHostHeaderBool), "getPassHostHeader": label.GetFuncBool(label.TraefikFrontendPassHostHeader, label.DefaultPassHostHeader),
"getPassTLSCert": label.GetFuncBool(label.TraefikFrontendPassTLSCert, label.DefaultPassTLSCert), "getPassTLSCert": label.GetFuncBool(label.TraefikFrontendPassTLSCert, label.DefaultPassTLSCert),
"getPriority": label.GetFuncInt(label.TraefikFrontendPriority, label.DefaultFrontendPriorityInt), "getPriority": label.GetFuncInt(label.TraefikFrontendPriority, label.DefaultFrontendPriority),
"getBasicAuth": label.GetFuncSliceString(label.TraefikFrontendAuthBasic), "getBasicAuth": label.GetFuncSliceString(label.TraefikFrontendAuthBasic),
"getEntryPoints": label.GetFuncSliceString(label.TraefikFrontendEntryPoints), "getEntryPoints": label.GetFuncSliceString(label.TraefikFrontendEntryPoints),
"getRedirect": label.GetRedirect, "getRedirect": label.GetRedirect,
@ -133,7 +133,7 @@ func getServers(instances []ecsInstance) map[string]types.Server {
serverName := provider.Normalize(fmt.Sprintf("server-%s-%s", instance.Name, instance.ID)) serverName := provider.Normalize(fmt.Sprintf("server-%s-%s", instance.Name, instance.ID))
servers[serverName] = types.Server{ servers[serverName] = types.Server{
URL: fmt.Sprintf("%s://%s:%s", protocol, host, port), URL: fmt.Sprintf("%s://%s:%s", protocol, host, port),
Weight: label.GetIntValue(instance.TraefikLabels, label.TraefikWeight, 0), Weight: label.GetIntValue(instance.TraefikLabels, label.TraefikWeight, label.DefaultWeight),
} }
} }

View file

@ -47,7 +47,8 @@ func TestBuildConfiguration(t *testing.T) {
"backend-instance": { "backend-instance": {
Servers: map[string]types.Server{ Servers: map[string]types.Server{
"server-instance-1": { "server-instance-1": {
URL: "http://10.0.0.1:1337", URL: "http://10.0.0.1:1337",
Weight: label.DefaultWeight,
}}, }},
}, },
}, },
@ -99,7 +100,8 @@ func TestBuildConfiguration(t *testing.T) {
}, },
Servers: map[string]types.Server{ Servers: map[string]types.Server{
"server-instance-1": { "server-instance-1": {
URL: "http://10.0.0.1:1337", URL: "http://10.0.0.1:1337",
Weight: label.DefaultWeight,
}}, }},
}, },
}, },

View file

@ -31,7 +31,7 @@ func (p *Provider) buildConfigurationV1(instances []ecsInstance) (*types.Configu
"getPort": getPort, "getPort": getPort,
"getProtocol": getFuncStringValueV1(label.TraefikProtocol, label.DefaultProtocol), "getProtocol": getFuncStringValueV1(label.TraefikProtocol, label.DefaultProtocol),
"getWeight": getFuncIntValueV1(label.TraefikWeight, label.DefaultWeightInt), "getWeight": getFuncIntValueV1(label.TraefikWeight, label.DefaultWeight),
"getLoadBalancerMethod": getFuncFirstStringValueV1(label.TraefikBackendLoadBalancerMethod, label.DefaultBackendLoadBalancerMethod), "getLoadBalancerMethod": getFuncFirstStringValueV1(label.TraefikBackendLoadBalancerMethod, label.DefaultBackendLoadBalancerMethod),
"getLoadBalancerSticky": getStickyV1, "getLoadBalancerSticky": getStickyV1,
"hasStickinessLabel": getFuncFirstBoolValueV1(label.TraefikBackendLoadBalancerStickiness, false), "hasStickinessLabel": getFuncFirstBoolValueV1(label.TraefikBackendLoadBalancerStickiness, false),
@ -43,9 +43,9 @@ func (p *Provider) buildConfigurationV1(instances []ecsInstance) (*types.Configu
// Frontend functions // Frontend functions
"filterFrontends": filterFrontends, "filterFrontends": filterFrontends,
"getFrontendRule": p.getFrontendRule, "getFrontendRule": p.getFrontendRule,
"getPassHostHeader": getFuncBoolValueV1(label.TraefikFrontendPassHostHeader, label.DefaultPassHostHeaderBool), "getPassHostHeader": getFuncBoolValueV1(label.TraefikFrontendPassHostHeader, label.DefaultPassHostHeader),
"getPassTLSCert": getFuncBoolValueV1(label.TraefikFrontendPassTLSCert, label.DefaultPassTLSCert), "getPassTLSCert": getFuncBoolValueV1(label.TraefikFrontendPassTLSCert, label.DefaultPassTLSCert),
"getPriority": getFuncIntValueV1(label.TraefikFrontendPriority, label.DefaultFrontendPriorityInt), "getPriority": getFuncIntValueV1(label.TraefikFrontendPriority, label.DefaultFrontendPriority),
"getBasicAuth": getFuncSliceStringV1(label.TraefikFrontendAuthBasic), "getBasicAuth": getFuncSliceStringV1(label.TraefikFrontendAuthBasic),
"getEntryPoints": getFuncSliceStringV1(label.TraefikFrontendEntryPoints), "getEntryPoints": getFuncSliceStringV1(label.TraefikFrontendEntryPoints),
} }

View file

@ -45,7 +45,8 @@ func TestBuildConfigurationV1(t *testing.T) {
"backend-testing": { "backend-testing": {
Servers: map[string]types.Server{ Servers: map[string]types.Server{
"server-testing1": { "server-testing1": {
URL: "http://10.0.0.1:1337", URL: "http://10.0.0.1:1337",
Weight: label.DefaultWeight,
}}, }},
LoadBalancer: &types.LoadBalancer{ LoadBalancer: &types.LoadBalancer{
Method: "wrr", Method: "wrr",
@ -100,7 +101,8 @@ func TestBuildConfigurationV1(t *testing.T) {
}, },
Servers: map[string]types.Server{ Servers: map[string]types.Server{
"server-testing1": { "server-testing1": {
URL: "http://10.0.0.1:1337", URL: "http://10.0.0.1:1337",
Weight: label.DefaultWeight,
}}, }},
LoadBalancer: &types.LoadBalancer{ LoadBalancer: &types.LoadBalancer{
Method: "wrr", Method: "wrr",

View file

@ -52,6 +52,6 @@ func getProtocol(instance eureka.InstanceInfo) string {
return label.DefaultProtocol return label.DefaultProtocol
} }
func getWeight(instance eureka.InstanceInfo) string { func getWeight(instance eureka.InstanceInfo) int {
return label.GetStringValue(instance.Metadata.Map, label.TraefikWeight, label.DefaultWeight) return label.GetIntValue(instance.Metadata.Map, label.TraefikWeight, label.DefaultWeight)
} }

View file

@ -91,11 +91,11 @@ func TestGetProtocol(t *testing.T) {
func TestGetWeight(t *testing.T) { func TestGetWeight(t *testing.T) {
testCases := []struct { testCases := []struct {
expectedWeight string expectedWeight int
instanceInfo eureka.InstanceInfo instanceInfo eureka.InstanceInfo
}{ }{
{ {
expectedWeight: "0", expectedWeight: label.DefaultWeight,
instanceInfo: eureka.InstanceInfo{ instanceInfo: eureka.InstanceInfo{
Port: &eureka.Port{ Port: &eureka.Port{
Port: 80, Enabled: true, Port: 80, Enabled: true,
@ -106,7 +106,7 @@ func TestGetWeight(t *testing.T) {
}, },
}, },
{ {
expectedWeight: "10", expectedWeight: 10,
instanceInfo: eureka.InstanceInfo{ instanceInfo: eureka.InstanceInfo{
Port: &eureka.Port{ Port: &eureka.Port{
Port: 80, Enabled: true, Port: 80, Enabled: true,

View file

@ -5,6 +5,7 @@ import (
"time" "time"
"github.com/containous/flaeg" "github.com/containous/flaeg"
"github.com/containous/traefik/provider/label"
"github.com/containous/traefik/tls" "github.com/containous/traefik/tls"
"github.com/containous/traefik/types" "github.com/containous/traefik/types"
"github.com/stretchr/testify/assert" "github.com/stretchr/testify/assert"
@ -448,11 +449,11 @@ func sampleConfiguration() *types.Configuration {
Servers: map[string]types.Server{ Servers: map[string]types.Server{
"http://10.10.0.1:8080": { "http://10.10.0.1:8080": {
URL: "http://10.10.0.1:8080", URL: "http://10.10.0.1:8080",
Weight: 1, Weight: label.DefaultWeight,
}, },
"http://10.21.0.1:8080": { "http://10.21.0.1:8080": {
URL: "http://10.21.0.1:8080", URL: "http://10.21.0.1:8080",
Weight: 1, Weight: label.DefaultWeight,
}, },
}, },
CircuitBreaker: nil, CircuitBreaker: nil,
@ -464,7 +465,7 @@ func sampleConfiguration() *types.Configuration {
Servers: map[string]types.Server{ Servers: map[string]types.Server{
"https://example.com": { "https://example.com": {
URL: "https://example.com", URL: "https://example.com",
Weight: 1, Weight: label.DefaultWeight,
}, },
}, },
CircuitBreaker: nil, CircuitBreaker: nil,
@ -476,11 +477,11 @@ func sampleConfiguration() *types.Configuration {
Servers: map[string]types.Server{ Servers: map[string]types.Server{
"https://10.15.0.1:8443": { "https://10.15.0.1:8443": {
URL: "https://10.15.0.1:8443", URL: "https://10.15.0.1:8443",
Weight: 1, Weight: label.DefaultWeight,
}, },
"https://10.15.0.2:9443": { "https://10.15.0.2:9443": {
URL: "https://10.15.0.2:9443", URL: "https://10.15.0.2:9443",
Weight: 1, Weight: label.DefaultWeight,
}, },
}, },
CircuitBreaker: nil, CircuitBreaker: nil,

View file

@ -267,7 +267,7 @@ func (p *Provider) loadIngresses(k8sClient Client) (*types.Configuration, error)
templateObjects.Backends[baseName].Servers[name] = types.Server{ templateObjects.Backends[baseName].Servers[name] = types.Server{
URL: url, URL: url,
Weight: 1, Weight: label.DefaultWeight,
} }
} else { } else {
endpoints, exists, err := k8sClient.GetEndpoints(service.Namespace, service.Name) endpoints, exists, err := k8sClient.GetEndpoints(service.Namespace, service.Name)
@ -295,7 +295,7 @@ func (p *Provider) loadIngresses(k8sClient Client) (*types.Configuration, error)
} }
templateObjects.Backends[baseName].Servers[name] = types.Server{ templateObjects.Backends[baseName].Servers[name] = types.Server{
URL: url, URL: url,
Weight: 1, Weight: label.DefaultWeight,
} }
} }
} }

View file

@ -116,9 +116,9 @@ func TestFiller(t *testing.T) {
{Key: "traefik/backends/backend.with.dot.too/servers", Value: []byte("")}, {Key: "traefik/backends/backend.with.dot.too/servers", Value: []byte("")},
{Key: "traefik/backends/backend.with.dot.too/servers/server.with.dot", Value: []byte("")}, {Key: "traefik/backends/backend.with.dot.too/servers/server.with.dot", Value: []byte("")},
{Key: "traefik/backends/backend.with.dot.too/servers/server.with.dot.without.url", Value: []byte("")}, {Key: "traefik/backends/backend.with.dot.too/servers/server.with.dot.without.url", Value: []byte("")},
{Key: "traefik/backends/backend.with.dot.too/servers/server.with.dot.without.url/weight", Value: []byte("0")}, {Key: "traefik/backends/backend.with.dot.too/servers/server.with.dot.without.url/weight", Value: []byte("1")},
{Key: "traefik/backends/backend.with.dot.too/servers/server.with.dot/url", Value: []byte("http://172.17.0.2:80")}, {Key: "traefik/backends/backend.with.dot.too/servers/server.with.dot/url", Value: []byte("http://172.17.0.2:80")},
{Key: "traefik/backends/backend.with.dot.too/servers/server.with.dot/weight", Value: []byte("0")}, {Key: "traefik/backends/backend.with.dot.too/servers/server.with.dot/weight", Value: []byte("1")},
{Key: "traefik/frontends/frontend.with.dot", Value: []byte("")}, {Key: "traefik/frontends/frontend.with.dot", Value: []byte("")},
{Key: "traefik/frontends/frontend.with.dot/backend", Value: []byte("backend.with.dot.too")}, {Key: "traefik/frontends/frontend.with.dot/backend", Value: []byte("backend.with.dot.too")},
{Key: "traefik/frontends/frontend.with.dot/errors", Value: []byte("")}, {Key: "traefik/frontends/frontend.with.dot/errors", Value: []byte("")},
@ -157,8 +157,8 @@ func TestFiller(t *testing.T) {
withLimit("bar", "3", "6", "9"))), withLimit("bar", "3", "6", "9"))),
backend("backend.with.dot.too", backend("backend.with.dot.too",
withPair("servers/server.with.dot/url", "http://172.17.0.2:80"), withPair("servers/server.with.dot/url", "http://172.17.0.2:80"),
withPair("servers/server.with.dot/weight", "0"), withPair("servers/server.with.dot/weight", "1"),
withPair("servers/server.with.dot.without.url/weight", "0")), withPair("servers/server.with.dot.without.url/weight", "1")),
) )
assert.EqualValues(t, expected, pairs1) assert.EqualValues(t, expected, pairs1)
@ -181,8 +181,8 @@ func TestFiller(t *testing.T) {
withPair("ratelimit/rateset/bar/period", "9")), withPair("ratelimit/rateset/bar/period", "9")),
entry("backends/backend.with.dot.too", entry("backends/backend.with.dot.too",
withPair("servers/server.with.dot/url", "http://172.17.0.2:80"), withPair("servers/server.with.dot/url", "http://172.17.0.2:80"),
withPair("servers/server.with.dot/weight", "0"), withPair("servers/server.with.dot/weight", "1"),
withPair("servers/server.with.dot.without.url/weight", "0")), withPair("servers/server.with.dot.without.url/weight", "1")),
) )
assert.EqualValues(t, expected, pairs2) assert.EqualValues(t, expected, pairs2)
} }

View file

@ -42,7 +42,7 @@ func (p *Provider) buildConfiguration() *types.Configuration {
// Frontend functions // Frontend functions
"getBackendName": p.getFuncString(pathFrontendBackend, ""), "getBackendName": p.getFuncString(pathFrontendBackend, ""),
"getPriority": p.getFuncInt(pathFrontendPriority, label.DefaultFrontendPriorityInt), "getPriority": p.getFuncInt(pathFrontendPriority, label.DefaultFrontendPriority),
"getPassHostHeader": p.getPassHostHeader(), "getPassHostHeader": p.getPassHostHeader(),
"getPassTLSCert": p.getFuncBool(pathFrontendPassTLSCert, label.DefaultPassTLSCert), "getPassTLSCert": p.getFuncBool(pathFrontendPassTLSCert, label.DefaultPassTLSCert),
"getEntryPoints": p.getFuncList(pathFrontendEntryPoints), "getEntryPoints": p.getFuncList(pathFrontendEntryPoints),
@ -89,12 +89,12 @@ func (p *Provider) getPassHostHeader() func(rootPath string) bool {
value, err := strconv.ParseBool(rawValue) value, err := strconv.ParseBool(rawValue)
if err != nil { if err != nil {
log.Errorf("Invalid value for %s %s: %s", rootPath, pathFrontendPassHostHeader, rawValue) log.Errorf("Invalid value for %s %s: %s", rootPath, pathFrontendPassHostHeader, rawValue)
return label.DefaultPassHostHeaderBool return label.DefaultPassHostHeader
} }
return value return value
} }
return p.getBool(label.DefaultPassHostHeaderBool, rootPath, pathFrontendPassHostHeaderDeprecated) return p.getBool(label.DefaultPassHostHeader, rootPath, pathFrontendPassHostHeaderDeprecated)
} }
} }
@ -402,7 +402,7 @@ func (p *Provider) getServers(rootPath string) map[string]types.Server {
serverName := p.last(serverKey) serverName := p.last(serverKey)
servers[serverName] = types.Server{ servers[serverName] = types.Server{
URL: serverURL, URL: serverURL,
Weight: p.getInt(0, serverKey, pathBackendServerWeight), Weight: p.getInt(label.DefaultWeight, serverKey, pathBackendServerWeight),
} }
} }

View file

@ -32,8 +32,8 @@ func TestProviderBuildConfiguration(t *testing.T) {
withPair("routes/route.with.dot/rule", "Host:test.localhost")), withPair("routes/route.with.dot/rule", "Host:test.localhost")),
backend("backend.with.dot.too", backend("backend.with.dot.too",
withPair("servers/server.with.dot/url", "http://172.17.0.2:80"), withPair("servers/server.with.dot/url", "http://172.17.0.2:80"),
withPair("servers/server.with.dot/weight", "0"), withPair("servers/server.with.dot/weight", strconv.Itoa(label.DefaultWeight)),
withPair("servers/server.with.dot.without.url/weight", "0")), withPair("servers/server.with.dot.without.url/weight", strconv.Itoa(label.DefaultWeight))),
), ),
expected: &types.Configuration{ expected: &types.Configuration{
Backends: map[string]*types.Backend{ Backends: map[string]*types.Backend{
@ -42,7 +42,7 @@ func TestProviderBuildConfiguration(t *testing.T) {
Servers: map[string]types.Server{ Servers: map[string]types.Server{
"server.with.dot": { "server.with.dot": {
URL: "http://172.17.0.2:80", URL: "http://172.17.0.2:80",
Weight: 0, Weight: label.DefaultWeight,
}, },
}, },
}, },
@ -82,8 +82,8 @@ func TestProviderBuildConfiguration(t *testing.T) {
withPair(pathBackendBufferingMemRequestBodyBytes, "2097152"), withPair(pathBackendBufferingMemRequestBodyBytes, "2097152"),
withPair(pathBackendBufferingRetryExpression, "IsNetworkError() && Attempts() <= 2"), withPair(pathBackendBufferingRetryExpression, "IsNetworkError() && Attempts() <= 2"),
withPair("servers/server1/url", "http://172.17.0.2:80"), withPair("servers/server1/url", "http://172.17.0.2:80"),
withPair("servers/server1/weight", "0"), withPair("servers/server1/weight", strconv.Itoa(label.DefaultWeight)),
withPair("servers/server2/weight", "0")), withPair("servers/server2/weight", strconv.Itoa(label.DefaultWeight))),
frontend("frontend1", frontend("frontend1",
withPair(pathFrontendBackend, "backend1"), withPair(pathFrontendBackend, "backend1"),
withPair(pathFrontendPriority, "6"), withPair(pathFrontendPriority, "6"),
@ -148,7 +148,7 @@ func TestProviderBuildConfiguration(t *testing.T) {
Servers: map[string]types.Server{ Servers: map[string]types.Server{
"server1": { "server1": {
URL: "http://172.17.0.2:80", URL: "http://172.17.0.2:80",
Weight: 0, Weight: label.DefaultWeight,
}, },
}, },
CircuitBreaker: &types.CircuitBreaker{ CircuitBreaker: &types.CircuitBreaker{
@ -2012,7 +2012,7 @@ func TestProviderGetServers(t *testing.T) {
expected: map[string]types.Server{ expected: map[string]types.Server{
"server1": { "server1": {
URL: "http://172.17.0.2:80", URL: "http://172.17.0.2:80",
Weight: 0, Weight: label.DefaultWeight,
}, },
}, },
}, },
@ -2027,7 +2027,7 @@ func TestProviderGetServers(t *testing.T) {
expected: map[string]types.Server{ expected: map[string]types.Server{
"server1": { "server1": {
URL: "http://172.17.0.2:80", URL: "http://172.17.0.2:80",
Weight: 0, Weight: label.DefaultWeight,
}, },
"server2": { "server2": {
URL: "http://172.17.0.3:80", URL: "http://172.17.0.3:80",

View file

@ -17,19 +17,21 @@ const (
// Default values // Default values
const ( const (
DefaultWeight = "0" // TODO [breaking] use int value DefaultWeight = 1
DefaultWeightInt = 0 // TODO rename to DefaultWeight
DefaultProtocol = "http" DefaultProtocol = "http"
DefaultPassHostHeader = "true" // TODO [breaking] use bool value DefaultPassHostHeader = true
DefaultPassHostHeaderBool = true // TODO rename to DefaultPassHostHeader
DefaultPassTLSCert = false DefaultPassTLSCert = false
DefaultFrontendPriority = "0" // TODO [breaking] int value DefaultFrontendPriority = 0
DefaultFrontendPriorityInt = 0 // TODO rename to DefaultFrontendPriority
DefaultCircuitBreakerExpression = "NetworkErrorRatio() > 1" DefaultCircuitBreakerExpression = "NetworkErrorRatio() > 1"
DefaultBackendLoadBalancerMethod = "wrr" DefaultBackendLoadBalancerMethod = "wrr"
DefaultBackendMaxconnExtractorFunc = "request.host" DefaultBackendMaxconnExtractorFunc = "request.host"
DefaultBackendLoadbalancerStickinessCookieName = "" DefaultBackendLoadbalancerStickinessCookieName = ""
DefaultBackendHealthCheckPort = 0 DefaultBackendHealthCheckPort = 0
// TODO need to be remove in extra-service-fabric
DefaultWeightInt = 1 // Deprecated
DefaultPassHostHeaderBool = true // Deprecated
DefaultFrontendPriorityInt = 0 // Deprecated
) )
var ( var (

View file

@ -602,17 +602,17 @@ func TestGetFuncString(t *testing.T) {
}{ }{
{ {
labels: nil, labels: nil,
labelName: TraefikWeight, labelName: TraefikProtocol,
defaultValue: DefaultWeight, defaultValue: DefaultProtocol,
expected: "0", expected: "http",
}, },
{ {
labels: map[string]string{ labels: map[string]string{
TraefikWeight: "10", TraefikProtocol: "https",
}, },
labelName: TraefikWeight, labelName: TraefikProtocol,
defaultValue: DefaultWeight, defaultValue: DefaultProtocol,
expected: "10", expected: "https",
}, },
} }

View file

@ -43,9 +43,9 @@ func (p *Provider) buildConfigurationV2(applications *marathon.Applications) *ty
"getSegmentNameSuffix": getSegmentNameSuffix, "getSegmentNameSuffix": getSegmentNameSuffix,
"getFrontendRule": p.getFrontendRule, "getFrontendRule": p.getFrontendRule,
"getFrontendName": p.getFrontendName, "getFrontendName": p.getFrontendName,
"getPassHostHeader": label.GetFuncBool(label.TraefikFrontendPassHostHeader, label.DefaultPassHostHeaderBool), "getPassHostHeader": label.GetFuncBool(label.TraefikFrontendPassHostHeader, label.DefaultPassHostHeader),
"getPassTLSCert": label.GetFuncBool(label.TraefikFrontendPassTLSCert, label.DefaultPassTLSCert), "getPassTLSCert": label.GetFuncBool(label.TraefikFrontendPassTLSCert, label.DefaultPassTLSCert),
"getPriority": label.GetFuncInt(label.TraefikFrontendPriority, label.DefaultFrontendPriorityInt), "getPriority": label.GetFuncInt(label.TraefikFrontendPriority, label.DefaultFrontendPriority),
"getEntryPoints": label.GetFuncSliceString(label.TraefikFrontendEntryPoints), "getEntryPoints": label.GetFuncSliceString(label.TraefikFrontendEntryPoints),
"getBasicAuth": label.GetFuncSliceString(label.TraefikFrontendAuthBasic), "getBasicAuth": label.GetFuncSliceString(label.TraefikFrontendAuthBasic),
"getRedirect": label.GetRedirect, "getRedirect": label.GetRedirect,
@ -339,7 +339,7 @@ func (p *Provider) getServer(app appData, task marathon.Task) (string, *types.Se
return serverName, &types.Server{ return serverName, &types.Server{
URL: fmt.Sprintf("%s://%s:%v", protocol, host, port), URL: fmt.Sprintf("%s://%s:%v", protocol, host, port),
Weight: label.GetIntValue(app.SegmentLabels, label.TraefikWeight, label.DefaultWeightInt), Weight: label.GetIntValue(app.SegmentLabels, label.TraefikWeight, label.DefaultWeight),
}, nil }, nil
} }

View file

@ -60,7 +60,7 @@ func TestBuildConfiguration(t *testing.T) {
Servers: map[string]types.Server{ Servers: map[string]types.Server{
"server-app-taskID": { "server-app-taskID": {
URL: "http://localhost:80", URL: "http://localhost:80",
Weight: 0, Weight: label.DefaultWeight,
}, },
}, },
CircuitBreaker: nil, CircuitBreaker: nil,
@ -119,7 +119,7 @@ func TestBuildConfiguration(t *testing.T) {
Servers: map[string]types.Server{ Servers: map[string]types.Server{
"server-app-taskID": { "server-app-taskID": {
URL: "http://localhost:80", URL: "http://localhost:80",
Weight: 0, Weight: label.DefaultWeight,
}, },
}, },
MaxConn: nil, MaxConn: nil,
@ -152,7 +152,7 @@ func TestBuildConfiguration(t *testing.T) {
Servers: map[string]types.Server{ Servers: map[string]types.Server{
"server-app-taskID": { "server-app-taskID": {
URL: "http://localhost:80", URL: "http://localhost:80",
Weight: 0, Weight: label.DefaultWeight,
}, },
}, },
}, },
@ -420,11 +420,11 @@ func TestBuildConfiguration(t *testing.T) {
Servers: map[string]types.Server{ Servers: map[string]types.Server{
"server-foo-v000-taskID-service-main": { "server-foo-v000-taskID-service-main": {
URL: "http://localhost:8080", URL: "http://localhost:8080",
Weight: 0, Weight: label.DefaultWeight,
}, },
"server-foo-v001-taskID-service-main": { "server-foo-v001-taskID-service-main": {
URL: "http://localhost:8081", URL: "http://localhost:8081",
Weight: 0, Weight: label.DefaultWeight,
}, },
}, },
}, },
@ -503,7 +503,7 @@ func TestBuildConfigurationSegments(t *testing.T) {
Servers: map[string]types.Server{ Servers: map[string]types.Server{
"server-app-taskID-service-web": { "server-app-taskID-service-web": {
URL: "http://localhost:80", URL: "http://localhost:80",
Weight: 0, Weight: label.DefaultWeight,
}, },
}, },
MaxConn: &types.MaxConn{ MaxConn: &types.MaxConn{
@ -515,7 +515,7 @@ func TestBuildConfigurationSegments(t *testing.T) {
Servers: map[string]types.Server{ Servers: map[string]types.Server{
"server-app-taskID-service-admin": { "server-app-taskID-service-admin": {
URL: "http://localhost:81", URL: "http://localhost:81",
Weight: 0, Weight: label.DefaultWeight,
}, },
}, },
MaxConn: &types.MaxConn{ MaxConn: &types.MaxConn{
@ -1278,15 +1278,15 @@ func TestGetServers(t *testing.T) {
expected: map[string]types.Server{ expected: map[string]types.Server{
"server-A": { "server-A": {
URL: "http://1.1.1.1:80", URL: "http://1.1.1.1:80",
Weight: 0, Weight: label.DefaultWeight,
}, },
"server-B": { "server-B": {
URL: "http://1.1.1.2:80", URL: "http://1.1.1.2:80",
Weight: 0, Weight: label.DefaultWeight,
}, },
"server-C": { "server-C": {
URL: "http://1.1.1.3:80", URL: "http://1.1.1.3:80",
Weight: 0, Weight: label.DefaultWeight,
}, },
}, },
}, },

View file

@ -27,7 +27,7 @@ func (p *Provider) buildConfigurationV1(applications *marathon.Applications) *ty
"getPort": getPortV1, "getPort": getPortV1,
"getServers": p.getServersV1, "getServers": p.getServersV1,
"getWeight": getFuncIntServiceV1(label.SuffixWeight, label.DefaultWeightInt), "getWeight": getFuncIntServiceV1(label.SuffixWeight, label.DefaultWeight),
"getProtocol": getFuncStringServiceV1(label.SuffixProtocol, label.DefaultProtocol), "getProtocol": getFuncStringServiceV1(label.SuffixProtocol, label.DefaultProtocol),
"hasCircuitBreakerLabels": hasFuncV1(label.TraefikBackendCircuitBreakerExpression), "hasCircuitBreakerLabels": hasFuncV1(label.TraefikBackendCircuitBreakerExpression),
"getCircuitBreakerExpression": getFuncStringV1(label.TraefikBackendCircuitBreakerExpression, label.DefaultCircuitBreakerExpression), "getCircuitBreakerExpression": getFuncStringV1(label.TraefikBackendCircuitBreakerExpression, label.DefaultCircuitBreakerExpression),
@ -46,9 +46,9 @@ func (p *Provider) buildConfigurationV1(applications *marathon.Applications) *ty
// Frontend functions // Frontend functions
"getServiceNames": getServiceNamesV1, "getServiceNames": getServiceNamesV1,
"getServiceNameSuffix": getSegmentNameSuffix, "getServiceNameSuffix": getSegmentNameSuffix,
"getPassHostHeader": getFuncBoolServiceV1(label.SuffixFrontendPassHostHeader, label.DefaultPassHostHeaderBool), "getPassHostHeader": getFuncBoolServiceV1(label.SuffixFrontendPassHostHeader, label.DefaultPassHostHeader),
"getPassTLSCert": getFuncBoolServiceV1(label.SuffixFrontendPassTLSCert, label.DefaultPassTLSCert), "getPassTLSCert": getFuncBoolServiceV1(label.SuffixFrontendPassTLSCert, label.DefaultPassTLSCert),
"getPriority": getFuncIntServiceV1(label.SuffixFrontendPriority, label.DefaultFrontendPriorityInt), "getPriority": getFuncIntServiceV1(label.SuffixFrontendPriority, label.DefaultFrontendPriority),
"getEntryPoints": getFuncSliceStringServiceV1(label.SuffixFrontendEntryPoints), "getEntryPoints": getFuncSliceStringServiceV1(label.SuffixFrontendEntryPoints),
"getFrontendRule": p.getFrontendRuleV1, "getFrontendRule": p.getFrontendRuleV1,
"getFrontendName": p.getFrontendNameV1, "getFrontendName": p.getFrontendNameV1,
@ -323,7 +323,7 @@ func (p *Provider) getServersV1(application marathon.Application, serviceName st
serverName := provider.Normalize("server-" + task.ID + getSegmentNameSuffix(serviceName)) serverName := provider.Normalize("server-" + task.ID + getSegmentNameSuffix(serviceName))
servers[serverName] = types.Server{ servers[serverName] = types.Server{
URL: fmt.Sprintf("%s://%s:%v", protocol, host, port), URL: fmt.Sprintf("%s://%s:%v", protocol, host, port),
Weight: label.GetIntValue(labels, getLabelNameV1(serviceName, label.SuffixWeight), label.DefaultWeightInt), Weight: label.GetIntValue(labels, getLabelNameV1(serviceName, label.SuffixWeight), label.DefaultWeight),
} }
} }

View file

@ -56,7 +56,7 @@ func TestBuildConfigurationV1(t *testing.T) {
Servers: map[string]types.Server{ Servers: map[string]types.Server{
"server-task": { "server-task": {
URL: "http://localhost:80", URL: "http://localhost:80",
Weight: 0, Weight: label.DefaultWeight,
}, },
}, },
CircuitBreaker: nil, CircuitBreaker: nil,
@ -112,7 +112,7 @@ func TestBuildConfigurationV1(t *testing.T) {
Servers: map[string]types.Server{ Servers: map[string]types.Server{
"server-task": { "server-task": {
URL: "http://localhost:80", URL: "http://localhost:80",
Weight: 0, Weight: label.DefaultWeight,
}, },
}, },
MaxConn: nil, MaxConn: nil,
@ -143,7 +143,7 @@ func TestBuildConfigurationV1(t *testing.T) {
Servers: map[string]types.Server{ Servers: map[string]types.Server{
"server-task": { "server-task": {
URL: "http://localhost:80", URL: "http://localhost:80",
Weight: 0, Weight: label.DefaultWeight,
}, },
}, },
}, },
@ -306,7 +306,7 @@ func TestBuildConfigurationServicesV1(t *testing.T) {
Servers: map[string]types.Server{ Servers: map[string]types.Server{
"server-task-service-web": { "server-task-service-web": {
URL: "http://localhost:80", URL: "http://localhost:80",
Weight: 0, Weight: label.DefaultWeight,
}, },
}, },
MaxConn: &types.MaxConn{ MaxConn: &types.MaxConn{
@ -318,7 +318,7 @@ func TestBuildConfigurationServicesV1(t *testing.T) {
Servers: map[string]types.Server{ Servers: map[string]types.Server{
"server-task-service-admin": { "server-task-service-admin": {
URL: "http://localhost:81", URL: "http://localhost:81",
Weight: 0, Weight: label.DefaultWeight,
}, },
}, },
MaxConn: &types.MaxConn{ MaxConn: &types.MaxConn{

View file

@ -39,8 +39,8 @@ func (p *Provider) buildConfigurationV2(tasks []state.Task) *types.Configuration
"getFrontEndName": getFrontendName, "getFrontEndName": getFrontendName,
"getEntryPoints": label.GetFuncSliceString(label.TraefikFrontendEntryPoints), "getEntryPoints": label.GetFuncSliceString(label.TraefikFrontendEntryPoints),
"getBasicAuth": label.GetFuncSliceString(label.TraefikFrontendAuthBasic), "getBasicAuth": label.GetFuncSliceString(label.TraefikFrontendAuthBasic),
"getPriority": label.GetFuncInt(label.TraefikFrontendPriority, label.DefaultFrontendPriorityInt), "getPriority": label.GetFuncInt(label.TraefikFrontendPriority, label.DefaultFrontendPriority),
"getPassHostHeader": label.GetFuncBool(label.TraefikFrontendPassHostHeader, label.DefaultPassHostHeaderBool), "getPassHostHeader": label.GetFuncBool(label.TraefikFrontendPassHostHeader, label.DefaultPassHostHeader),
"getPassTLSCert": label.GetFuncBool(label.TraefikFrontendPassTLSCert, label.DefaultPassTLSCert), "getPassTLSCert": label.GetFuncBool(label.TraefikFrontendPassTLSCert, label.DefaultPassTLSCert),
"getFrontendRule": p.getFrontendRule, "getFrontendRule": p.getFrontendRule,
"getRedirect": label.GetRedirect, "getRedirect": label.GetRedirect,
@ -184,7 +184,7 @@ func (p *Provider) getServers(tasks []taskData) map[string]types.Server {
serverName := "server-" + getID(task) serverName := "server-" + getID(task)
servers[serverName] = types.Server{ servers[serverName] = types.Server{
URL: fmt.Sprintf("%s://%s:%s", protocol, host, port), URL: fmt.Sprintf("%s://%s:%s", protocol, host, port),
Weight: getIntValue(task.TraefikLabels, label.TraefikWeight, label.DefaultWeightInt, math.MaxInt32), Weight: getIntValue(task.TraefikLabels, label.TraefikWeight, label.DefaultWeight, math.MaxInt32),
} }
} }

View file

@ -90,11 +90,11 @@ func TestBuildConfiguration(t *testing.T) {
Servers: map[string]types.Server{ Servers: map[string]types.Server{
"server-ID1": { "server-ID1": {
URL: "http://10.10.10.10:80", URL: "http://10.10.10.10:80",
Weight: 0, Weight: label.DefaultWeight,
}, },
"server-ID2": { "server-ID2": {
URL: "http://10.10.10.11:81", URL: "http://10.10.10.11:81",
Weight: 0, Weight: label.DefaultWeight,
}, },
}, },
}, },
@ -102,11 +102,11 @@ func TestBuildConfiguration(t *testing.T) {
Servers: map[string]types.Server{ Servers: map[string]types.Server{
"server-ID3": { "server-ID3": {
URL: "http://20.10.10.10:80", URL: "http://20.10.10.10:80",
Weight: 0, Weight: label.DefaultWeight,
}, },
"server-ID4": { "server-ID4": {
URL: "http://20.10.10.11:81", URL: "http://20.10.10.11:81",
Weight: 0, Weight: label.DefaultWeight,
}, },
}, },
}, },
@ -617,7 +617,7 @@ func TestGetServers(t *testing.T) {
expected: map[string]types.Server{ expected: map[string]types.Server{
"server-ID1": { "server-ID1": {
URL: "http://10.10.10.10:80", URL: "http://10.10.10.10:80",
Weight: 0, Weight: label.DefaultWeight,
}, },
"server-ID2": { "server-ID2": {
URL: "http://10.10.10.11:81", URL: "http://10.10.10.11:81",

View file

@ -24,7 +24,7 @@ func (p *Provider) buildConfigurationV1(tasks []state.Task) *types.Configuration
"getBackendName": getBackendNameV1, "getBackendName": getBackendNameV1,
"getHost": p.getHostV1, "getHost": p.getHostV1,
"getProtocol": getFuncApplicationStringValueV1(label.TraefikProtocol, label.DefaultProtocol), "getProtocol": getFuncApplicationStringValueV1(label.TraefikProtocol, label.DefaultProtocol),
"getWeight": getFuncApplicationIntValueV1(label.TraefikWeight, label.DefaultWeightInt), "getWeight": getFuncApplicationIntValueV1(label.TraefikWeight, label.DefaultWeight),
"getBackend": getBackendV1, "getBackend": getBackendV1,
"getPort": p.getPort, "getPort": p.getPort,
@ -33,8 +33,8 @@ func (p *Provider) buildConfigurationV1(tasks []state.Task) *types.Configuration
"getFrontEndName": getFrontendNameV1, "getFrontEndName": getFrontendNameV1,
"getEntryPoints": getFuncSliceStringValueV1(label.TraefikFrontendEntryPoints), "getEntryPoints": getFuncSliceStringValueV1(label.TraefikFrontendEntryPoints),
"getBasicAuth": getFuncSliceStringValueV1(label.TraefikFrontendAuthBasic), "getBasicAuth": getFuncSliceStringValueV1(label.TraefikFrontendAuthBasic),
"getPriority": getFuncIntValueV1(label.TraefikFrontendPriority, label.DefaultFrontendPriorityInt), "getPriority": getFuncIntValueV1(label.TraefikFrontendPriority, label.DefaultFrontendPriority),
"getPassHostHeader": getFuncBoolValueV1(label.TraefikFrontendPassHostHeader, label.DefaultPassHostHeaderBool), "getPassHostHeader": getFuncBoolValueV1(label.TraefikFrontendPassHostHeader, label.DefaultPassHostHeader),
"getFrontendRule": p.getFrontendRuleV1, "getFrontendRule": p.getFrontendRuleV1,
} }

View file

@ -86,11 +86,11 @@ func TestBuildConfigurationV1(t *testing.T) {
Servers: map[string]types.Server{ Servers: map[string]types.Server{
"server-ID1": { "server-ID1": {
URL: "http://10.10.10.10:80", URL: "http://10.10.10.10:80",
Weight: 0, Weight: label.DefaultWeight,
}, },
"server-ID2": { "server-ID2": {
URL: "http://10.10.10.11:81", URL: "http://10.10.10.11:81",
Weight: 0, Weight: label.DefaultWeight,
}, },
}, },
}, },
@ -98,11 +98,11 @@ func TestBuildConfigurationV1(t *testing.T) {
Servers: map[string]types.Server{ Servers: map[string]types.Server{
"server-ID3": { "server-ID3": {
URL: "http://20.10.10.10:80", URL: "http://20.10.10.10:80",
Weight: 0, Weight: label.DefaultWeight,
}, },
"server-ID4": { "server-ID4": {
URL: "http://20.10.10.11:81", URL: "http://20.10.10.11:81",
Weight: 0, Weight: label.DefaultWeight,
}, },
}, },
}, },

View file

@ -29,8 +29,8 @@ func (p *Provider) buildConfigurationV2(services []rancherData) *types.Configura
// Frontend functions // Frontend functions
"getBackendName": getBackendName, "getBackendName": getBackendName,
"getFrontendRule": p.getFrontendRule, "getFrontendRule": p.getFrontendRule,
"getPriority": label.GetFuncInt(label.TraefikFrontendPriority, label.DefaultFrontendPriorityInt), "getPriority": label.GetFuncInt(label.TraefikFrontendPriority, label.DefaultFrontendPriority),
"getPassHostHeader": label.GetFuncBool(label.TraefikFrontendPassHostHeader, label.DefaultPassHostHeaderBool), "getPassHostHeader": label.GetFuncBool(label.TraefikFrontendPassHostHeader, label.DefaultPassHostHeader),
"getPassTLSCert": label.GetFuncBool(label.TraefikFrontendPassTLSCert, label.DefaultPassTLSCert), "getPassTLSCert": label.GetFuncBool(label.TraefikFrontendPassTLSCert, label.DefaultPassTLSCert),
"getEntryPoints": label.GetFuncSliceString(label.TraefikFrontendEntryPoints), "getEntryPoints": label.GetFuncSliceString(label.TraefikFrontendEntryPoints),
"getBasicAuth": label.GetFuncSliceString(label.TraefikFrontendAuthBasic), "getBasicAuth": label.GetFuncSliceString(label.TraefikFrontendAuthBasic),
@ -170,7 +170,7 @@ func getServers(service rancherData) map[string]types.Server {
protocol := label.GetStringValue(service.SegmentLabels, label.TraefikProtocol, label.DefaultProtocol) protocol := label.GetStringValue(service.SegmentLabels, label.TraefikProtocol, label.DefaultProtocol)
port := label.GetStringValue(service.SegmentLabels, label.TraefikPort, "") port := label.GetStringValue(service.SegmentLabels, label.TraefikPort, "")
weight := label.GetIntValue(service.SegmentLabels, label.TraefikWeight, label.DefaultWeightInt) weight := label.GetIntValue(service.SegmentLabels, label.TraefikWeight, label.DefaultWeight)
serverName := "server-" + strconv.Itoa(index) serverName := "server-" + strconv.Itoa(index)
servers[serverName] = types.Server{ servers[serverName] = types.Server{

View file

@ -454,7 +454,7 @@ func TestProviderBuildConfiguration(t *testing.T) {
Servers: map[string]types.Server{ Servers: map[string]types.Server{
"server-0": { "server-0": {
URL: "http://127.0.0.1:80", URL: "http://127.0.0.1:80",
Weight: 0, Weight: label.DefaultWeight,
}, },
}, },
CircuitBreaker: nil, CircuitBreaker: nil,
@ -855,7 +855,7 @@ func TestGetServers(t *testing.T) {
expected: map[string]types.Server{ expected: map[string]types.Server{
"server-0": { "server-0": {
URL: "http://10.10.10.0:", URL: "http://10.10.10.0:",
Weight: 0, Weight: label.DefaultWeight,
}, },
}, },
}, },

View file

@ -18,7 +18,7 @@ func (p *Provider) buildConfigurationV1(services []rancherData) *types.Configura
// Backend functions // Backend functions
"getPort": getFuncStringV1(label.TraefikPort, ""), "getPort": getFuncStringV1(label.TraefikPort, ""),
"getProtocol": getFuncStringV1(label.TraefikProtocol, label.DefaultProtocol), "getProtocol": getFuncStringV1(label.TraefikProtocol, label.DefaultProtocol),
"getWeight": getFuncIntV1(label.TraefikWeight, label.DefaultWeightInt), "getWeight": getFuncIntV1(label.TraefikWeight, label.DefaultWeight),
"hasCircuitBreakerLabel": hasFuncV1(label.TraefikBackendCircuitBreakerExpression), "hasCircuitBreakerLabel": hasFuncV1(label.TraefikBackendCircuitBreakerExpression),
"getCircuitBreakerExpression": getFuncStringV1(label.TraefikBackendCircuitBreakerExpression, label.DefaultCircuitBreakerExpression), "getCircuitBreakerExpression": getFuncStringV1(label.TraefikBackendCircuitBreakerExpression, label.DefaultCircuitBreakerExpression),
"hasLoadBalancerLabel": hasLoadBalancerLabel, "hasLoadBalancerLabel": hasLoadBalancerLabel,
@ -33,8 +33,8 @@ func (p *Provider) buildConfigurationV1(services []rancherData) *types.Configura
// Frontend functions // Frontend functions
"getBackend": getBackendNameV1, "getBackend": getBackendNameV1,
"getFrontendRule": p.getFrontendRuleV1, "getFrontendRule": p.getFrontendRuleV1,
"getPriority": getFuncIntV1(label.TraefikFrontendPriority, label.DefaultFrontendPriorityInt), "getPriority": getFuncIntV1(label.TraefikFrontendPriority, label.DefaultFrontendPriority),
"getPassHostHeader": getFuncBoolV1(label.TraefikFrontendPassHostHeader, label.DefaultPassHostHeaderBool), "getPassHostHeader": getFuncBoolV1(label.TraefikFrontendPassHostHeader, label.DefaultPassHostHeader),
"getEntryPoints": getFuncSliceStringV1(label.TraefikFrontendEntryPoints), "getEntryPoints": getFuncSliceStringV1(label.TraefikFrontendEntryPoints),
"getBasicAuth": getFuncSliceStringV1(label.TraefikFrontendAuthBasic), "getBasicAuth": getFuncSliceStringV1(label.TraefikFrontendAuthBasic),
"hasRedirect": hasRedirect, "hasRedirect": hasRedirect,

View file

@ -149,7 +149,7 @@ func TestProviderBuildConfigurationV1(t *testing.T) {
Servers: map[string]types.Server{ Servers: map[string]types.Server{
"server-0": { "server-0": {
URL: "http://127.0.0.1:80", URL: "http://127.0.0.1:80",
Weight: 0, Weight: label.DefaultWeight,
}, },
}, },
CircuitBreaker: nil, CircuitBreaker: nil,

View file

@ -55,9 +55,7 @@ import (
"golang.org/x/net/http2" "golang.org/x/net/http2"
) )
var ( var httpServerLogger = stdlog.New(log.WriterLevel(logrus.DebugLevel), "", 0)
httpServerLogger = stdlog.New(log.WriterLevel(logrus.DebugLevel), "", 0)
)
// Server is the reverse-proxy/load-balancer engine // Server is the reverse-proxy/load-balancer engine
type Server struct { type Server struct {

View file

@ -16,6 +16,7 @@ import (
"github.com/containous/traefik/healthcheck" "github.com/containous/traefik/healthcheck"
"github.com/containous/traefik/metrics" "github.com/containous/traefik/metrics"
"github.com/containous/traefik/middlewares" "github.com/containous/traefik/middlewares"
"github.com/containous/traefik/provider/label"
"github.com/containous/traefik/rules" "github.com/containous/traefik/rules"
"github.com/containous/traefik/testhelpers" "github.com/containous/traefik/testhelpers"
"github.com/containous/traefik/tls" "github.com/containous/traefik/tls"
@ -1220,7 +1221,7 @@ func buildBackend(backendBuilders ...func(*types.Backend)) *types.Backend {
func withServer(name, url string) func(backend *types.Backend) { func withServer(name, url string) func(backend *types.Backend) {
return func(be *types.Backend) { return func(be *types.Backend) {
be.Servers[name] = types.Server{URL: url} be.Servers[name] = types.Server{URL: url, Weight: label.DefaultWeight}
} }
} }

View file

@ -38,7 +38,7 @@ func (p *Provider) buildConfiguration(sfClient sfClient) (*types.Configuration,
"filterServicesByLabelValue": filterServicesByLabelValue, // FIXME unused "filterServicesByLabelValue": filterServicesByLabelValue, // FIXME unused
// Backend functions // Backend functions
"getWeight": getFuncServiceStringLabel(label.TraefikWeight, label.DefaultWeight), "getWeight": getFuncServiceIntLabel(label.TraefikWeight, label.DefaultWeightInt),
"getProtocol": getFuncServiceStringLabel(label.TraefikProtocol, label.DefaultProtocol), "getProtocol": getFuncServiceStringLabel(label.TraefikProtocol, label.DefaultProtocol),
"getMaxConn": getMaxConn, "getMaxConn": getMaxConn,
"getHealthCheck": getHealthCheck, "getHealthCheck": getHealthCheck,
@ -46,8 +46,8 @@ func (p *Provider) buildConfiguration(sfClient sfClient) (*types.Configuration,
"getLoadBalancer": getLoadBalancer, "getLoadBalancer": getLoadBalancer,
// Frontend Functions // Frontend Functions
"getPriority": getFuncServiceStringLabel(label.TraefikFrontendPriority, label.DefaultFrontendPriority), "getPriority": getFuncServiceIntLabel(label.TraefikFrontendPriority, label.DefaultFrontendPriorityInt),
"getPassHostHeader": getFuncServiceStringLabel(label.TraefikFrontendPassHostHeader, label.DefaultPassHostHeader), "getPassHostHeader": getFuncServiceBoolLabel(label.TraefikFrontendPassHostHeader, label.DefaultPassHostHeaderBool),
"getPassTLSCert": getFuncBoolLabel(label.TraefikFrontendPassTLSCert, false), "getPassTLSCert": getFuncBoolLabel(label.TraefikFrontendPassTLSCert, false),
"getEntryPoints": getFuncServiceSliceStringLabel(label.TraefikFrontendEntryPoints), "getEntryPoints": getFuncServiceSliceStringLabel(label.TraefikFrontendEntryPoints),
"getBasicAuth": getFuncServiceSliceStringLabel(label.TraefikFrontendAuthBasic), "getBasicAuth": getFuncServiceSliceStringLabel(label.TraefikFrontendAuthBasic),

View file

@ -30,6 +30,18 @@ func getFuncServiceStringLabel(labelName string, defaultValue string) func(servi
} }
} }
func getFuncServiceIntLabel(labelName string, defaultValue int) func(service ServiceItemExtended) int {
return func(service ServiceItemExtended) int {
return label.GetIntValue(service.Labels, labelName, defaultValue)
}
}
func getFuncServiceBoolLabel(labelName string, defaultValue bool) func(service ServiceItemExtended) bool {
return func(service ServiceItemExtended) bool {
return label.GetBoolValue(service.Labels, labelName, defaultValue)
}
}
func getFuncServiceSliceStringLabel(labelName string) func(service ServiceItemExtended) []string { func getFuncServiceSliceStringLabel(labelName string) func(service ServiceItemExtended) []string {
return func(service ServiceItemExtended) []string { return func(service ServiceItemExtended) []string {
return label.GetSliceStringValue(service.Labels, labelName) return label.GetSliceStringValue(service.Labels, labelName)