Add passHostHeader and responseForwarding in IngressRoute

Co-authored-by: Mathieu Lonjaret <mathieu.lonjaret@gmail.com>
This commit is contained in:
Julien Salleyron 2019-09-13 16:46:04 +02:00 committed by Traefiker Bot
parent 7fa3537015
commit 401b3afa3b
7 changed files with 106 additions and 20 deletions

View file

@ -226,6 +226,13 @@ spec:
port: 80 port: 80
# (default 1) A weight used by the weighted round-robin strategy (WRR). # (default 1) A weight used by the weighted round-robin strategy (WRR).
weight: 1 weight: 1
# (default true) PassHostHeader controls whether to leave the request's Host
# Header as it was before it reached the proxy, or whether to let the proxy set it
# to the destination (backend) host.
passHostHeader: true
responseForwarding:
# (default 100ms) Interval between flushes of the buffered response body to the client.
flushInterval: 100ms
--- ---
apiVersion: traefik.containo.us/v1alpha1 apiVersion: traefik.containo.us/v1alpha1

View file

@ -127,15 +127,16 @@ func TestRateLimit(t *testing.T) {
incomingLoad: 200, incomingLoad: 200,
burst: 300, burst: 300,
}, },
{ // TODO Try to disambiguate when it fails if it is because of too high a load.
desc: "Zero average ==> no rate limiting", // {
config: dynamic.RateLimit{ // desc: "Zero average ==> no rate limiting",
Average: 0, // config: dynamic.RateLimit{
Burst: 1, // Average: 0,
}, // Burst: 1,
incomingLoad: 1000, // },
loadDuration: time.Second, // incomingLoad: 1000,
}, // loadDuration: time.Second,
// },
} }
for _, test := range testCases { for _, test := range testCases {

View file

@ -0,0 +1,20 @@
apiVersion: traefik.containo.us/v1alpha1
kind: IngressRoute
metadata:
name: test.route
namespace: default
spec:
entryPoints:
- foo
routes:
- match: Host(`foo.com`) && PathPrefix(`/bar`)
kind: Rule
priority: 12
services:
- name: whoami
port: 80
passHostHeader: false
responseForwarding:
flushInterval: 10s

View file

@ -157,12 +157,18 @@ func createLoadBalancerServerHTTP(client Client, namespace string, service v1alp
return nil, err return nil, err
} }
// TODO: support other strategies.
lb := &dynamic.ServersLoadBalancer{}
lb.SetDefaults()
lb.Servers = servers
if service.PassHostHeader != nil {
lb.PassHostHeader = *service.PassHostHeader
}
lb.ResponseForwarding = service.ResponseForwarding
return &dynamic.Service{ return &dynamic.Service{
LoadBalancer: &dynamic.ServersLoadBalancer{ LoadBalancer: lb,
Servers: servers,
// TODO: support other strategies.
PassHostHeader: true,
},
}, nil }, nil
} }

View file

@ -1536,6 +1536,44 @@ func TestLoadIngressRoutes(t *testing.T) {
}, },
}, },
}, },
{
desc: "Simple Ingress Route, with options",
paths: []string{"services.yml", "with_options.yml"},
expected: &dynamic.Configuration{
TCP: &dynamic.TCPConfiguration{
Routers: map[string]*dynamic.TCPRouter{},
Services: map[string]*dynamic.TCPService{},
},
HTTP: &dynamic.HTTPConfiguration{
Routers: map[string]*dynamic.Router{
"default/test.route-6b204d94623b3df4370c": {
EntryPoints: []string{"foo"},
Service: "default/test.route-6b204d94623b3df4370c",
Rule: "Host(`foo.com`) && PathPrefix(`/bar`)",
Priority: 12,
},
},
Middlewares: map[string]*dynamic.Middleware{},
Services: map[string]*dynamic.Service{
"default/test.route-6b204d94623b3df4370c": {
LoadBalancer: &dynamic.ServersLoadBalancer{
Servers: []dynamic.Server{
{
URL: "http://10.10.0.1:80",
},
{
URL: "http://10.10.0.2:80",
},
},
PassHostHeader: false,
ResponseForwarding: &dynamic.ResponseForwarding{FlushInterval: "10s"},
},
},
},
},
TLS: &dynamic.TLSConfiguration{},
},
},
{ {
desc: "port selected by name (TODO)", desc: "port selected by name (TODO)",
}, },
@ -1543,6 +1581,7 @@ func TestLoadIngressRoutes(t *testing.T) {
for _, test := range testCases { for _, test := range testCases {
test := test test := test
t.Run(test.desc, func(t *testing.T) { t.Run(test.desc, func(t *testing.T) {
t.Parallel() t.Parallel()

View file

@ -1,6 +1,7 @@
package v1alpha1 package v1alpha1
import ( import (
"github.com/containous/traefik/v2/pkg/config/dynamic"
"github.com/containous/traefik/v2/pkg/types" "github.com/containous/traefik/v2/pkg/types"
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
) )
@ -46,12 +47,14 @@ type TLSOptionRef struct {
// Service defines an upstream to proxy traffic. // Service defines an upstream to proxy traffic.
type Service struct { type Service struct {
Name string `json:"name"` Name string `json:"name"`
Port int32 `json:"port"` Port int32 `json:"port"`
Scheme string `json:"scheme,omitempty"` Scheme string `json:"scheme,omitempty"`
HealthCheck *HealthCheck `json:"healthCheck,omitempty"` HealthCheck *HealthCheck `json:"healthCheck,omitempty"`
Strategy string `json:"strategy,omitempty"` Strategy string `json:"strategy,omitempty"`
Weight *int `json:"weight,omitempty"` PassHostHeader *bool `json:"passHostHeader,omitempty"`
ResponseForwarding *dynamic.ResponseForwarding `json:"responseForwarding,omitempty"`
Weight *int `json:"weight,omitempty"`
} }
// MiddlewareRef is a ref to the Middleware resources. // MiddlewareRef is a ref to the Middleware resources.

View file

@ -635,6 +635,16 @@ func (in *Service) DeepCopyInto(out *Service) {
*out = new(HealthCheck) *out = new(HealthCheck)
(*in).DeepCopyInto(*out) (*in).DeepCopyInto(*out)
} }
if in.PassHostHeader != nil {
in, out := &in.PassHostHeader, &out.PassHostHeader
*out = new(bool)
**out = **in
}
if in.ResponseForwarding != nil {
in, out := &in.ResponseForwarding, &out.ResponseForwarding
*out = new(dynamic.ResponseForwarding)
**out = **in
}
if in.Weight != nil { if in.Weight != nil {
in, out := &in.Weight, &out.Weight in, out := &in.Weight, &out.Weight
*out = new(int) *out = new(int)