Skip to content

Commit 633194a

Browse files
wondersdDonald Wonders
authored andcommitted
load balancer class support
Signed-off-by: Don Wonders <[email protected]>
1 parent 3999cdd commit 633194a

File tree

8 files changed

+50
-10
lines changed

8 files changed

+50
-10
lines changed

api/config/v1alpha1/shared_types.go

Lines changed: 5 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -172,6 +172,11 @@ type KubernetesServiceSpec struct {
172172
// +optional
173173
Type *ServiceType `json:"type,omitempty"`
174174

175+
// LoadBalancerClass, when specified, allows for choosing the LoadBalancer provider
176+
// implementation if more than one are available or is otherwise expected to be specified
177+
// +optional
178+
LoadBalancerClass *string `json:"loadBalancerClass,omitempty"`
179+
175180
// TODO: Expose config as use cases are better understood, e.g. labels.
176181
}
177182

api/config/v1alpha1/zz_generated.deepcopy.go

Lines changed: 5 additions & 0 deletions
Some generated files are not rendered by default. Learn more about customizing how changed files appear on GitHub.

charts/gateway-helm/crds/generated/config.gateway.envoyproxy.io_envoyproxies.yaml

Lines changed: 6 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -3807,6 +3807,12 @@ spec:
38073807
description: Annotations that should be appended to the
38083808
service. By default, no annotations are appended.
38093809
type: object
3810+
loadBalancerClass:
3811+
description: LoadBalancerClass, when specified, allows
3812+
for choosing the LoadBalancer provider implementation
3813+
if more than one are available or is otherwise expected
3814+
to be specified
3815+
type: string
38103816
type:
38113817
default: LoadBalancer
38123818
description: Type determines how the Service is exposed.

docs/latest/api/config_types.md

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -550,6 +550,7 @@ _Appears in:_
550550
| --- | --- |
551551
| `annotations` _object (keys:string, values:string)_ | Annotations that should be appended to the service. By default, no annotations are appended. |
552552
| `type` _[ServiceType](#servicetype)_ | Type determines how the Service is exposed. Defaults to LoadBalancer. Valid options are ClusterIP, LoadBalancer and NodePort. "LoadBalancer" means a service will be exposed via an external load balancer (if the cloud provider supports it). "ClusterIP" means a service will only be accessible inside the cluster, via the cluster IP. "NodePort" means a service will be exposed on a static Port on all Nodes of the cluster. |
553+
| `loadBalancerClass` _string_ | LoadBalancerClass, when specified, allows for choosing the LoadBalancer provider implementation if more than one are available or is otherwise expected to be specified |
553554

554555

555556
## KubernetesWatchMode

internal/infrastructure/kubernetes/proxy/resource_provider.go

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -97,7 +97,7 @@ func (r *ResourceRender) Service() (*corev1.Service, error) {
9797
}
9898

9999
// Set the spec of gateway service
100-
serviceSpec := resource.ExpectedServiceSpec(envoyServiceConfig.Type)
100+
serviceSpec := resource.ExpectedServiceSpec(envoyServiceConfig)
101101
serviceSpec.Ports = ports
102102
serviceSpec.Selector = resource.GetSelector(labels).MatchLabels
103103
serviceSpec.ExternalIPs = r.infra.Addresses

internal/infrastructure/kubernetes/ratelimit/resource_provider.go

Lines changed: 4 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -69,8 +69,10 @@ func (r *ResourceRender) Service() (*corev1.Service, error) {
6969
}
7070

7171
labels := rateLimitLabels()
72-
73-
serviceSpec := resource.ExpectedServiceSpec(egcfgv1a1.GetKubernetesServiceType(egcfgv1a1.ServiceTypeClusterIP))
72+
kubernetesServiceSpec := &egcfgv1a1.KubernetesServiceSpec{
73+
Type: egcfgv1a1.GetKubernetesServiceType(egcfgv1a1.ServiceTypeClusterIP),
74+
}
75+
serviceSpec := resource.ExpectedServiceSpec(kubernetesServiceSpec)
7476
serviceSpec.Ports = ports
7577
serviceSpec.Selector = resource.GetSelector(labels).MatchLabels
7678

internal/infrastructure/kubernetes/resource/resource.go

Lines changed: 6 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -23,11 +23,14 @@ func GetSelector(labels map[string]string) *metav1.LabelSelector {
2323
}
2424

2525
// ExpectedServiceSpec returns service spec.
26-
func ExpectedServiceSpec(serviceType *egcfgv1a1.ServiceType) corev1.ServiceSpec {
26+
func ExpectedServiceSpec(service *egcfgv1a1.KubernetesServiceSpec) corev1.ServiceSpec {
2727
serviceSpec := corev1.ServiceSpec{}
28-
serviceSpec.Type = corev1.ServiceType(*serviceType)
28+
serviceSpec.Type = corev1.ServiceType(*service.Type)
2929
serviceSpec.SessionAffinity = corev1.ServiceAffinityNone
30-
if *serviceType == egcfgv1a1.ServiceTypeLoadBalancer {
30+
if *service.Type == egcfgv1a1.ServiceTypeLoadBalancer {
31+
if service.LoadBalancerClass != nil {
32+
serviceSpec.LoadBalancerClass = service.LoadBalancerClass
33+
}
3134
// Preserve the client source IP and avoid a second hop for LoadBalancer.
3235
serviceSpec.ExternalTrafficPolicy = corev1.ServiceExternalTrafficPolicyTypeLocal
3336
}

internal/infrastructure/kubernetes/resource/resource_test.go

Lines changed: 22 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -19,25 +19,43 @@ import (
1919

2020
func TestExpectedServiceSpec(t *testing.T) {
2121
type args struct {
22-
serviceType *egcfgv1a1.ServiceType
22+
service *egcfgv1a1.KubernetesServiceSpec
2323
}
24+
loadbalancerClass := "foobar"
2425
tests := []struct {
2526
name string
2627
args args
2728
want corev1.ServiceSpec
2829
}{
2930
{
3031
name: "LoadBalancer",
31-
args: args{serviceType: egcfgv1a1.GetKubernetesServiceType(egcfgv1a1.ServiceTypeLoadBalancer)},
32+
args: args{service: &egcfgv1a1.KubernetesServiceSpec{
33+
Type: egcfgv1a1.GetKubernetesServiceType(egcfgv1a1.ServiceTypeLoadBalancer),
34+
}},
3235
want: corev1.ServiceSpec{
3336
Type: corev1.ServiceTypeLoadBalancer,
3437
SessionAffinity: corev1.ServiceAffinityNone,
3538
ExternalTrafficPolicy: corev1.ServiceExternalTrafficPolicyTypeLocal,
3639
},
3740
},
41+
{
42+
name: "LoadBalancerWithClass",
43+
args: args{service: &egcfgv1a1.KubernetesServiceSpec{
44+
Type: egcfgv1a1.GetKubernetesServiceType(egcfgv1a1.ServiceTypeLoadBalancer),
45+
LoadBalancerClass: &loadbalancerClass,
46+
}},
47+
want: corev1.ServiceSpec{
48+
Type: corev1.ServiceTypeLoadBalancer,
49+
LoadBalancerClass: &loadbalancerClass,
50+
SessionAffinity: corev1.ServiceAffinityNone,
51+
ExternalTrafficPolicy: corev1.ServiceExternalTrafficPolicyTypeLocal,
52+
},
53+
},
3854
{
3955
name: "ClusterIP",
40-
args: args{serviceType: egcfgv1a1.GetKubernetesServiceType(egcfgv1a1.ServiceTypeClusterIP)},
56+
args: args{service: &egcfgv1a1.KubernetesServiceSpec{
57+
Type: egcfgv1a1.GetKubernetesServiceType(egcfgv1a1.ServiceTypeClusterIP),
58+
}},
4159
want: corev1.ServiceSpec{
4260
Type: corev1.ServiceTypeClusterIP,
4361
SessionAffinity: corev1.ServiceAffinityNone,
@@ -46,7 +64,7 @@ func TestExpectedServiceSpec(t *testing.T) {
4664
}
4765
for _, tt := range tests {
4866
t.Run(tt.name, func(t *testing.T) {
49-
assert.Equalf(t, tt.want, ExpectedServiceSpec(tt.args.serviceType), "expectedServiceSpec(%v)", tt.args.serviceType)
67+
assert.Equalf(t, tt.want, ExpectedServiceSpec(tt.args.service), "expectedServiceSpec(%v)", tt.args.service)
5068
})
5169
}
5270
}

0 commit comments

Comments
 (0)