73 lines
2.3 KiB
Cheetah
73 lines
2.3 KiB
Cheetah
[backends]
|
|
{{range $service := .Services}}
|
|
{{$sname := $service.ServiceName}}
|
|
|
|
{{ $circuitBreaker := getCircuitBreaker $service.Attributes }}
|
|
{{if $circuitBreaker }}
|
|
[backends."backend-{{ $sname }}".circuitBreaker]
|
|
expression = "{{ $circuitBreaker.Expression }}"
|
|
{{end}}
|
|
|
|
{{ $loadBalancer := getLoadBalancer $service.Attributes }}
|
|
{{if $loadBalancer }}
|
|
[backends."backend-{{ $sname }}".loadBalancer]
|
|
method = "{{ $loadBalancer.Method }}"
|
|
sticky = {{ $loadBalancer.Sticky }}
|
|
{{if $loadBalancer.Stickiness }}
|
|
[backends."backend-{{ $sname }}".loadBalancer.stickiness]
|
|
cookieName = "{{ $loadBalancer.Stickiness.CookieName }}"
|
|
{{end}}
|
|
{{end}}
|
|
|
|
{{ $maxConn := getMaxConn $service.Attributes }}
|
|
{{if $maxConn }}
|
|
[backends."backend-{{ $sname }}".maxConn]
|
|
extractorFunc = "{{ $maxConn.ExtractorFunc }}"
|
|
amount = {{ $maxConn.Amount }}
|
|
{{end}}
|
|
|
|
{{ $healthCheck := getHealthCheck $service.Attributes }}
|
|
{{if $healthCheck }}
|
|
[backends.backend-{{ $sname }}.healthCheck]
|
|
path = "{{ $healthCheck.Path }}"
|
|
port = {{ $healthCheck.Port }}
|
|
interval = "{{ $healthCheck.Interval }}"
|
|
{{end}}
|
|
|
|
{{end}}
|
|
{{range $index, $node := .Nodes}}
|
|
|
|
[backends."backend-{{ getBackend $node }}".servers."{{ getServerName $node $index }}"]
|
|
url = "{{ getProtocol $node.Service.Tags }}://{{ getBackendAddress $node }}:{{ $node.Service.Port }}"
|
|
weight = {{ getWeight $node.Service.Tags }}
|
|
|
|
{{end}}
|
|
|
|
[frontends]
|
|
{{range $service := .Services}}
|
|
|
|
[frontends."frontend-{{ $service.ServiceName }}"]
|
|
backend = "backend-{{ $service.ServiceName }}"
|
|
priority = {{ getPriority $service.Attributes }}
|
|
passHostHeader = {{ getPassHostHeader $service.Attributes }}
|
|
passTLSCert = {{ getPassTLSCert $service.Attributes }}
|
|
|
|
entryPoints = [{{range getFrontEndEntryPoints $service.Attributes }}
|
|
"{{.}}",
|
|
{{end}}]
|
|
|
|
{{ $whitelistSourceRange := getWhitelistSourceRange $service.Attributes }}
|
|
{{if $whitelistSourceRange }}
|
|
whitelistSourceRange = [{{range $whitelistSourceRange}}
|
|
"{{.}}",
|
|
{{end}}]
|
|
{{end}}
|
|
|
|
basicAuth = [{{range getBasicAuth $service.Attributes }}
|
|
"{{.}}",
|
|
{{end}}]
|
|
|
|
[frontends."frontend-{{$service.ServiceName}}".routes."route-host-{{$service.ServiceName}}"]
|
|
rule = "{{ getFrontendRule $service }}"
|
|
|
|
{{end}}
|