Skip to content

Latest commit

 

History

History
88 lines (67 loc) · 4.43 KB

expansion.md

File metadata and controls

88 lines (67 loc) · 4.43 KB

Adding capacity to a MinIO Tenant Slack

This document explains how to expand an existing MinIO Tenant with Operator. This is only applicable to a Tenant (MinIO Deployment) created by MinIO Operator.

MinIO expansion is done in terms of MinIO pools, read more about the design in MinIO Docs.

Getting Started

You can add capacity to the tenant using editing your tenant yaml or using the MinIO Operator Console.

kubectl -n NAMESPACE edit tenant TENANT_NAME

Modify the .spec.pools section to add an additional pool. For example, to add a pool with 4 drives, modify the yaml as:

spec:
  pools:
      ...
        - servers: 4
    ## For naming of the pool, you can use any name, but keeping sequential numbers is recommended.
        name: pool-1
    ## volumesPerServer specifies the number of volumes attached per MinIO Tenant Pod / Server.
        volumesPerServer: 4
    ## This VolumeClaimTemplate is used across all the volumes provisioned for MinIO Tenant in this Pool.
        volumeClaimTemplate:
          metadata:
            name: data
          spec:
            accessModes:
              - ReadWriteOnce
            resources:
              requests:
                storage: 2Gi

NOTE: Important points to consider before using Tenant expansion:

  • During Tenant expansion, MinIO Operator removes the existing StatefulSet and creates a new StatefulSet with required number of Pods. This means, there is a downtime during expansion, as the pods are terminated and created again. As existing StatefulSet pods are terminated, its PVCs are also deleted. It is very important to ensure PVs bound to MinIO StatefulSet PVCs are not deleted at this time to avoid data loss. We recommend configuring every PV with reclaim policy retain, to ensure the PV is not deleted. If you attempt Tenant expansion while the PV reclaim policy is set to something else, it may lead to data loss. If you have the reclaim policy set to something else, change it as explained in Kubernetes documents.

  • MinIO server currently doesn't support reducing storage capacity.

Underlying Details in Tenant Expansion

What are MinIO pools

A MinIO pool is a self-contained entity with same SLA's (read/write quorum) for each object. There are no limits on how many pools can be combined. After adding of a pool, MinIO simply uses the least used pool. All pools are for all purposes are invisible to an any application, and MinIO handles the pools internally.

Rules of Adding pools

There is only one requirement, i.e. based on initial pool's erasure set count (say n), new pools are expected to have a minimum of n drives to match the original Tenant SLA, or it should be in multiples of n. For example if initial set count is 4, new pools should have at least 4 or multiple of 4 drives.

Effects on KES/TLS Enabled Instance

If your MinIO Operator configuration has KES or Automatic TLS enabled, there are additional considerations:

  • When new pools are added, Operator invalidates older self-signed TLS certificates and the related secrets. Operator then creates new certificate signing requests (CSR). This is because there are new MinIO nodes that must be added in certificate DNS names. The administrator must approve these CSRs for MinIO server to be deployed again. Unless the CSR are approved, Operator will not create MinIO StatefulSet pods.

  • If you're using your own certificates, as explained here, please ensure to use/update proper certificates that allow older and new MinIO nodes.

Downtime

The Tenant expansion process requires removing the existing StatefulSet and creating a new StatefulSet with the required number of pods. Kubernetes automatically terminates and re-creates pods and PVCs during this process. Since MinIO requires at least (Volumes/2)+1 volumes to support regular read and write operations, the expansion process may result in a period of downtime where MinIO returns errors for read and write operations.