A newer version of this documentation is available.

View Latest

Annotation Documentation

    Couchbase Operator uses special annotations to configure specific resources.

    History Retention

    Bucket

    apiVersion: v2
    kind: CouchbaseBucket
    metadata:
      name: "my-bucket"
      annotations:
        cao.couchbase.com/historyRetention.seconds: "1000"
        cao.couchbase.com/historyRetention.bytes: "2147483648"
        cao.couchbase.com/historyRetention.collectionHistoryDefault: "true"
    spec:
      storageBackend: magma
      memoryQuota: 1024Mi
      evictionPolicy: valueOnly

    cao.couchbase.com/historyRetention.seconds

    Used for configuring history retention time for a bucket. This parameter is parsed into an integer and defines how many seconds of history an individual vbucket should aim to retain on disk. Defaults to 0, and can be altered after bucket creation. This annotation is only supported on buckets with couchbasebuckets.spec.storageBackend=magma.

    cao.couchbase.com/historyRetention.bytes

    Used for configuring history retention size for a bucket. This parameter is parsed into an integer and defines how many bytes of history an individual vbucket should aim to retain on disk. Defaults to 0 and has a minimum working value of 2147483648. Can be altered after bucket creation. Only supported on buckets with couchbasebuckets.spec.storageBackend=magma. This annotation is only supported on buckets with couchbasebuckets.spec.storageBackend=magma.

    cao.couchbase.com/historyRetention.collectionHistoryDefault

    Used for configuring whether history retention is enabled for a collection by default. This parameter sets whether history retention is enabled by default on newly created collections. Defaults to true, and accepts true or false. This field can be altered after bucket creation. This annotation is only supported on buckets with couchbasebuckets.spec.storageBackend=magma.

    Collection

    apiVersion: v2
    kind: CouchbaseCollection
    metadata:
      name: "my-collection"
      annotations:
        cao.couchbase.com/history: "true"

    cao.couchbase.com/history

    Used for enabling/disabling history retention at collection creation time. This parameter is used to enable/disable history retention when a new collection is being created. Any changes to this field once the collection has been created will be ignored. Accepts a either true or false and defaults to the bucket level collectionHistoryDefault.

    Bucket Backend Configuration

    Managed Buckets

    cao.couchbase.com/buckets.defaultStorageBackend

    Used to configure the default storage backend for managed CouchbaseBucket. Changing the storage backend of a pre-existing bucket is only supported on CouchbaseServer version 7.6.0 Defaults to couchstore, accepts either couchstore or magma.

    Unmanaged Buckets

    cao.couchbase.com/buckets.targetUnmanagedBucketStorageBackend

    Used to force a storage backend on all buckets in a Couchbase Cluster. This configuration only takes action if bucket management is disabled When configured the Couchbase Operator will attempt to force all buckets in a cluster to a particular storage backend. This config is only used with Couchbase Server 7.6.0. Accepts either couchstore or magma.

    Cluster Scheduling

    Rescheduling To Different Server Groups On Failed Scheduling

    cao.couchbase.com/rescheduleDifferentServerGroup

    Used to allow Couchbase Operator to attempt to reschedule a pod to a different server group if the pod fails to schedule on the original server group. By default Couchbase Operator will continue to try to schedule the pod on the original server group if it fails to schedule. With this annotation applied to a cluster the operator will try to schedule the pod to a different server group that has the same number of Couchbase Pods in it as the original server group. This is to ensure that the cluster remains balanced across the server groups. This is a best effort attempt and may not always succeed. If there are no server groups with the same number of pods as the original server group the pod will be scheduled on the original server group. Accepts either true or false.

    Server Group Shuffling

    cao.couchbase.com/shuffleServerGroups

    Used to allow Couchbase Operator to shuffle the order that pods are scheduled to defined server groups. By default Couchbase Operator will schedule pods to server groups in lexical order. The shuffling is pseudo-random and is based on the cluster name and namespce, so the same cluster/namespace combination will always shuffle the server groups in the same order. Accepts either true or false.

    Pod Rescheduling

    Individual Pod Rescheduling

    cao.couchbase.com/reschedule

    Used to force a pod to be rescheduled. When this annotation is applied to a Couchbase pod, the operator will detect it and reschedule the pod. The pods will either be Swap Rebalanced or go through a InPlaceUpgrade depending on couchbaseclusters.spec.upgradeProcess. Accepts either true or false.

    Host Network

    Improved Host Network Support

    cao.couchbase.com/networking.improvedHostNetwork

    Used to enable improved host network support. This annotation is used to enable improved host network support for Couchbase Server pods. When enabled on a cluster the operator will skip SAN validation and will add the underlying Kubernetes hostname a pod is running on to the alternate addresses list.

    Cloud Native Gateway

    OTLP Endpoint

    cao.couchbase.com/networking.cloudNativeGateway.otlp.endpoint

    Used to set a custom OTLP endpoint for on Cloud Native Gateway. This annotation is applied to the cluster, and takes a string value (e.g. "https://otel:1234"). The value is passed directly to the Cloud Native Gateway container.