Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add the resources field to the eventing CRD #51

Merged
merged 1 commit into from
Apr 30, 2020
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
39 changes: 39 additions & 0 deletions config/300-eventing.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -93,6 +93,45 @@ spec:
description: The default broker type to use for the brokers Knative creates.
If no value is provided, ChannelBasedBroker will be used.
type: string
resources:
description: A mapping of deployment name to resource requirements
type: array
items:
type: object
properties:
container:
description: The name of the container
type: string
requests:
type: object
properties:
memory:
type: string
pattern: ^([+-]?[0-9.]+)([eEinumkKMGTP]*[-+]?[0-9]*)$
cpu:
type: string
pattern: ^([+-]?[0-9.]+)([eEinumkKMGTP]*[-+]?[0-9]*)$
storage:
type: string
pattern: ^([+-]?[0-9.]+)([eEinumkKMGTP]*[-+]?[0-9]*)$
ephemeral-storage:
type: string
pattern: ^([+-]?[0-9.]+)([eEinumkKMGTP]*[-+]?[0-9]*)$
limits:
type: object
properties:
memory:
type: string
pattern: ^([+-]?[0-9.]+)([eEinumkKMGTP]*[-+]?[0-9]*)$
cpu:
type: string
pattern: ^([+-]?[0-9.]+)([eEinumkKMGTP]*[-+]?[0-9]*)$
storage:
type: string
pattern: ^([+-]?[0-9.]+)([eEinumkKMGTP]*[-+]?[0-9]*)$
ephemeral-storage:
type: string
pattern: ^([+-]?[0-9.]+)([eEinumkKMGTP]*[-+]?[0-9]*)$
type: object
status:
properties:
Expand Down
1 change: 1 addition & 0 deletions docs/configuration.md
Original file line number Diff line number Diff line change
Expand Up @@ -37,6 +37,7 @@ These are the configurable fields in each resource:
* [default](#specregistrydefault)
* [override](#specregistryoverride)
* [imagePullSecrets](#specregistryimagepullsecrets)
* [resources](#specresources)
* [defaultBrokerClass](#specdefaultbrokerclass)


Expand Down
4 changes: 4 additions & 0 deletions pkg/apis/operator/v1alpha1/knativeeventing_types.go
Original file line number Diff line number Diff line change
Expand Up @@ -47,6 +47,10 @@ type KnativeEventingSpec struct {
// +optional
Registry Registry `json:"registry,omitempty"`

// Override containers' resource requirements
// +optional
Resources []ResourceRequirementsOverride `json:"resources,omitempty"`

// The default broker type to use for the brokers Knative creates.
// If no value is provided, ChannelBasedBroker will be used.
// +optional
Expand Down
7 changes: 7 additions & 0 deletions pkg/apis/operator/v1alpha1/zz_generated.deepcopy.go

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

Original file line number Diff line number Diff line change
Expand Up @@ -24,12 +24,12 @@ import (
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
"k8s.io/apimachinery/pkg/apis/meta/v1/unstructured"
"k8s.io/client-go/kubernetes/scheme"
servingv1alpha1 "knative.dev/operator/pkg/apis/operator/v1alpha1"
"knative.dev/operator/pkg/apis/operator/v1alpha1"
)

// ResourceRequirementsTransform configures the resource requests for
// all containers within all deployments in the manifest
func ResourceRequirementsTransform(instance *servingv1alpha1.KnativeServing, log *zap.SugaredLogger) mf.Transformer {
func ResourceRequirementsTransform(resources []v1alpha1.ResourceRequirementsOverride, log *zap.SugaredLogger) mf.Transformer {
return func(u *unstructured.Unstructured) error {
if u.GetKind() == "Deployment" {
deployment := &appsv1.Deployment{}
Expand All @@ -38,7 +38,7 @@ func ResourceRequirementsTransform(instance *servingv1alpha1.KnativeServing, log
}
containers := deployment.Spec.Template.Spec.Containers
for i := range containers {
if override := find(instance, containers[i].Name); override != nil {
if override := find(resources, containers[i].Name); override != nil {
merge(&override.Limits, &containers[i].Resources.Limits)
merge(&override.Requests, &containers[i].Resources.Requests)
}
Expand All @@ -63,8 +63,8 @@ func merge(src, tgt *v1.ResourceList) {
}
}

func find(instance *servingv1alpha1.KnativeServing, name string) *servingv1alpha1.ResourceRequirementsOverride {
for _, override := range instance.Spec.Resources {
func find(resources []v1alpha1.ResourceRequirementsOverride, name string) *v1alpha1.ResourceRequirementsOverride {
for _, override := range resources {
if override.Container == name {
return &override
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -282,7 +282,7 @@ func TestResourceRequirementsTransform(t *testing.T) {
if err != nil {
t.Fatalf("Failed to create manifest: %v", err)
}
actual, err := manifest.Transform(ResourceRequirementsTransform(&test.Input, log))
actual, err := manifest.Transform(ResourceRequirementsTransform(test.Input.Spec.Resources, log))
if err != nil {
t.Fatalf("Failed to transform manifest: %v", err)
}
Expand Down
1 change: 1 addition & 0 deletions pkg/reconciler/knativeeventing/knativeeventing.go
Original file line number Diff line number Diff line change
Expand Up @@ -149,6 +149,7 @@ func (r *Reconciler) transform(ctx context.Context, instance *eventingv1alpha1.K
mf.InjectNamespace(instance.GetNamespace()),
common.ImageTransform(&instance.Spec.Registry, logger),
common.ConfigMapTransform(instance.Spec.Config, logger),
common.ResourceRequirementsTransform(instance.Spec.Resources, logger),
kec.DefaultBrokerConfigMapTransform(instance, logger),
}
transforms := append(standard, platform...)
Expand Down
2 changes: 1 addition & 1 deletion pkg/reconciler/knativeserving/knativeserving.go
Original file line number Diff line number Diff line change
Expand Up @@ -151,10 +151,10 @@ func (r *Reconciler) transform(ctx context.Context, instance *servingv1alpha1.Kn
mf.InjectNamespace(instance.GetNamespace()),
common.ConfigMapTransform(instance.Spec.Config, logger),
common.ImageTransform(&instance.Spec.Registry, logger),
common.ResourceRequirementsTransform(instance.Spec.Resources, logger),
ksc.GatewayTransform(instance, logger),
ksc.CustomCertsTransform(instance, logger),
ksc.HighAvailabilityTransform(instance, logger),
ksc.ResourceRequirementsTransform(instance, logger),
}
transforms := append(standard, platform...)
return r.config.Transform(transforms...)
Expand Down