Using unencrypted RDS DB resources exposes data to unauthorized access to the underlying storage.
This includes database data, logs, automatic
backups, read replicas, snapshots, and cluster metadata.
This situation can occur in a variety of scenarios, such as:
AWS-managed encryption at rest reduces this risk with a simple switch.
There is a risk if you answered yes to any of those questions.
It is recommended to enable encryption at rest on any RDS DB resource, regardless of the engine.
In any case, no further maintenance is
required as encryption at rest is fully managed by AWS.
For AWS::RDS::DBInstance and AWS::RDS::DBCluster:
AWSTemplateFormatVersion: '2010-09-09'
Resources:
DatabaseInstance:
Type: AWS::RDS::DBInstance
Properties:
StorageEncrypted: false # Sensitive, disabled by default
DatabaseCluster:
Type: AWS::RDS:DBCluster:
Properties:
StorageEncrypted: false # Sensitive, disabled by default
For AWS::RDS::DBInstance and AWS::RDS::DBCluster:
AWSTemplateFormatVersion: '2010-09-09'
Resources:
DatabaseInstance:
Type: AWS::RDS::DBInstance
Properties:
StorageEncrypted: true
DatabaseCluster:
Type: AWS::RDS:DBCluster:
Properties:
StorageEncrypted: false # Sensitive, disabled by default