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: valueOnlycao.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
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.