Skip to content
New issue

Have a question about this project? # for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “#”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? # to your account

feat(rds): change the default retention policy of Cluster and DB Instance #8023

Merged
merged 1 commit into from
Jun 1, 2020

Conversation

skinny85
Copy link
Contributor

Commit Message

feat(rds): change the default retention policy of Cluster and DB Instance

The 'Snapshot' retention policy is a special one used only for RDS.
It deletes the underlying resource, but before doing that,
creates a snapshot of it, so that the data is not lost.
Use the 'Snapshot' policy instead of 'Retain',
for the DatabaseCluster and DbInstance resources.

Fixes #3298

BREAKING CHANGE: the default retention policy for RDS Cluster and DbInstance is now 'Snapshot'

End Commit Message


By submitting this pull request, I confirm that my contribution is made under the terms of the Apache-2.0 license

@skinny85 skinny85 requested a review from nija-at May 16, 2020 01:21
@skinny85 skinny85 self-assigned this May 16, 2020
@mergify mergify bot added the contribution/core This is a PR that came from AWS. label May 16, 2020
@skinny85
Copy link
Contributor Author

@jogold I would love to get your opinion on this change as well!

@aws-cdk-automation
Copy link
Collaborator

AWS CodeBuild CI Report

  • CodeBuild project: AutoBuildProject6AEA49D1-qxepHUsryhcu
  • Commit ID: 419dd37
  • Result: SUCCEEDED
  • Build Logs (available for 30 days)

Powered by github-codebuild-logs, available on the AWS Serverless Application Repository

@jogold
Copy link
Contributor

jogold commented May 16, 2020

@jogold I would love to get your opinion on this change as well!

Looks good. I just wonder if this change would better fit in core/cfn-resource.ts as SNAPSHOT is supported also by other resources (ec2 volumes, elasticache, neptune and redshift)?

/**
* Sets the deletion policy of the resource based on the removal policy specified.
*/
public applyRemovalPolicy(policy: RemovalPolicy | undefined, options: RemovalPolicyOptions = {}) {

@skinny85 skinny85 added the pr-linter/exempt-readme The PR linter will not require README changes label May 18, 2020
@skinny85
Copy link
Contributor Author

@jogold thanks, you're probably right. Let me try to add the changes needed in @aws-cdk/core to this PR.

I wanted to also ask you about the behavior for DbInstance's retention policies. This is what the CloudFormation documentation says on the subject:

  1. For AWS::RDS::DBInstance resources that don't specify the DBClusterIdentifier property, AWS CloudFormation saves a snapshot of the DB instance.

  2. For AWS::RDS::DBInstance resources that do specify the DBClusterIdentifier property, AWS CloudFormation deletes the DB instance.

However, in the current PR, I actually change that behavior: in the DatabaseCluster construct, I assign Snapshot retention to the created DbInstance resources, even though they all have the dbClusterIdentifier filled. Same in the DatabaseInstance construct: if the removalPolicy was not passed explicitly in the props, I set it always to Snapshot.

What is your opinion on this? Do the changes make sense to you, or should we instead by default simply have the same behavior CloudFormation has?

@jogold
Copy link
Contributor

jogold commented May 19, 2020

Cluster

  • For the cluster you are going back to the CF default, which is Snapshot
  • For the instances you are forcing to Snapshot but you could do the same as for the cluster?

Stand-alone instance

You are going from forcing Retain to forcing Snapshot if unspecified.

For me Snapshot is as safe as Retain but cheaper. It's not identical in terms of availability but I think it's a good compromise.

@skinny85
Copy link
Contributor Author

@jogold thanks for the response. Some clarifications below:

Cluster

  • For the cluster you are going back to the CF default, which is Snapshot

Yes.

  • For the instances you are forcing to Snapshot but you could do the same as for the cluster?

For instances created inside DatabaseCluster, we are forcing Snapshot, which is not the CloudFormation default (because the AWS::RDS::DBInstance resources created inside DatabaseCluster have the DBClusterIdentifier property always filled, the CloudFormation default for them is actually Delete, like I mentioned here: #8023 (comment) ).

Stand-alone instance

You are going from forcing Retain to forcing Snapshot if unspecified.

For me Snapshot is as safe as Retain but cheaper. It's not identical in terms of availability but I think it's a good compromise.

Right. Here's my question then:

  • I'm always forcing Snapshot for DatabaseInstance, even if they have the dBClusterIdentifier property filled. Is that correct? Is it even possible for DatabaseInstance that is not created inside DatabaseCluster to have the dBClusterIdentifier property set? (I can't easily tell from the code whether that's possible or not)

Would appreciate your thoughts on this topic!

@jogold
Copy link
Contributor

jogold commented May 20, 2020

  • For the instances you are forcing to Snapshot but you could do the same as for the cluster?

For instances created inside DatabaseCluster, we are forcing Snapshot, which is not the CloudFormation default (because the AWS::RDS::DBInstance resources created inside DatabaseCluster have the DBClusterIdentifier property always filled, the CloudFormation default for them is actually Delete, like I mentioned here: #8023 (comment) ).

Sorry for the confusion, the same here meant going back to CF default. Since we have Snapshot on the cluster, I'm not sure we need it on the instance. But let me check that again.

Is it even possible for DatabaseInstance that is not created inside DatabaseCluster to have the dBClusterIdentifier property set?

It's not possible for a DatabaseInstance (L2) to have the dBClusterIdentifier property. Instances created in a cluster use the L1 CfnDBInstance. This actually means that we could use the CF default for a DatabaseInstance. But looking again at the doc now I see that those defaults apply only to the DeletionPolicy and not to the UpdateReplacePolicy. For stand alone instances this is critical because a change in any property that requires a replacement could lead to data loss. The right solution for stand-alone instances seems to be: use CF default for DeletionPolicy (= Snapshot), force Snapshot for UpdateReplacePolicy. The core method applyRemovalPolicy currently doesn't handle this case.

packages/@aws-cdk/aws-rds/lib/cluster.ts Outdated Show resolved Hide resolved
packages/@aws-cdk/aws-rds/lib/instance.ts Outdated Show resolved Hide resolved
@skinny85 skinny85 force-pushed the feat/rds-snapshot-retention-policy branch from 419dd37 to 5a32b1a Compare May 21, 2020 22:57
@skinny85 skinny85 requested a review from nija-at May 21, 2020 22:58
@skinny85
Copy link
Contributor Author

@jogold @nija-at thanks a lot for your comments. I've incorporated all of your feedback in the newest revision. Please re-review when you have the chance!

@aws-cdk-automation
Copy link
Collaborator

AWS CodeBuild CI Report

  • CodeBuild project: AutoBuildProject6AEA49D1-qxepHUsryhcu
  • Commit ID: 5a32b1a
  • Result: SUCCEEDED
  • Build Logs (available for 30 days)

Powered by github-codebuild-logs, available on the AWS Serverless Application Repository

Copy link
Contributor

@nija-at nija-at left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Should this be a 'feat' change, i.e, do we want this listed in the 'Features' section of the changelog? I usually mark these as 'chore'. (breaking changes callout will be picked up either way)

Added 'do-not-merge' to address some comments here.

packages/@aws-cdk/aws-rds/lib/cluster.ts Outdated Show resolved Hide resolved
@nija-at nija-at added the pr/do-not-merge This PR should not be merged at this time. label May 22, 2020
…ance to Snapshot

The 'Snapshot' retention policy is a special one used only for RDS.
It deletes the underlying resource, but before doing that,
creates a snapshot of it, so that the data is not lost.
Use the 'Snapshot' policy instead of 'Retain',
for the DatabaseCluster and DbInstance resources.

Fixes aws#3298

BREAKING CHANGE: the default retention policy for RDS Cluster and DbInstance is now 'Snapshot'
@skinny85 skinny85 force-pushed the feat/rds-snapshot-retention-policy branch from 5a32b1a to 0351e7c Compare June 1, 2020 19:01
@aws-cdk-automation
Copy link
Collaborator

AWS CodeBuild CI Report

  • CodeBuild project: AutoBuildProject6AEA49D1-qxepHUsryhcu
  • Commit ID: 0351e7c
  • Result: SUCCEEDED
  • Build Logs (available for 30 days)

Powered by github-codebuild-logs, available on the AWS Serverless Application Repository

@skinny85 skinny85 merged commit 2d83328 into aws:master Jun 1, 2020
@skinny85 skinny85 deleted the feat/rds-snapshot-retention-policy branch June 1, 2020 20:09
@skinny85 skinny85 added this to the RDS to 'developer preview' milestone Jul 8, 2020
# for free to join this conversation on GitHub. Already have an account? # to comment
Labels
contribution/core This is a PR that came from AWS. pr/do-not-merge This PR should not be merged at this time. pr-linter/exempt-readme The PR linter will not require README changes
Projects
None yet
Development

Successfully merging this pull request may close these issues.

RDS: Missing default Snapshot deletion policy
4 participants