Skip to content

Latest commit

 

History

History
989 lines (721 loc) · 48.6 KB

crd.adoc

File metadata and controls

989 lines (721 loc) · 48.6 KB

API Reference

minio.min.io/v2

Package v2 - This page provides a quick automatically generated reference for the MinIO Operator minio.min.io/v2 CRD. For more complete documentation on the MinIO Operator CRD, see MinIO Kubernetes Documentation.

The minio.min.io/v2 API was released with the v4.0.0 MinIO Operator. The MinIO Operator automatically converts existing tenants using the /v1 API to /v2.

The minio.min.io/v1 API is deprecated and will be removed in a future release. Update your existing MinIO Tenant object specifications to the /v2 API. For documentation on the v1 API, see the MinIO Operator CRD v1 reference.

AuditConfig

AuditConfig defines configuration parameters for Audit (type) logs

Appears In:
Field Description

diskCapacityGB integer

Required
Specify the amount of storage to request in Gigabytes (GB) for storing audit logs.

CertificateConfig

CertificateConfig (certConfig) defines controlling attributes associated to any TLS certificate automatically generated by the Operator as part of tenant creation. These fields have no effect if spec.autoCert: false.

Appears In:
Field Description

commonName string

Optional
The CommonName or CN attribute to associate to automatically generated TLS certificates.

organizationName string array

Optional
Specify one or more OrganizationName or O attributes to associate to automatically generated TLS certificates.

dnsNames string array

Optional
Specify one or more x.509 Subject Alternative Names (SAN) to associate to automatically generated TLS certificates. MinIO Server pods use SNI to determine which certificate to respond with based on the requested hostname.

CertificateStatus

CertificateStatus keeps track of all the certificates managed by the operator

Appears In:
Field Description

autoCertEnabled boolean

AutoCertEnabled registers whether we know if the tenant has autocert enabled

ConsoleConfiguration

ConsoleConfiguration (console) defines configuration of the MinIO Console deployed as part of the MinIO Tenant. The Operator automatically configures the Console for connectivity to MinIO server pods in the tenant.
For more complete documentation on this object, see the MinIO Kubernetes Documentation.

Appears In:
Field Description

replicas integer

Optional
Specify the number of replica Console pods to deploy in the tenant. Defaults to 2.

image string

Optional
The Docker image to use for deploying the MinIO Console. Defaults to minio/console:v0.7.5.+

imagePullPolicy PullPolicy

Optional
The pull policy for the MinIO Console Docker image. Specify one of the following:
* Always
* Never
* IfNotPresent (Default)
Refer to the Kubernetes documentation for details https://kubernetes.io/docs/concepts/containers/images#updating-images

consoleSecret LocalObjectReference

Required
Specify a Kubernetes opaque secret which contains environment variables to use for setting up the MinIO Console service.
See the MinIO Operator console-secret.yaml for an example.

serviceAccountName string

Optional
The Kubernetes Service Account to use for running MinIO Console pods created as part of the Tenant.

env EnvVar

Optional
Specify one or more Environment Variables for use by the MinIO Console.

Optional
Object specification for specifying CPU and memory resource allocations or limits in the MinIO tenant.

externalCertSecret LocalCertificateReference

Optional
Enables TLS with SNI support on each MinIO Console pod in the tenant. If externalCertSecret is omitted and spec.requestAutoCert is set to false, MinIO Console pods deploy without TLS enabled.
Specify a Kubernetes TLS secret. The MinIO Operator copies the specified certificate to every MinIO Console pod in the tenant. When the MinIO Console pod/service responds to a TLS connection request, it uses SNI to select the certificate with matching subjectAlternativeName.
Specify an object containing the following fields:
* - name - The name of the Kubernetes secret containing the TLS certificate.
* - type - Specify kubernetes.io/tls
See the MinIO Operator CRD reference for examples and more complete documentation on configuring TLS for MinIO Tenants.

externalCaCertSecret LocalCertificateReference

Optional
Allows MinIO Console pods to verify client TLS certificates signed by a Certificate Authority not in the pod’s trust store.
Specify one or more Kubernetes TLS secrets. The MinIO Operator copies the specified CA files to every MinIO Console pod in the tenant.
Each element in the externalCertSecret array is an object containing the following fields:
* - name - The name of the Kubernetes secret containing the Certificate Authority files.
* - type - Specify kubernetes.io/tls.
See the MinIO Operator CRD reference for examples and more complete documentation on configuring TLS for MinIO Tenants.

annotations object (keys:string, values:string)

Optional
If provided, use these annotations for Console Object Meta annotations

labels object (keys:string, values:string)

Optional
If provided, use these labels for Console Object Meta labels

nodeSelector object (keys:string, values:string)

Optional
The filter for the Operator to apply when selecting which nodes on which to deploy MinIO Console pods. The Operator only selects those nodes whose labels match the specified selector.
See the Kubernetes documentation on Assigning Pods to Nodes for more information.

tolerations Toleration

Optional
Specify one or more Kubernetes tolerations to apply to MinIO Console pods.

securityContext PodSecurityContext

Optional
Specify the Security Context of MinIO Console pods. The Operator supports only the following pod security fields:
* fsGroup
* fsGroupChangePolicy
* runAsGroup
* runAsNonRoot
* runAsUser
* seLinuxOptions

ExposeServices

ExposeServices (exposeServices) defines the exposure of the MinIO object storage and Console services.

Appears In:
Field Description

minio boolean

Optional
Directs the Operator to expose the MinIO service. Defaults to true.

console boolean

Optional
Directs the Operator to expose the MinIO Console service. Defaults to true.

HealthStatus (string)

Appears In:

KESConfig

KESConfig (kes) defines the configuration of the MinIO Key Encryption Service (KES) StatefulSet deployed as part of the MinIO Tenant. KES supports Server-Side Encryption of objects using an external Key Management Service (KMS).

Appears In:
Field Description

replicas integer

Optional
Specify the number of replica KES pods to deploy in the tenant. Defaults to 2.

image string

Optional
The Docker image to use for deploying MinIO KES. Defaults to minio/kes:v0.14.0.

imagePullPolicy PullPolicy

Optional
The pull policy for the MinIO Console Docker image. Specify one of the following:
* Always
* Never
* IfNotPresent (Default)
Refer to the Kubernetes documentation for details https://kubernetes.io/docs/concepts/containers/images#updating-images

serviceAccountName string

Optional
The Kubernetes Service Account to use for running MinIO KES pods created as part of the Tenant.

Required
Specify a Kubernetes opaque secret which contains environment variables to use for setting up the MinIO KES service.
See the MinIO Operator console-secret.yaml for an example.

externalCertSecret LocalCertificateReference

Optional
Enables TLS with SNI support on each MinIO KES pod in the tenant. If externalCertSecret is omitted and spec.requestAutoCert is set to false, MinIO KES pods deploy without TLS enabled.
Specify a Kubernetes TLS secret. The MinIO Operator copies the specified certificate to every MinIO Console pod in the tenant. When the MinIO Console pod/service responds to a TLS connection request, it uses SNI to select the certificate with matching subjectAlternativeName.
Specify an object containing the following fields:
* - name - The name of the Kubernetes secret containing the TLS certificate.
* - type - Specify kubernetes.io/tls
See the MinIO Operator CRD reference for examples and more complete documentation on configuring TLS for MinIO Tenants.

clientCertSecret LocalCertificateReference

Optional
Specify a a Kubernetes TLS secret containing a custom root Certificate Authority and x.509 certificate to use for performing mTLS authentication with an external Key Management Service, such as Hashicorp Vault.
Specify an object containing the following fields:
* - name - The name of the Kubernetes secret containing the Certificate Authority and x.509 Certificate.
* - type - Specify kubernetes.io/tls

annotations object (keys:string, values:string)

Optional
If provided, use these annotations for KES Object Meta annotations

labels object (keys:string, values:string)

Optional
If provided, use these labels for KES Object Meta labels

nodeSelector object (keys:string, values:string)

Optional
The filter for the Operator to apply when selecting which nodes on which to deploy MinIO KES pods. The Operator only selects those nodes whose labels match the specified selector.
See the Kubernetes documentation on Assigning Pods to Nodes for more information.

tolerations Toleration

Optional
Specify one or more Kubernetes tolerations to apply to MinIO KES pods.

keyName string

Optional
If provided, use this as the name of the key that KES creates on the KMS backend

securityContext PodSecurityContext

Specify the Security Context of MinIO KES pods. The Operator supports only the following pod security fields:
* fsGroup
* fsGroupChangePolicy
* runAsGroup
* runAsNonRoot
* runAsUser
* seLinuxOptions

LocalCertificateReference

LocalCertificateReference (externalCertSecret, externalCaCertSecret,clientCertSecret) contains a Kubernetes secret containing TLS certificates or Certificate Authority files for use with enabling TLS in the MinIO Tenant.

Field Description

name string

Required
The name of the Kubernetes secret containing the TLS certificate or Certificate Authority file.

type string

Required
The type of Kubernetes secret. Specify kubernetes.io/tls

LogConfig

LogConfig (log) defines the configuration of the MinIO Log Search API deployed as part of the MinIO Tenant. The Operator deploys a PostgreSQL instance as part of the tenant to support storing and querying MinIO logs.
If the tenant specification includes the console object, the Operator automatically configures and enables MinIO Log Search via the Console UI.

Appears In:
Field Description

image string

Optional
The Docker image to use for deploying the MinIO Log Search API. Defaults to minio/logsearchapi:v4.1.3.

Optional
Object specification for specifying CPU and memory resource allocations or limits in the MinIO tenant.

nodeSelector object (keys:string, values:string)

Optional
The filter for the Operator to apply when selecting which nodes on which to deploy MinIO Log Search API pods. The Operator only selects those nodes whose labels match the specified selector.
See the Kubernetes documentation on Assigning Pods to Nodes for more information.

affinity Affinity

Optional
Specify node affinity, pod affinity, and pod anti-affinity for LogSearch API pods.

tolerations Toleration

Optional
Specify one or more Kubernetes tolerations to apply to MinIO Log Search API pods.

annotations object (keys:string, values:string)

Optional
If provided, use these annotations for Log Search Object Meta annotations

labels object (keys:string, values:string)

Optional
If provided, use these labels for Log Search Object Meta labels

Optional
Object specification for configuring the backing PostgreSQL database for the LogSearch API.

audit AuditConfig

Required
Object specification for configuring LogSearch API.

securityContext PodSecurityContext

Optional
Specify the Security Context of pods deployed as part of the Log Search API. The Operator supports only the following pod security fields:
* fsGroup
* fsGroupChangePolicy
* runAsGroup
* runAsNonRoot
* runAsUser
* seLinuxOptions

LogDbConfig

LogDbConfig (db) defines the configuration of the PostgreSQL StatefulSet deployed to support the MinIO LogSearch API.

Appears In:
Field Description

image string

Optional
The Docker image to use for deploying PostgreSQL. Defaults to library/postgres.

volumeClaimTemplate PersistentVolumeClaim

Optional
Specify the configuration options for the MinIO Operator to use when generating Persistent Volume Claims for the PostgreSQL pod.

Optional
Object specification for specifying CPU and memory resource allocations or limits for the PostgreSQL pod.

nodeSelector object (keys:string, values:string)

Optional
The filter for the Operator to apply when selecting which nodes on which to deploy the PostgreSQL pod. The Operator only selects those nodes whose labels match the specified selector.
See the Kubernetes documentation on Assigning Pods to Nodes for more information.

affinity Affinity

Optional
Specify node affinity, pod affinity, and pod anti-affinity for the PostgreSQL pods.

tolerations Toleration

Optional
Specify one or more Kubernetes tolerations to apply to the PostgreSQL pods.

annotations object (keys:string, values:string)

Optional
If provided, use these annotations for PostgreSQL Object Meta annotations

labels object (keys:string, values:string)

Optional
If provided, use these labels for PostgreSQL Object Meta labels

securityContext PodSecurityContext

Optional
Specify the Security Context of the PostgreSQL pods. The Operator supports only the following pod security fields:
* fsGroup
* fsGroupChangePolicy
* runAsGroup
* runAsNonRoot
* runAsUser
* seLinuxOptions

Logging

Logging describes Logging for MinIO tenants.

Appears In:
Field Description

json boolean

anonymous boolean

quiet boolean

Pool

Pool (pools) defines a MinIO server pool on a Tenant. Each pool consists of a set of MinIO server pods which "pool" their storage resources for supporting object storage and retrieval requests. Each server pool is independent of all others and supports horizontal scaling of available storage resources in the MinIO Tenant.
See the MinIO Operator CRD reference for the pools object for examples and more complete documentation.

Appears In:
Field Description

name string

Optional
Specify the name of the pool. The Operator automatically generates the pool name if this field is omitted.

servers integer

Required The number of MinIO server pods to deploy in the pool. The minimum value is 2. The MinIO Operator requires a minimum of 4 volumes per pool. Specifically, the result of pools.servers X pools.volumesPerServer must be greater than 4.

volumesPerServer integer

Required
The number of Persistent Volume Claims to generate for each MinIO server pod in the pool.
The MinIO Operator requires a minimum of 4 volumes per pool. Specifically, the result of pools.servers X pools.volumesPerServer must be greater than 4.

volumeClaimTemplate PersistentVolumeClaim

Required
Specify the configuration options for the MinIO Operator to use when generating Persistent Volume Claims for the MinIO tenant.

Optional
Object specification for specifying CPU and memory resource allocations or limits in the MinIO tenant.

nodeSelector object (keys:string, values:string)

Optional
The filter for the Operator to apply when selecting which nodes on which to deploy pods in the pool. The Operator only selects those nodes whose labels match the specified selector.
See the Kubernetes documentation on Assigning Pods to Nodes for more information.

affinity Affinity

Optional
Specify node affinity, pod affinity, and pod anti-affinity for pods in the MinIO pool.

tolerations Toleration array

Optional
Specify one or more Kubernetes tolerations to apply to pods deployed in the MinIO pool.

securityContext PodSecurityContext

Optional
Specify the Security Context of pods in the pool. The Operator supports only the following pod security fields:
* fsGroup
* fsGroupChangePolicy
* runAsGroup
* runAsNonRoot
* runAsUser
* seLinuxOptions

PoolState (string)

Appears In:

PoolStatus

PoolStatus keeps track of all the pools and their current state

Appears In:
Field Description

ssName string

state PoolState

PrometheusConfig

PrometheusConfig (prometheus) defines the configuration of a Prometheus instance as part of the MinIO tenant. The Operator automatically configures the Prometheus instance to scrape and store metrics from the MinIO tenant.
The Operator deploys each Prometheus pod using the prometheus/prometheus:latest Docker image.

Appears In:
Field Description

image string

Optional
Defines the Docker image to use for deploying Prometheus pods. Defaults to prometheus/prometheus:latest.

sidecarimage string

Optional
Deprecated in Operator v4.0.1
Defines the Docker image to use as a sidecar for the Prometheus server. Defaults to alpine.
The specified Docker image must be the alpine package.

initimage string

Optional
Deprecated in Operator v4.0.1
Defines the Docker image to use as the init container for running the Prometheus server. Defaults to busybox.
The specified Docker image must be the busybox package.

diskCapacityGB integer

Optional
Specify the amount of storage to request in Gigabytes (GB) for supporting the Prometheus pod.

storageClassName string

Optional
Specify the storage class for the PVC to support the Prometheus pod.

annotations object (keys:string, values:string)

Optional
If provided, use these annotations for Prometheus Object Meta annotations

labels object (keys:string, values:string)

Optional
If provided, use these labels for Prometheus Object Meta labels

nodeSelector object (keys:string, values:string)

Optional
The filter for the Operator to apply when selecting which nodes on which to deploy the Prometheus pod. The Operator only selects those nodes whose labels match the specified selector.
See the Kubernetes documentation on Assigning Pods to Nodes for more information.

Optional
Object specification for specifying CPU and memory resource allocations or limits of the Prometheus pod.

securityContext PodSecurityContext

Optional
Specify the Security Context of the Prometheus pod. The Operator supports only the following pod security fields:
* fsGroup
* fsGroupChangePolicy
* runAsGroup
* runAsNonRoot
* runAsUser
* seLinuxOptions

PrometheusOperatorConfig

PrometheusOperatorConfig (prometheus) defines the configuration of a Prometheus service monitor object as part of the MinIO tenant. The Operator automatically configures the Prometheus service monitor to scrape and store metrics from the MinIO tenant.
Specify if the Service Monitor to be created for this tenant.

Appears In:
Field Description

labels object (keys:string, values:string)

Optional
If provided, use these labels for Console Object Meta labels

annotations object (keys:string, values:string)

Optional
If provided, use these annotations for Console Object Meta annotations

S3Features

S3Features (s3) - Object describing which S3 features to enable/disable in the MinIO Tenant.
Currently only supports BucketDNS

Appears In:
Field Description

bucketDNS boolean

Optional
Specify true to allow clients to access buckets using the DNS path <bucket>.minio.default.svc.cluster.local. Defaults to false.

ServiceMetadata

ServiceMetadata (serviceMetadata) defines custom labels and annotations for the MinIO Object Storage service and/or MinIO Console service.

Appears In:
Field Description

minioServiceLabels object (keys:string, values:string)

Optional
If provided, append these labels to the MinIO service

minioServiceAnnotations object (keys:string, values:string)

Optional
If provided, append these annotations to the MinIO service

consoleServiceLabels object (keys:string, values:string)

Optional
If provided, append these labels to the Console service

consoleServiceAnnotations object (keys:string, values:string)

Optional
If provided, append these annotations to the Console service

SideCars

SideCars (sidecars) defines a list of containers that the Operator attaches to each MinIO server pods in the pool.

Appears In:
Field Description

containers Container array

Optional
List of containers to run inside the Pod

volumeClaimTemplates PersistentVolumeClaim

Optional
volumeClaimTemplates is a list of claims that pods are allowed to reference. The StatefulSet controller is responsible for mapping network identities to claims in a way that maintains the identity of a pod. Every claim in this list must have at least one matching (by name) volumeMount in one container in the template. A claim in this list takes precedence over any volumes in the template, with the same name.

volumes Volume array

Optional
List of volumes that can be mounted by containers belonging to the pod. More info: https://kubernetes.io/docs/concepts/storage/volumes

Tenant

Tenant is a Kubernetes object describing a MinIO Tenant.

Appears In:
Field Description

metadata ObjectMeta

Refer to Kubernetes API documentation for fields of metadata.

scheduler TenantScheduler

spec TenantSpec

Required
The root field for the MinIO Tenant object.

TenantScheduler

TenantScheduler (scheduler) - Object describing Kubernetes Scheduler to use for deploying the MinIO Tenant.

Appears In:
Field Description

name string

Optional
Specify the name of the Kubernetes scheduler to be used to schedule Tenant pods

TenantSpec

TenantSpec (spec) defines the configuration of a MinIO Tenant object.
The following parameters are specific to the minio.min.io/v2 MinIO CRD API spec definition added as part of the MinIO Operator v4.0.0.
For more complete documentation on this object, see the MinIO Kubernetes Documentation.

Appears In:
Field Description

pools Pool array

Required
An array of objects describing each MinIO server pool deployed in the MinIO Tenant. Each pool consists of a set of MinIO server pods which "pool" their storage resources for supporting object storage and retrieval requests. Each server pool is independent of all others and supports horizontal scaling of available storage resources in the MinIO Tenant.
The MinIO Tenant spec must have at least one element in the pools array.
See the MinIO Operator CRD reference for the pools object for examples and more complete documentation.

image string

Optional
The Docker image to use when deploying minio server pods. Defaults to minio/minio:RELEASE.2021-06-17T00-10-46Z.

imagePullSecret LocalObjectReference

Optional
Specify the secret key to use for pulling images from a private Docker repository.

podManagementPolicy PodManagementPolicyType

Optional
Pod Management Policy for pod created by StatefulSet

credsSecret LocalObjectReference

Required
Specify a Kubernetes opaque secret to use for setting the MinIO root access key and secret key. Specify the secret as name: <secret>. The Kubernetes secret must contain the following fields:
* data.accesskey - The access key for the root credentials
* data.secretkey - The secret key for the root credentials

env EnvVar array

Optional
If provided, the MinIO Operator adds the specified environment variables when deploying the Tenant resource.

externalCertSecret LocalCertificateReference array

Optional
Enables TLS with SNI support on each MinIO pod in the tenant. If externalCertSecret is omitted and requestAutoCert is set to false, the MinIO Tenant deploys without TLS enabled.
Specify an array of Kubernetes TLS secrets. The MinIO Operator copies the specified certificates to every MinIO server pod in the tenant. When the MinIO pod/service responds to a TLS connection request, it uses SNI to select the certificate with matching subjectAlternativeName.
Each element in the externalCertSecret array is an object containing the following fields:
* - name - The name of the Kubernetes secret containing the TLS certificate.
* - type - Specify kubernetes.io/tls
See the MinIO Operator CRD reference for examples and more complete documentation on configuring TLS for MinIO Tenants.

externalCaCertSecret LocalCertificateReference

Optional
Allows MinIO server pods to verify client TLS certificates signed by a Certificate Authority not in the pod’s trust store.
Specify an array of Kubernetes TLS secrets. The MinIO Operator copies the specified certificates to every MinIO server pod in the tenant.
Each element in the externalCertSecret array is an object containing the following fields:
* - name - The name of the Kubernetes secret containing the Certificate Authority.
* - type - Specify kubernetes.io/tls.
See the MinIO Operator CRD reference for examples and more complete documentation on configuring TLS for MinIO Tenants.

externalClientCertSecret LocalCertificateReference

Optional
Enables mTLS authentication between the MinIO Tenant pods and MinIO KES. Required for enabling connectivity between the MinIO Tenant and MinIO KES.
Specify a Kubernetes TLS secrets. The MinIO Operator copies the specified certificate to every MinIO server pod in the tenant. The secret must contain the following fields:
* name - The name of the Kubernetes secret containing the TLS certificate.
* type - Specify kubernetes.io/tls
The specified certificate must correspond to an identity on the KES server. See the KES Wiki for more information on KES identities.
If deploying KES with the MinIO Operator, include the hash of the certificate as part of the kes object specification.
See the MinIO Operator CRD reference for examples and more complete documentation on configuring TLS for MinIO Tenants.

mountPath string

Optional
Mount path for MinIO volume (PV). Defaults to /export

subPath string

Optional
Subpath inside mount path. This is the directory where MinIO stores data. Default to ""` (empty)

requestAutoCert boolean

Optional
Enables using Kubernetes-based TLS certificate generation and signing for pods and services in the MinIO Tenant.
* Specify true to explicitly enable automatic certificate generate (Default).
* Specify false to disable automatic certificate generation.
If requestAutoCert is set to false and externalCertSecret is omitted, the MinIO Tenant deploys without TLS enabled. See the MinIO Operator CRD reference for examples and more complete documentation on configuring TLS for MinIO Tenants.

Optional
S3 related features can be disabled or enabled such as bucketDNS etc.

certConfig CertificateConfig

Optional
Enables setting the CommonName, Organization, and dnsName attributes for all TLS certificates automatically generated by the Operator. Configuring this object has no effect if requestAutoCert is false.

Optional
Directs the MinIO Operator to deploy the MinIO Console using the specified configuration. The MinIO Console is a first-party graphical user interface for performing administration on the MinIO Tenant.

kes KESConfig

Optional
Directs the MinIO Operator to deploy the MinIO Key Encryption Service (KES) using the specified configuration. The MinIO KES supports performing server-side encryption of objects on the MiNIO Tenant.

log LogConfig

Optional
Directs the MinIO Operator to deploy and configure the MinIO Log Search API. The Operator deploys a PostgreSQL instance as part of the tenant to support storing and querying MinIO logs.
If the tenant spec includes the console configuration, the Operator automatically configures and enables MinIO log search via the Console UI.

prometheus PrometheusConfig

Optional
Directs the MinIO Operator to deploy and configure Prometheus for collecting tenant metrics.
For example, minio.<namespace>.svc.<cluster-domain>.<example>/minio/v2/metrics/cluster. The specific DNS name for the service depends on your Kubernetes cluster configuration. See the Kubernetes documentation on DNS for Services and Pods for more information.

prometheusOperator PrometheusOperatorConfig

Optional
Directs the MinIO Operator to deploy a ServiceMonitor object.
ServiceMonitor object allows native integration with Prometheus Operator.

serviceAccountName string

Optional
The Kubernetes Service Account to use for running MinIO pods created as part of the Tenant.

priorityClassName string

Optional
Indicates the Pod priority and therefore importance of a Pod relative to other Pods in the cluster. This is applied to MinIO pods only.
Refer Kubernetes Priority Class documentation for more complete documentation.

imagePullPolicy PullPolicy

Optional
The pull policy for the MinIO Docker image. Specify one of the following:
* Always
* Never
* IfNotPresent (Default)
Refer Kubernetes documentation for details https://kubernetes.io/docs/concepts/containers/images#updating-images

sideCars SideCars

Optional
A list of containers to run as sidecars along every MinIO Pod deployed in the tenant.

exposeServices ExposeServices

Optional
Directs the Operator to expose the MinIO and/or Console services.

serviceMetadata ServiceMetadata

Optional
Specify custom labels and annotations to append to the MinIO service and/or Console service.

Optional
An array of Kubernetes opaque secrets to use for generating MinIO users during tenant provisioning.
Each element in the array is an object consisting of a key-value pair name: <string>, where the <string> references an opaque Kubernetes secret.
Each referenced Kubernetes secret must include the following fields:
* CONSOLE_ACCESS_KEY - The "Username" for the MinIO user
* CONSOLE_SECRET_KEY - The "Password" for the MinIO user
The Operator creates each user with the consoleAdmin policy by default. You can change the assigned policy after the Tenant starts.

logging Logging

Optional
Enable JSON, Anonymous logging for MinIO tenants.