Skip to main content
CRITICALRDSSecurity

RDS Publicly Accessible

rds-publicly-accessible

What this rule checks

Detects RDS instances that are publicly accessible.

How to fix it

  1. 1Set PubliclyAccessible to false
  2. 2Use VPC security groups to control access
  3. 3Access databases through bastion hosts or VPN
FlaggedpubliclyAccessible true with a public subnet gives the database a routable endpoint reachable from the internet.
import { aws_ec2 as ec2, aws_rds as rds } from 'aws-cdk-lib';

const vpc = new ec2.Vpc(this, 'Vpc');

new rds.DatabaseInstance(this, 'Db', {
  engine: rds.DatabaseInstanceEngine.postgres({ version: rds.PostgresEngineVersion.VER_16 }),
  vpc,
  vpcSubnets: { subnetType: ec2.SubnetType.PUBLIC },
  publiclyAccessible: true,
});
FixedThe instance sits in private subnets with publiclyAccessible false, so it is reachable only from inside the VPC.
import { aws_ec2 as ec2, aws_rds as rds } from 'aws-cdk-lib';

const vpc = new ec2.Vpc(this, 'Vpc');

new rds.DatabaseInstance(this, 'Db', {
  engine: rds.DatabaseInstanceEngine.postgres({ version: rds.PostgresEngineVersion.VER_16 }),
  vpc,
  vpcSubnets: { subnetType: ec2.SubnetType.PRIVATE_WITH_EGRESS },
  publiclyAccessible: false,
});

CDK Insights pinpoints the exact file and line in your CDK source for every finding, so you can jump straight to the fix.

Affected resource types

AWS::RDS::DBInstance

Compliance frameworks

SOC2HIPAAPCI-DSSCISNIST

AWS documentation

Read the AWS guidance

Intentional? Suppress this finding

Sometimes a flag is deliberate โ€” a genuinely public endpoint, say. You can dismiss rds-publicly-accessible and the reason is kept in the report, not silently hidden.

In .cdk-insights.json:

{
  "ignoreRules": [
    { "id": "rds-publicly-accessible", "reason": "Why this is intentional" }
  ]
}

Or inline in your CDK code:

Validations.of(scope).acknowledge({
  id: 'cdk-insights::rds-publicly-accessible',
  reason: 'Why this is intentional',
});

Use the rule ID rds-publicly-accessible shown above โ€” not the CDK-* ID from SARIF / GitHub code scanning. To dismiss every finding on one construct instead, use ignorePaths. Suppression docs โ†’

Catch this in your stack

$ npx cdk-insights scan

CDK Insights runs this and 118+ other rules locally against your synthesised CDK app โ€” free, no account, your code never leaves your machine.

More RDS rules