Importing Existing RDS Instance into AWS CDK Stack

0

We have previously deployed an RDS instance manually through the AWS console. We now want to manage this instance using AWS CDK for IaC benefits.

Problem

When trying to import the existing RDS instance into a CDK stack (either new or existing), I encounter the error: "The following resource types are not supported for resource import: AWS::SecretsManager::SecretTargetAttachment"

I'm following the AWS CDK import documentation: import existing resources into AWS CDK Stacks Enter image description here

Questions

How can I successfully import my existing RDS instance into my CDK stack? Are there workarounds for the AWS::SecretsManager::SecretTargetAttachment error?

My cdk stack is

export default class VpcStack extends cdkl.Stack {
  constructor(scope: Construct, id: string, props: cdkl.StackProps) {
    super(scope, id, props);
    let gvars = util.getGvars(this)
    new s3.Bucket(this, 'MyExampleBucket');

  // defining existing rds cluster with exactly same configuration
  const pvtdbkey = secretsmanager.Secret.fromSecretNameV2(this, 'pvtdbki', 'pvtdbki');

    let instanceType = ec2.InstanceType.of(ec2.InstanceClass.T3, ec2.InstanceSize.MEDIUM)
    let instances: number | undefined = 1; // By default, create a cluster with only one writer instance
    const ParameterGroup = rds.ParameterGroup.fromParameterGroupName(this, 'DefaultParameterGroup', 'default.aurora-mysql8.0');
    const backup = {
      retention: cdkl.Duration.days(1),
      preferredWindow: '06:15-06:45', 
    }

    const pvtdb = new rds.DatabaseCluster(this, 'ffdev', {
      clusterIdentifier: 'ffdev-cluster',
      engine: rds.DatabaseClusterEngine.auroraMysql({ version: rds.AuroraMysqlEngineVersion.VER_3_06_0 }),
      credentials: rds.Credentials.fromSecret(pvtdbkey),
      port: 6549,
      instances,
      instanceProps: {
        vpc: gvars.vpc,
        instanceType,
        vpcSubnets: { subnetType: ec2.SubnetType.PRIVATE_ISOLATED },
        securityGroups: [gvars.pvtdbsg]
      },
      parameterGroup: ParameterGroup,
      backup,
      removalPolicy: cdkl.RemovalPolicy.RETAIN
    })

1 Answer
0

Hi

According to AWS CloudFormation documentation, AWS CloudFormation supports resource import for public (AWS) resources and private resource types that are provisionable.

However, there is no mention of explicit support for importing AWS::SecretsManager::SecretTargetAttachment resource.

But there is workaround trail :)

  • Use the cdk import command to import the existing RDS instance into your CDK stack. This will create a CloudFormation template that references the existing RDS instance by its unique identifier (ARN).
  • After importing the RDS instance, define the secretsmanager.SecretTargetAttachment resource within your CDK code. This code will recreate the attachment between the Secret Manager secret and the RDS instance.

For more information Import https://aws.amazon.com/blogs/devops/how-to-import-existing-resources-into-aws-cdk-stacks/

profile picture
EXPERT
answered 4 months ago

You are not logged in. Log in to post an answer.

A good answer clearly answers the question and provides constructive feedback and encourages professional growth in the question asker.

Guidelines for Answering Questions