operator-sdk alpha config-gen
config-gen programatically generates configuration for a controller-runtime based project using the project source code (golang) and a KubebuilderConfigGen resource file.
This is an alternative to expressing configuration as a static set of kustomize patches in the “config” directory.
config-gen may be used as a standalone command run against a file, as a kustomize transformer plugin, or as a configuration function (e.g. kpt).
Following is an example KubebuilderConfigGen resource used by config-gen:
kubebuilderconfiggen.yaml
this resource describes how to generate configuration for a controller-runtime
based project
apiVersion: kubebuilder.sigs.k8s.io/v1alpha1 kind: KubebuilderConfigGen metadata: name: my-project-name spec: controllerManager: image: my-org-name/my-project-name:v0.1.0
If this file was at the project source root, config-gen could be used to emit configuration using:
The KubebuilderConfigGen resource has the following fields:
apiVersion: kubebuilder.sigs.k8s.io/v1alpha1 kind: KubebuilderConfigGen
metadata: # name of the project. used in various resource names. # required name: project-name
controllerManager:
# image to run
image: my-org/my-project:v0.1.0
# if set, use component config for the controller-manager
# optional
componentConfig:
# use component config
enable: true
# path to component config to put into a ConfigMap
configFilepath: ./path/to/componentconfig.yaml
# configure how metrics are exposed
metrics:
# disable the auth proxy required for scraping metrics
# disable: false
# generate prometheus ServiceMonitor resource
enableServiceMonitor: true
# configure how webhooks are generated
# optional -- defaults to not generating webhook configuration
webhooks:
# enable will cause webhook config to be generated
enable: true
enableConversion:
# key is the name of the CRD
"bars.example.my.domain": true
# configures where to get the certificate used for webhooks
certificateSource:
# type of certificate source
# one of ["certManager", "dev", "manual"] -- defaults to "manual"
# certManager: certmanager is used to manage certificates -- requires CertManager to be installed
# dev: certificate is generated and wired into resources
# manual: no certificate is generated or wired into resources
type: "dev"
# options for a dev certificate -- requires "dev" as the type
devCertificate:
duration: 1h
#
# As command
#
# create the kubebuilderconfiggen.yaml at project root
cat > kubebuilderconfiggen.yaml <<EOF
apiVersion: kubebuilder.sigs.k8s.io/v1alpha1
kind: KubebuilderConfigGen
metadata:
name: project
spec:
controllerManager
image: org/project:v0.1.0
EOF
# run the config generator
kubebuilder alpha config-gen kubebuilderconfiggen.yaml
# run the config generator and apply
kubebuilder alpha config-gen kubebuilderconfiggen.yaml | kubectl apply -f -
kubebuilder alpha config-gen kubebuilderconfiggen.yaml patch1.yaml patch2.yaml
#
# As Kustomize plugin
# this allows using config-gen with kustomize features such as patches, commonLabels,
# commonAnnotations, resources, configMapGenerator and other transformer plugins.
#
# install the latest kustomize
GO111MODULE=on go get sigs.k8s.io/kustomize/kustomize/v4
# install the command as a kustomize plugin
kubebuilder alpha config-gen install-as-plugin
# create the kustomization.yaml containing the KubebuilderConfigGen resource
cat > kustomization.yaml <<EOF
apiVersion: kustomize.config.k8s.io/v1beta1
kind: Kustomization
transformers:
- |-
apiVersion: kubebuilder.sigs.k8s.io/v1alpha1
kind: KubebuilderConfigGen
metadata:
name: my-project
spec:
controllerManager:
image: my-org/my-project:v0.1.0
EOF
# generate configuration from kustomize > v4.0.0
kustomize build --enable-alpha-plugins .
# generate configuration from kustomize <= v4.0.0
kustomize build --enable_alpha_plugins .
--plugins strings plugin keys to be used for this subcommand execution
- operator-sdk alpha - Alpha-stage subcommands