1
0
mirror of https://github.com/openshift/openshift-docs.git synced 2026-02-05 12:46:18 +01:00
Files
openshift-docs/modules/olm-terms.adoc
2023-04-05 21:09:56 +00:00

80 lines
4.7 KiB
Plaintext

// Module included in the following assemblies:
//
// * operators/understanding/olm/olm-common-terms.adoc
:_content-type: CONCEPT
[id="olm-common-terms-glossary_{context}"]
= Common Operator Framework terms
[id="olm-common-terms-bundle_{context}"]
== Bundle
In the bundle format, a _bundle_ is a collection of an Operator CSV, manifests, and metadata. Together, they form a unique version of an Operator that can be installed onto the cluster.
[id="olm-common-terms-bundle-image_{context}"]
== Bundle image
In the bundle format, a _bundle image_ is a container image that is built from Operator manifests and that contains one bundle. Bundle images are stored and distributed by Open Container Initiative (OCI) spec container registries, such as Quay.io or DockerHub.
[id="olm-common-terms-catalogsource_{context}"]
== Catalog source
A _catalog source_ represents a store of metadata that OLM can query to discover and install Operators and their dependencies.
[id="olm-common-terms-channel_{context}"]
== Channel
A _channel_ defines a stream of updates for an Operator and is used to roll out updates for subscribers. The head points to the latest version of that channel. For example, a `stable` channel would have all stable versions of an Operator arranged from the earliest to the latest.
An Operator can have several channels, and a subscription binding to a certain channel would only look for updates in that channel.
[id="olm-common-terms-channel-head_{context}"]
== Channel head
A _channel head_ refers to the latest known update in a particular channel.
[id="olm-common-terms-csv_{context}"]
== Cluster service version
A _cluster service version (CSV)_ is a YAML manifest created from Operator
metadata that assists OLM in running the Operator in a cluster. It is the
metadata that accompanies an Operator container image, used to populate user
interfaces with information such as its logo, description, and version.
It is also a source of technical information that is required to run the Operator, like the RBAC rules it requires and which custom resources (CRs) it manages or depends on.
[id="olm-common-terms-dependency_{context}"]
== Dependency
An Operator may have a _dependency_ on another Operator being present in the cluster. For example, the Vault Operator has a dependency on the etcd Operator for its data persistence layer.
OLM resolves dependencies by ensuring that all specified versions of Operators and CRDs are installed on the cluster during the installation phase. This dependency is resolved by finding and installing an Operator in a catalog that satisfies the required CRD API, and is not related to packages or bundles.
[id="olm-common-terms-index-image_{context}"]
== Index image
In the bundle format, an _index image_ refers to an image of a database (a database snapshot) that contains information about Operator bundles including CSVs and CRDs of all versions. This index can host a history of Operators on a cluster and be maintained by adding or removing Operators using the `opm` CLI tool.
[id="olm-common-terms-installplan_{context}"]
== Install plan
An _install plan_ is a calculated list of resources to be created to automatically install or upgrade a CSV.
[id="olm-common-terms-multitenancy_{context}"]
== Multitenancy
A _tenant_ in {product-title} is a user or group of users that share common access and privileges for a set of deployed workloads, typically represented by a namespace or project. You can use tenants to provide a level of isolation between different groups or teams.
When a cluster is shared by multiple users or groups, it is considered a _multitenant_ cluster.
[id="olm-common-terms-operatorgroup_{context}"]
== Operator group
An _Operator group_ configures all Operators deployed in the same namespace as the `OperatorGroup` object to watch for their CR in a list of namespaces or cluster-wide.
[id="olm-common-terms-package_{context}"]
== Package
In the bundle format, a _package_ is a directory that encloses all released history of an Operator with each version. A released version of an Operator is described in a CSV manifest alongside the CRDs.
[id="olm-common-terms-registry_{context}"]
== Registry
A _registry_ is a database that stores bundle images of Operators, each with all of its latest and historical versions in all channels.
[id="olm-common-terms-subscription_{context}"]
== Subscription
A _subscription_ keeps CSVs up to date by tracking a channel in a package.
[id="olm-common-terms-update-graph_{context}"]
== Update graph
An _update graph_ links versions of CSVs together, similar to the update graph of any other packaged software. Operators can be installed sequentially, or certain versions can be skipped. The update graph is expected to grow only at the head with newer versions being added.