diff --git a/docs/kms/README.md b/docs/kms/README.md index 394b42204..30c0d4a7b 100644 --- a/docs/kms/README.md +++ b/docs/kms/README.md @@ -14,15 +14,15 @@ MinIO supports two different KMS concepts: - Direct KMS master keys: MinIO can also be configured to directly use a master key specified by the environment variable `MINIO_SSE_MASTER_KEY`. Direct master keys are useful if the storage backend is not on the same machine as the MinIO server, e.g., - if network drives or MinIO gateway is used and an external KMS would cause too much management overhead. - + if network drives or MinIO gateway is used and an external KMS would cause too much management overhead. + Note: KMS master keys are mainly for testing purposes. It's not recommended to use them for production deployments. Further if the MinIO server machine is ever compromised, then the master key must also be treated as compromised. -**Important:** +**Important:** If multiple MinIO servers are configured as [gateways](https://github.com/minio/minio/blob/master/docs/gateway/README.md) pointing to the *same* backend - for example the same NAS storage - then the KMS configuration **must** be the same for -all gateways. Otherwise one gateway may not be able to decrypt objects created by another gateway. It is the operators' +all gateways. Otherwise one gateway may not be able to decrypt objects created by another gateway. It is the operators' responsibility to ensure consistency. ## Get started @@ -36,47 +36,135 @@ Either use Hashicorp Vault as external KMS or specify a master key directly depe #### 2.1 Setup Hashicorp Vault -Here is a sample quick start for configuring vault with a transit backend and Approle with correct policy +Here is a sample quick start for configuring vault with a transit backend and Approle with correct policy MinIO requires the following Vault setup: - The [transit backend](https://www.vaultproject.io/api/secret/transit/index.html) configured with a named encryption key-ring - [AppRole](https://www.vaultproject.io/docs/auth/approle.html) based authentication with read/update policy for transit backend. In particular, read and update policy are required for the [Generate Data Key](https://www.vaultproject.io/api/secret/transit/index.html#generate-data-key) endpoint and [Decrypt Data](https://www.vaultproject.io/api/secret/transit/index.html#decrypt-data) endpoint. -**2.1.1 Start Vault server in dev mode** - -In dev mode, Vault server runs in-memory and starts unsealed. Note that running Vault in dev mode is insecure and any data stored in the Vault is lost upon restart. +**2.1.1 Start Vault server** +Vault requires access to `mlock` syscall by default. Use `setcap` to give the Vault executable the ability to use the `mlock` syscall without running the process as root. To do so run: ``` -vault server -dev +sudo setcap cap_ipc_lock=+ep $(readlink -f $(which vault)) ``` -**2.1.2 Set up vault transit backend and create an app role** +Create `vault-config.json` to use file backend and start the server. +``` +cat > vault-config.json < NOTE: In this example we use `"tls_disable": true` for demonstration purposes only, +> in production setup you should generate proper TLS certificates by specifying +> - [`tls_cert_file`](https://www.vaultproject.io/docs/configuration/listener/tcp.html#tls_cert_file) +> - [`tls_key_file`](https://www.vaultproject.io/docs/configuration/listener/tcp.html#tls_key_file) + + +**2.1.2 Initialize vault and unseal it** ``` +export VAULT_ADDR='http://127.0.0.1:8200' +vault operator init +Unseal Key 1: eyW/+8ZtsgT81Cb0e8OVxzJAQP5lY7Dcamnze+JnWEDT +Unseal Key 2: 0tZn+7QQCxphpHwTm6/dC3LpP5JGIbYl6PK8Sy79R+P2 +Unseal Key 3: cmhs+AUMXUuB6Lzsvgcbp3bRT6VDGQjgCBwB2xm0ANeF +Unseal Key 4: /fTPpec5fWpGqWHK+uhnnTNMQyAbl5alUi4iq2yNgyqj +Unseal Key 5: UPdDVPto+H6ko+20NKmagK40MOskqOBw4y/S51WpgVy/ + +Initial Root Token: s.zaU4Gbcu0Wh46uj2V3VuUde0 + +Vault is initialized with 5 key shares and a key threshold of 3. Please securely +distribute the key shares printed above. When the Vault is re-sealed, +restarted, or stopped, you must supply at least 3 of these keys to unseal it +before it can start servicing requests. + +Vault does not store the generated master key. Without at least 3 key to +reconstruct the master key, Vault will remain permanently sealed! + +It is possible to generate new unseal keys, provided you have a quorum of +existing unseal keys shares. See "vault operator rekey" for more information. +``` + +Use any of the previously generated keys to unseal the vault +``` +vault operator unseal eyW/+8ZtsgT81Cb0e8OVxzJAQP5lY7Dcamnze+JnWEDT +vault operator unseal 0tZn+7QQCxphpHwTm6/dC3LpP5JGIbYl6PK8Sy79R+P2 +vault operator unseal cmhs+AUMXUuB6Lzsvgcbp3bRT6VDGQjgCBwB2xm0ANeF +Key Value +--- ----- +Seal Type shamir +Initialized true +Sealed false ---> NOTE: vault is unsealed +Total Shares 5 +Threshold 3 +Version 1.1.3 +Cluster Name vault-cluster-3f084948 +Cluster ID 8c92e999-7062-4da6-4434-0fc05f34824d +HA Enabled false +``` + +Obtain root token from the `vault operator init` output above. It is displayed as `Initial Root Token: s.zaU4Gbcu0Wh46uj2V3VuUde0` + +**2.1.3 Set up vault transit backend and create an app role** +``` +export VAULT_TOKEN=s.zaU4Gbcu0Wh46uj2V3VuUde0 + +vault auth enable approle # enable approle style auth +vault secrets enable transit # enable transit secrets engine +# define an encryption key-ring for the transit path +vault write -f transit/keys/my-minio-key + cat > vaultpolicy.hcl <