Chapter 8. Operator SDK
8.1. Installing the Operator SDK CLI
The Operator SDK provides a command-line interface (CLI) tool that Operator developers can use to build, test, and deploy an Operator. You can install the Operator SDK CLI on your workstation so that you are prepared to start authoring your own Operators.
The Red Hat-supported version of the Operator SDK CLI tool, including the related scaffolding and testing tools for Operator projects, is deprecated and is planned to be removed in a future release of OpenShift Container Platform. Red Hat will provide bug fixes and support for this feature during the current release lifecycle, but this feature will no longer receive enhancements and will be removed from future OpenShift Container Platform releases.
The Red Hat-supported version of the Operator SDK is not recommended for creating new Operator projects. Operator authors with existing Operator projects can use the version of the Operator SDK CLI tool released with OpenShift Container Platform 4.16 to maintain their projects and create Operator releases targeting newer versions of OpenShift Container Platform.
The following related base images for Operator projects are not deprecated. The runtime functionality and configuration APIs for these base images are still supported for bug fixes and for addressing CVEs.
- The base image for Ansible-based Operator projects
- The base image for Helm-based Operator projects
For the most recent list of major functionality that has been deprecated or removed within OpenShift Container Platform, refer to the Deprecated and removed features section of the OpenShift Container Platform release notes.
For information about the unsupported, community-maintained, version of the Operator SDK, see Operator SDK (Operator Framework).
Operator authors with cluster administrator access to a Kubernetes-based cluster, such as OpenShift Container Platform, can use the Operator SDK CLI to develop their own Operators based on Go, Ansible, Java, or Helm. Kubebuilder is embedded into the Operator SDK as the scaffolding solution for Go-based Operators, which means existing Kubebuilder projects can be used as is with the Operator SDK and continue to work. See Developing Operators for full documentation on the Operator SDK.
OpenShift Container Platform 4.16 supports Operator SDK 1.36.1.
8.1.1. Installing the Operator SDK CLI on Linux
You can install the OpenShift SDK CLI tool on Linux.
Prerequisites
- Go v1.19+
- 
							dockerv17.03+,podmanv1.9.3+, orbuildahv1.7+
Procedure
- Navigate to the OpenShift mirror site.
- From the latest 4.16 directory, download the latest version of the tarball for Linux.
- Unpack the archive: - tar xvf operator-sdk-v1.36.1-ocp-linux-x86_64.tar.gz - $ tar xvf operator-sdk-v1.36.1-ocp-linux-x86_64.tar.gz- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Make the file executable: - chmod +x operator-sdk - $ chmod +x operator-sdk- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Move the extracted - operator-sdkbinary to a directory that is on your- PATH.Tip- To check your - PATH:- echo $PATH - $ echo $PATH- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - sudo mv ./operator-sdk /usr/local/bin/operator-sdk - $ sudo mv ./operator-sdk /usr/local/bin/operator-sdk- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
Verification
- After you install the Operator SDK CLI, verify that it is available: - operator-sdk version - $ operator-sdk version- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example output - operator-sdk version: "v1.36.1-ocp", ... - operator-sdk version: "v1.36.1-ocp", ...- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
8.1.2. Installing the Operator SDK CLI on macOS
You can install the OpenShift SDK CLI tool on macOS.
Prerequisites
- Go v1.19+
- 
							dockerv17.03+,podmanv1.9.3+, orbuildahv1.7+
Procedure
- 
							For the amd64andarm64architectures, navigate to the OpenShift mirror site for theamd64architecture and OpenShift mirror site for thearm64architecture respectively.
- From the latest 4.16 directory, download the latest version of the tarball for macOS.
- Unpack the Operator SDK archive for - amd64architecture by running the following command:- tar xvf operator-sdk-v1.36.1-ocp-darwin-x86_64.tar.gz - $ tar xvf operator-sdk-v1.36.1-ocp-darwin-x86_64.tar.gz- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Unpack the Operator SDK archive for - arm64architecture by running the following command:- tar xvf operator-sdk-v1.36.1-ocp-darwin-aarch64.tar.gz - $ tar xvf operator-sdk-v1.36.1-ocp-darwin-aarch64.tar.gz- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Make the file executable by running the following command: - chmod +x operator-sdk - $ chmod +x operator-sdk- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Move the extracted - operator-sdkbinary to a directory that is on your- PATHby running the following command:Tip- Check your - PATHby running the following command:- echo $PATH - $ echo $PATH- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - sudo mv ./operator-sdk /usr/local/bin/operator-sdk - $ sudo mv ./operator-sdk /usr/local/bin/operator-sdk- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
Verification
- After you install the Operator SDK CLI, verify that it is available by running the following command:: - operator-sdk version - $ operator-sdk version- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example output - operator-sdk version: "v1.36.1-ocp", ... - operator-sdk version: "v1.36.1-ocp", ...- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
8.2. Operator SDK CLI reference
The Operator SDK command-line interface (CLI) is a development kit designed to make writing Operators easier.
The Red Hat-supported version of the Operator SDK CLI tool, including the related scaffolding and testing tools for Operator projects, is deprecated and is planned to be removed in a future release of OpenShift Container Platform. Red Hat will provide bug fixes and support for this feature during the current release lifecycle, but this feature will no longer receive enhancements and will be removed from future OpenShift Container Platform releases.
The Red Hat-supported version of the Operator SDK is not recommended for creating new Operator projects. Operator authors with existing Operator projects can use the version of the Operator SDK CLI tool released with OpenShift Container Platform 4.16 to maintain their projects and create Operator releases targeting newer versions of OpenShift Container Platform.
The following related base images for Operator projects are not deprecated. The runtime functionality and configuration APIs for these base images are still supported for bug fixes and for addressing CVEs.
- The base image for Ansible-based Operator projects
- The base image for Helm-based Operator projects
For the most recent list of major functionality that has been deprecated or removed within OpenShift Container Platform, refer to the Deprecated and removed features section of the OpenShift Container Platform release notes.
For information about the unsupported, community-maintained, version of the Operator SDK, see Operator SDK (Operator Framework).
Operator SDK CLI syntax
operator-sdk <command> [<subcommand>] [<argument>] [<flags>]
$ operator-sdk <command> [<subcommand>] [<argument>] [<flags>]See Developing Operators for full documentation on the Operator SDK.
8.2.1. bundle
					The operator-sdk bundle command manages Operator bundle metadata.
				
8.2.1.1. validate
						The bundle validate subcommand validates an Operator bundle.
					
| Flag | Description | 
|---|---|
| 
										 | 
										Help output for the  | 
| 
										 | 
										Tool to pull and unpack bundle images. Only used when validating a bundle image. Available options are  | 
| 
										 | List all optional validators available. When set, no validators are run. | 
| 
										 | 
										Label selector to select optional validators to run. When run with the  | 
8.2.2. cleanup
					The operator-sdk cleanup command destroys and removes resources that were created for an Operator that was deployed with the run command.
				
| Flag | Description | 
|---|---|
| 
									 | 
									Help output for the  | 
| 
									 | 
									Path to the  | 
| 
									 | If present, namespace in which to run the CLI request. | 
| 
									 | 
									Time to wait for the command to complete before failing. The default value is  | 
8.2.3. completion
					The operator-sdk completion command generates shell completions to make issuing CLI commands quicker and easier.
				
| Subcommand | Description | 
|---|---|
| 
									 | Generate bash completions. | 
| 
									 | Generate zsh completions. | 
| Flag | Description | 
|---|---|
| 
									 | Usage help output. | 
For example:
operator-sdk completion bash
$ operator-sdk completion bashExample output
bash completion for operator-sdk -*- shell-script -*- ex: ts=4 sw=4 et filetype=sh
# bash completion for operator-sdk                         -*- shell-script -*-
...
# ex: ts=4 sw=4 et filetype=sh8.2.4. create
					The operator-sdk create command is used to create, or scaffold, a Kubernetes API.
				
8.2.4.1. api
						The create api subcommand scaffolds a Kubernetes API. The subcommand must be run in a project that was initialized with the init command.
					
| Flag | Description | 
|---|---|
| 
										 | 
										Help output for the  | 
8.2.5. generate
					The operator-sdk generate command invokes a specific generator to generate code or manifests.
				
8.2.5.1. bundle
						The generate bundle subcommand generates a set of bundle manifests, metadata, and a bundle.Dockerfile file for your Operator project.
					
							Typically, you run the generate kustomize manifests subcommand first to generate the input Kustomize bases that are used by the generate bundle subcommand. However, you can use the make bundle command in an initialized project to automate running these commands in sequence.
						
| Flag | Description | 
|---|---|
| 
										 | 
										Comma-separated list of channels to which the bundle belongs. The default value is  | 
| 
										 | 
										Root directory for  | 
| 
										 | The default channel for the bundle. | 
| 
										 | 
										Root directory for Operator manifests, such as deployments and RBAC. This directory is different from the directory passed to the  | 
| 
										 | 
										Help for  | 
| 
										 | 
										Directory from which to read an existing bundle. This directory is the parent of your bundle  | 
| 
										 | 
										Directory containing Kustomize bases and a  | 
| 
										 | Generate bundle manifests. | 
| 
										 | Generate bundle metadata and Dockerfile. | 
| 
										 | Directory to write the bundle to. | 
| 
										 | 
										Overwrite the bundle metadata and Dockerfile if they exist. The default value is  | 
| 
										 | Package name for the bundle. | 
| 
										 | Run in quiet mode. | 
| 
										 | Write bundle manifest to standard out. | 
| 
										 | Semantic version of the Operator in the generated bundle. Set only when creating a new bundle or upgrading the Operator. | 
8.2.5.2. kustomize
						The generate kustomize subcommand contains subcommands that generate Kustomize data for the Operator.
					
8.2.5.2.1. manifests
							The generate kustomize manifests subcommand generates or regenerates Kustomize bases and a kustomization.yaml file in the config/manifests directory, which are used to build bundle manifests by other Operator SDK commands. This command interactively asks for UI metadata, an important component of manifest bases, by default unless a base already exists or you set the --interactive=false flag.
						
| Flag | Description | 
|---|---|
| 
											 | Root directory for API type definitions. | 
| 
											 | 
											Help for  | 
| 
											 | Directory containing existing Kustomize files. | 
| 
											 | 
											When set to  | 
| 
											 | Directory where to write Kustomize files. | 
| 
											 | Package name. | 
| 
											 | Run in quiet mode. | 
8.2.6. init
					The operator-sdk init command initializes an Operator project and generates, or scaffolds, a default project directory layout for the given plugin.
				
This command writes the following files:
- Boilerplate license file
- 
							PROJECTfile with the domain and repository
- 
							Makefileto build the project
- 
							go.modfile with project dependencies
- 
							kustomization.yamlfile for customizing manifests
- Patch file for customizing images for manager manifests
- Patch file for enabling Prometheus metrics
- 
							main.gofile to run
| Flag | Description | 
|---|---|
| 
									 | 
									Help output for the  | 
| 
									 | 
									Name and optionally version of the plugin to initialize the project with. Available plugins are  | 
| 
									 | 
									Project version. Available values are  | 
8.2.7. run
					The operator-sdk run command provides options that can launch the Operator in various environments.
				
8.2.7.1. bundle
						The run bundle subcommand deploys an Operator in the bundle format with Operator Lifecycle Manager (OLM).
					
| Flag | Description | 
|---|---|
| 
										 | 
										Index image in which to inject a bundle. The default image is  | 
| 
										 | 
										Install mode supported by the cluster service version (CSV) of the Operator, for example  | 
| 
										 | 
										Install timeout. The default value is  | 
| 
										 | 
										Path to the  | 
| 
										 | If present, namespace in which to run the CLI request. | 
| 
										 | 
										Specifies the security context to use for the catalog pod. Allowed values include  | 
| 
										 | 
										Help output for the  | 
- 
									The restrictedsecurity context is not compatible with thedefaultnamespace. To configure your Operator’s pod security admission in your production environment, see "Complying with pod security admission". For more information about pod security admission, see "Understanding and managing pod security admission".
8.2.7.2. bundle-upgrade
						The run bundle-upgrade subcommand upgrades an Operator that was previously installed in the bundle format with Operator Lifecycle Manager (OLM).
					
| Flag | Description | 
|---|---|
| 
										 | 
										Upgrade timeout. The default value is  | 
| 
										 | 
										Path to the  | 
| 
										 | If present, namespace in which to run the CLI request. | 
| 
										 | 
										Specifies the security context to use for the catalog pod. Allowed values include  | 
| 
										 | 
										Help output for the  | 
- 
									The restrictedsecurity context is not compatible with thedefaultnamespace. To configure your Operator’s pod security admission in your production environment, see "Complying with pod security admission". For more information about pod security admission, see "Understanding and managing pod security admission".
8.2.8. scorecard
					The operator-sdk scorecard command runs the scorecard tool to validate an Operator bundle and provide suggestions for improvements. The command takes one argument, either a bundle image or directory containing manifests and metadata. If the argument holds an image tag, the image must be present remotely.
				
| Flag | Description | 
|---|---|
| 
									 | 
									Path to scorecard configuration file. The default path is  | 
| 
									 | 
									Help output for the  | 
| 
									 | 
									Path to  | 
| 
									 | List which tests are available to run. | 
| 
									 | Namespace in which to run the test images. | 
| 
									 | 
									Output format for results. Available values are  | 
| 
									 | 
									Option to run scorecard with the specified security context. Allowed values include  | 
| 
									 | Label selector to determine which tests are run. | 
| 
									 | 
									Service account to use for tests. The default value is  | 
| 
									 | Disable resource cleanup after tests are run. | 
| 
									 | 
									Seconds to wait for tests to complete, for example  | 
- 
								The restrictedsecurity context is not compatible with thedefaultnamespace. To configure your Operator’s pod security admission in your production environment, see "Complying with pod security admission". For more information about pod security admission, see "Understanding and managing pod security admission".