Overview of Db2 native encryption
Db2® native encryption uses a two-tier approach to data encryption. Data is encrypted with a Data Encryption Key (DEK), which is in turn encrypted with a Master Key (MK). The encrypted DEK is stored with the data while the MK is stored in a keystore external to Db2.
Db2 native encryption ensures that the DEK is never exposed outside of the encrypted database, transaction log, or backup file. There are no interfaces provided to access the DEK in either its clear text or encrypted forms. As the MK is stored in a different location from the encrypted data, the chance of the encrypted DEK being concurrently exposed with the MK used to encrypt it is very unlikely. Since the risk of the DEK being exposed is extremely low, the need to rotate it is negligible. The rotation of the MK, which is used to protect the DEK, can be done efficiently without the need to decrypt and re-encrypt the data
Data Encryption Key (DEK)
Db2 encrypts data with a data encryption key (DEK) before the data is written to disk. The DEK is stored, encrypted by the master key (MK), within the database or backup image. The DEK itself is generated by Db2 as needed, such as when an encrypted database or encrypted database backup is created. A unique DEK exists for each encrypted database and for each encrypted backup.
Master Key (MK)
- Database creation
- Master key rotation
- Restoring into a new database
- tracking the MK labels and their corresponding keys for offsite recovery without having the entire keystore available on the backup site
- having an HADR pair that requires synchronized keys
- encrypting a backup for an unencrypted database
Keystore
Master keys are stored in a keystore. A keystore can be a file that is directly accessed by Db2 (local) or a third-party keystore with which Db2 communicates over the network (centralized).
Keystores supported by Db2
- A local keystore file that follows the Public Key Cryptography Standards (PKCS) #12 archive file
format for storing cryptography objects Note: PKCS is an OASIS standard for public key cryptography. The numbers 11 and 12 refer to specific parts of the standard.
- A centralized keystore that is accessed using one of the following methods:
- Any key manager product that supports Key Management Interoperability Protocol (KMIP) version
1.1 or higher. A key manager is software that you can use to create, update, and secure a keystore.
Note: KMIP is an OASIS standard for network protocol that is related to key management.
- One of the following supported Hardware Security Modules (HSM) that use the PKCS #11 API:
- Gemalto Safenet HSM (formerly Luna) version 6.1 (firmware version 6.23.0) and higher
- Thales nShield HSM, security world software version 11.50 and higher
- Any key manager product that supports Key Management Interoperability Protocol (KMIP) version
1.1 or higher. A key manager is software that you can use to create, update, and secure a keystore.
MKs and the keystore
An MK can either be created directly within the keystore or generated by Db2, upon request, and stored within the keystore. One or more MKs can exist and each MK can be referenced by different Db2 databases or backup images.