I’ve got a DynamoDB resource with DeletionPolicy: Retain, i wanted to rename this table which I expected would create a new table with the new name and leave the old one intact, however it’s deleting the old one.
The deletion policy only applies when you delete the the resource (or stack, which contains the resource).
If you rename the table, then you get the behaviour described in the docs: replacement
The only thing that might work (not that I’ve tested it) it would be to rename the logical resource (i.e. companiesTable in this case) and the table name at the same time…
@rowanu AWS doesn’t supports renaming DynamoDB tables. If you’re renaming a table in your serverless.yml, which is what I assume @msingleton is doing, then you’re really deleting the old table and creating a new one.
Even with DelectionPolicy: Retain you still see CloudFormation report the table has been deleted but in the DynamoDB console the table is still there. That’s why I think the delete message is in reference to deleting it from the CloudFormation stack and not actually deleting the resource.
Yeah. A common pattern is to manage it in a different stack i.e. a resource-only stack. You can still use SLS to provision it, even if the service doesn’t have any functions.
@msingleton Was the application deployed with DeletionPolicy: Retainbefore you renamed then table? I’ve done this many times and it’s always worked for me but if you added the DeletionPolicy and renamed in the same deploy then it makes sense that it would still delete the old table.
@buggy the initial application was deployed without deletion policy. I added it after renaming, then renamed a few more times to test and it deleted every time.
Possibly if I rename the resource in the config file and deploy it with Retain, it may work