StorageGRID provides several ways to encrypt your data at rest including the use of external key management servers. We have partnered with Entrust to add their KeyControl product to the lineup of supported Key management solutions for StorageGRID node encryption. KeyControl provides a highly available decentralized vault-based solution that is compliant with the Key Management Interoperability Protocol (KMIP). This makes KeyControl an excellent option for StorageGRID. For more information on KeyControl and to try it for yourself, please visit their website. For installation and configuration instructions please read the KeyControl online documentation. You should also read through the StorageGRID documentation relating to encryption and KMS configuration.
Let’s walk through a basic implementation with a single site StorageGRID solution containing a mix of virtual appliances and a physical appliance. Only the physical appliance will be encrypted with a key from two KeyControl servers.
Once you have chosen your KeyControl deployment method and have the desired number of clustered KeyControl server installed, it is time to create a new vault.
In KeyControl, this is as simple as clicking the “Create Vault” button
data:image/s3,"s3://crabby-images/e16cf/e16cf93ed06de8d29dca60a736ce0296ef655870" alt="aronk_0-1720708596273.png aronk_0-1720708596273.png"
Fill in the details for the vault.
- Choose “KMIP” for the Type of vault
- Give the vault a name
- Add an optional description
Provide an admin name and email (the Email address will be the login name)
Click on the create vault button and when the vault has been created, a window will pop up containing the link to the Vault URL, username, and a randomly generated temporary password. Make sure you copy out these items as you will need them for the remaining steps.
data:image/s3,"s3://crabby-images/f47f9/f47f981f784ff28c31c3e66b9540eb1a3c4d3f6d" alt="aronk_2-1720708596280.png aronk_2-1720708596280.png"
Open the Vault URL and login with the provided credentials. You will be prompted to set a new password and log in with the new password.
data:image/s3,"s3://crabby-images/dd5ee/dd5eecb3a65713dfbc5d7d13c13c53269757074d" alt="aronk_3-1720708596282.png aronk_3-1720708596282.png"
Once logged into the vault click on the large Security icon in the middle. And then on Client Certificates to create the certificate bundle required to authenticate StorageGRID to the KMS.
data:image/s3,"s3://crabby-images/28ded/28dedb85bae374960155e68b6ac2925b29c1d9d1" alt="aronk_4-1720708596284.png aronk_4-1720708596284.png"
data:image/s3,"s3://crabby-images/c5915/c59152f6656135f37599cde03b6a183cbfcf2b8e" alt="aronk_5-1720708596289.png aronk_5-1720708596289.png"
In the Client certificate window, click on the “+” to create a new certificate.
data:image/s3,"s3://crabby-images/2af28/2af28cf6ae1c21cef2cccc0e04b4068dbf3e8c0c" alt="aronk_6-1720708596290.png aronk_6-1720708596290.png"
In the Certificate creation window, provide a name for the certificate, and an expiration date. We will not have a CSR to upload and do not check the boxes for Authentication or Encryption. Click the Create button and the new certificate will be generated and appear in the Manage Client Certificate list.
data:image/s3,"s3://crabby-images/d6154/d6154785cffc9975d03c68370b4f5e47049bf404" alt="aronk_7-1720708596292.png aronk_7-1720708596292.png"
Select the new certificate and click on the download button. Unzip the certificate package and you will have two .pem files: cacert.pem and certificate_name.pem. The named certificate file is a combined certificate and key that will need to be separated out into individual files with the Key text (highlighted in blue) as a new file named certificate_name.key. The “Bag Attributes” and “Key Attributes” sections are optional.
data:image/s3,"s3://crabby-images/c8f0c/c8f0c534ec4149e1a7642022013436e09289d3e0" alt="aronk_8-1720708596317.png aronk_8-1720708596317.png"
We are now ready for the StorageGRID configuration. For an appliance to use node encryption with an external KMS, it must be set at the time the appliance is installed. From inside the installer UI, select the Node Encryption menu item under the Configure Hardware Tab, check the box to enable node encryption and save. Repeat this step for all nodes to be encrypted. The node is now ready to be joined to the StorageGRID solution.
data:image/s3,"s3://crabby-images/0c798/0c79821bb37375804fe977d6eae17df2152ccf8f" alt="aronk_9-1720708596318.png aronk_9-1720708596318.png"
data:image/s3,"s3://crabby-images/b3fb2/b3fb2ce0a36c550eb9ec588e880395ac8b40d994" alt="aronk_10-1720708596320.png aronk_10-1720708596320.png"
Once the node or nodes are all installed and part of the grid, you can now configure StorageGRID to use the KeyControl cluster for kms.
On the StorageGRID management UI under the Configuration tab, click on the Key management server menu item in the Security column.
data:image/s3,"s3://crabby-images/f0de9/f0de9a76a6ea6cdcccfe9499d15c8286e0911f81" alt="aronk_11-1720708596324.png aronk_11-1720708596324.png"
Click the Create button to add the new KeyControl KMS.
data:image/s3,"s3://crabby-images/4fdfa/4fdfaa63630cb1437de958d3a8c4d462f49886bb" alt="aronk_12-1720708596327.png aronk_12-1720708596327.png"
Under the details for the new KMS configuration. Provide a name to identify the KMS, an encryption key name (If one exists already in the KeyControl Vault that you wish to use, or this will be the name of the new key created by this process), what site should be managed by this KMS or all sites not managed by another configured KMS, the port should remain the default, and the hostnames or IP’s on the KeyControl servers in the cluster.
data:image/s3,"s3://crabby-images/dabed/dabed10583f2aadf442b1174eca3d6acc3dab402" alt="aronk_13-1720708596330.png aronk_13-1720708596330.png"
After the details have been entered click the continue button to get to the next page to upload the server certificate. This is the cacert.pem file that was provided by the KeyControl client certificate creation.
data:image/s3,"s3://crabby-images/3ec3f/3ec3f8a0ead4ff724d54e078ee3548f33370dd2f" alt="aronk_14-1720708596333.png aronk_14-1720708596333.png"
Once the certificate is successfully uploaded, click the continue button for the next page where we upload the client certificate and key files.
data:image/s3,"s3://crabby-images/9e627/9e6275aa42567e9747d68a7b47b60626601e5bbb" alt="aronk_15-1720708596336.png aronk_15-1720708596336.png"
The final step is to click the Test and save button. If all went well you should be greeted with a final window that informs you there is no existing key in the vault and a new key will be created.
data:image/s3,"s3://crabby-images/d7da0/d7da0a80521cd000c08c0434d4ee7d0a20b400da" alt="aronk_16-1720708596338.png aronk_16-1720708596338.png"
Once the key is created you will see the new KMS in the list with a certificate status unknown. After a few minutes this will update to show the certificates are valid.
data:image/s3,"s3://crabby-images/34908/3490886392a41908e937296d618cc25ff5538c58" alt="aronk_17-1720708596342.png aronk_17-1720708596342.png"
data:image/s3,"s3://crabby-images/0d6c0/0d6c0775b7c238fed024e614ebef809c62f6a218" alt="aronk_18-1720708596345.png aronk_18-1720708596345.png"
Clicking on the KMS name will bring up the information on the KMS. This is also where you can choose to rotate the keys.
data:image/s3,"s3://crabby-images/20fd5/20fd555e5f16fe1ad194559fb7cc2170942d5f79" alt="aronk_19-1720708596348.png aronk_19-1720708596348.png"
You can click on the Encrypted nodes tab and verify the nodes encrypted and the keys used.
data:image/s3,"s3://crabby-images/31e57/31e572cb22b5a62b210cdd8631c2eb9d9c29921f" alt="aronk_20-1720708596351.png aronk_20-1720708596351.png"
If we look in the KeyControl vault Objects, we see the keys in the vault and can compare to the StorageGRID keys in use.
data:image/s3,"s3://crabby-images/4130f/4130ffe185d278f4a96ad38b9f0ebadfb9cf3312" alt="aronk_21-1720708596353.png aronk_21-1720708596353.png"
data:image/s3,"s3://crabby-images/510a4/510a4aa3412e64f709a6512a4c0c8c5c7ddf3f4e" alt="aronk_22-1720708596354.png aronk_22-1720708596354.png"