2020-02-05 02:08:47 -05:00
# KMS Guide [![Slack](https://slack.min.io/slack?type=svg)](https://slack.min.io)
2018-08-17 15:52:14 -04:00
2020-09-13 19:23:18 -04:00
MinIO uses a key-management-system (KMS) to support SSE-S3. If a client requests SSE-S3, or auto-encryption is enabled, the MinIO server encrypts each object with an unique object key which is protected by a master key managed by the KMS.
2018-12-12 01:50:29 -05:00
2020-05-19 21:33:11 -04:00
## Quick Start
2024-01-18 02:03:17 -05:00
MinIO supports multiple KMS implementations via our [KES ](https://github.com/minio/kes#kes ) project. We run a KES instance at `https://play.min.io:7373` for you to experiment and quickly get started. To run MinIO with a KMS just fetch the root identity, set the following environment variables and then start your MinIO server. If you haven't installed MinIO, yet, then follow the MinIO [install instructions ](https://min.io/docs/minio/linux/index.html#quickstart-for-linux ) first.
2020-05-19 21:33:11 -04:00
2022-02-11 19:51:25 -05:00
### 1. Fetch the root identity
2020-05-20 16:55:54 -04:00
As the initial step, fetch the private key and certificate of the root identity:
```sh
curl -sSL --tlsv1.2 \
-O 'https://raw.githubusercontent.com/minio/kes/master/root.key' \
-O 'https://raw.githubusercontent.com/minio/kes/master/root.cert'
```
2022-02-11 19:51:25 -05:00
### 2. Set the MinIO-KES configuration
2020-05-20 16:55:54 -04:00
```sh
export MINIO_KMS_KES_ENDPOINT=https://play.min.io:7373
export MINIO_KMS_KES_KEY_FILE=root.key
export MINIO_KMS_KES_CERT_FILE=root.cert
export MINIO_KMS_KES_KEY_NAME=my-minio-key
```
2022-02-11 19:51:25 -05:00
### 3. Start the MinIO Server
2020-05-20 16:55:54 -04:00
```sh
2021-01-05 13:22:57 -05:00
export MINIO_ROOT_USER=minio
export MINIO_ROOT_PASSWORD=minio123
2020-05-20 16:55:54 -04:00
minio server ~/export
```
2020-05-19 21:33:11 -04:00
> The KES instance at `https://play.min.io:7373` is meant to experiment and provides a way to get started quickly.
> Note that anyone can access or delete master keys at `https://play.min.io:7373`. You should run your own KES
> instance in production.
## Configuration Guides
A typical MinIO deployment that uses a KMS for SSE-S3 looks like this:
2022-02-11 19:51:25 -05:00
2020-02-05 02:08:47 -05:00
```
2020-05-01 15:36:30 -04:00
┌────────────┐
│ ┌──────────┴─┬─────╮ ┌────────────┐
└─┤ ┌──────────┴─┬───┴──────────┤ ┌──────────┴─┬─────────────────╮
└─┤ ┌──────────┴─┬─────┬──────┴─┤ KES Server ├─────────────────┤
└─┤ MinIO ├─────╯ └────────────┘ ┌────┴────┐
└────────────┘ │ KMS │
└─────────┘
2020-09-03 15:43:45 -04:00
```
2018-12-18 16:00:32 -05:00
2020-09-13 19:23:18 -04:00
In a given setup, there are `n` MinIO instances talking to `m` KES servers but only `1` central KMS. The most simple setup consists of `1` MinIO server or cluster talking to `1` KMS via `1` KES server.
2019-07-17 15:55:26 -04:00
2020-09-13 19:23:18 -04:00
The main difference between various MinIO-KMS deployments is the KMS implementation. The following table helps you select the right option for your use case:
2019-07-17 15:55:26 -04:00
2020-10-06 14:09:43 -04:00
| KMS | Purpose |
|:---------------------------------------------------------------------------------------------|:------------------------------------------------------------------|
| [Hashicorp Vault ](https://github.com/minio/kes/wiki/Hashicorp-Vault-Keystore ) | Local KMS. MinIO and KMS on-prem (**Recommended**) |
| [AWS-KMS + SecretsManager ](https://github.com/minio/kes/wiki/AWS-SecretsManager ) | Cloud KMS. MinIO in combination with a managed KMS installation |
2021-01-16 15:08:02 -05:00
| [Gemalto KeySecure /Thales CipherTrust ](https://github.com/minio/kes/wiki/Gemalto-KeySecure ) | Local KMS. MinIO and KMS On-Premises. |
| [Google Cloud Platform SecretManager ](https://github.com/minio/kes/wiki/GCP-SecretManager ) | Cloud KMS. MinIO in combination with a managed KMS installation |
2020-10-06 14:09:43 -04:00
| [FS ](https://github.com/minio/kes/wiki/Filesystem-Keystore ) | Local testing or development (**Not recommended for production**) |
2020-09-13 19:23:18 -04:00
The MinIO-KES configuration is always the same - regardless of the underlying KMS implementation. Checkout the MinIO-KES [configuration example ](https://github.com/minio/kes/wiki/MinIO-Object-Storage ).
2020-02-05 02:08:47 -05:00
2020-05-19 21:33:11 -04:00
### Further references
2019-07-17 15:55:26 -04:00
2022-09-29 00:28:45 -04:00
- [Run MinIO with TLS / HTTPS ](https://min.io/docs/minio/linux/operations/network-encryption.html )
2020-09-03 15:43:45 -04:00
- [Tweak the KES server configuration ](https://github.com/minio/kes/wiki/Configuration )
- [Run a load balancer infront of KES ](https://github.com/minio/kes/wiki/TLS-Proxy )
- [Understand the KES server concepts ](https://github.com/minio/kes/wiki/Concepts )
2019-07-17 15:55:26 -04:00
2020-05-19 21:33:11 -04:00
## Auto Encryption
2022-02-11 19:51:25 -05:00
2020-09-13 19:23:18 -04:00
Auto-Encryption is useful when MinIO administrator wants to ensure that all data stored on MinIO is encrypted at rest.
2018-12-14 16:35:48 -05:00
2020-09-13 19:23:18 -04:00
### Using `mc encrypt` (recommended)
2022-02-11 19:51:25 -05:00
2020-09-03 15:43:45 -04:00
MinIO automatically encrypts all objects on buckets if KMS is successfully configured and bucket encryption configuration is enabled for each bucket as shown below:
2022-02-11 19:51:25 -05:00
2020-09-03 15:43:45 -04:00
```
2020-12-01 19:00:49 -05:00
mc encrypt set sse-s3 myminio/bucket/
2020-09-03 15:43:45 -04:00
```
2018-12-14 16:35:48 -05:00
2020-09-03 15:43:45 -04:00
Verify if MinIO has `sse-s3` enabled
2022-02-11 19:51:25 -05:00
2019-07-15 20:32:15 -04:00
```
2020-09-03 15:43:45 -04:00
mc encrypt info myminio/bucket/
Auto encryption 'sse-s3' is enabled
2018-12-14 16:35:48 -05:00
```
2021-06-25 11:12:40 -04:00
### Using environment (not-recommended)
2022-02-11 19:51:25 -05:00
2020-09-13 19:23:18 -04:00
MinIO automatically encrypts all objects on buckets if KMS is successfully configured and following ENV is enabled:
2022-02-11 19:51:25 -05:00
2020-09-13 19:23:18 -04:00
```
export MINIO_KMS_AUTO_ENCRYPTION=on
```
2020-09-03 15:43:45 -04:00
2020-09-13 19:23:18 -04:00
### Verify auto-encryption
2022-02-11 19:51:25 -05:00
2020-02-05 02:08:47 -05:00
> Note that auto-encryption only affects requests without S3 encryption headers. So, if a S3 client sends
> e.g. SSE-C headers, MinIO will encrypt the object with the key sent by the client and won't reach out to
2020-09-03 15:43:45 -04:00
> the configured KMS.
2020-02-05 02:08:47 -05:00
2020-09-03 15:43:45 -04:00
To verify auto-encryption, use the following `mc` command:
2018-12-14 19:21:41 -05:00
2019-07-15 20:32:15 -04:00
```
2020-05-19 21:33:11 -04:00
mc cp test.file myminio/bucket/
2018-12-14 19:21:41 -05:00
test.file: 5 B / 5 B ▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓ 100.00% 337 B/s 0s
2020-09-03 15:43:45 -04:00
```
2020-05-19 21:33:11 -04:00
2020-09-03 15:43:45 -04:00
```
2020-05-19 21:33:11 -04:00
mc stat myminio/bucket/test.file
2018-12-14 19:21:41 -05:00
Name : test.file
...
Encrypted :
X-Amz-Server-Side-Encryption: AES256
```
2022-03-29 12:53:33 -04:00
## Encrypted Private Key
MinIO supports encrypted KES client private keys. Therefore, you can use
2022-07-17 11:43:14 -04:00
an password-protected private keys for `MINIO_KMS_KES_KEY_FILE` .
2022-03-29 12:53:33 -04:00
When using password-protected private keys for accessing KES you need to
provide the password via:
2022-07-17 11:43:14 -04:00
2022-03-29 12:53:33 -04:00
```
export MINIO_KMS_KES_KEY_PASSWORD=< your-password >
2022-07-17 11:43:14 -04:00
```
2022-03-29 12:53:33 -04:00
Note that MinIO only supports encrypted private keys - not encrypted certificates.
Certificates are no secrets and sent in plaintext as part of the TLS handshake.
2020-02-05 02:08:47 -05:00
## Explore Further
2018-08-17 15:52:14 -04:00
2022-09-29 00:28:45 -04:00
- [Use `mc` with MinIO Server ](https://min.io/docs/minio/linux/reference/minio-mc.html )
- [Use `aws-cli` with MinIO Server ](https://min.io/docs/minio/linux/integrations/aws-cli-with-minio.html )
- [Use `minio-go` SDK with MinIO Server ](https://min.io/docs/minio/linux/developers/go/minio-go.html )
- [The MinIO documentation website ](https://min.io/docs/minio/linux/index.html )