-
Notifications
You must be signed in to change notification settings - Fork 4k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
aws-lambda: version resource name changing from v1 to v2 #20650
Comments
I don't think we changed anything about our hashing or name generation between versions, so it's strange to me that you're running into this We're in maintenance mode for v1, so since this isn't a major issue we won't be addressing it. You can work around this by overriding the logical ids of resources which are having their names changed. |
Which is why I've reported it! The documentation at https://docs.aws.amazon.com/cdk/v2/guide/migrating-v2.html says:
I am unable to re-deploy my app after upgrading from CDK v1 to CDK v2, hence my reporting this issue. At the moment, without making any code modifications, my only recourse is to destroy the stack and then do a new deploy of the stack, which results in a complete loss of the infrastructure during that process. I have, as required by the guidelines, provided a small (2 lines of code!) 100% reproducible example of the problem I'm having.
So are you proposing that I hack my code - for each deployment of the stack - to override the "wrong" logical ID with the logical ID that has already been deployed? Without knowing how many instances I've deployed ... ? Or are you proposing that there is a way for me to (a) see if the stack has already been deployed, (b) retrieve the logical ID of the resource if it has been deployed, (c) continue with the rest of the code and then (d) override the "wrong" ID with the old one? If so, can you please provide more guidance/example code? If I truly have to destroy existing deployments in order to upgrade to CDK v2 then perhaps AWS CDK is not the tool for me after all. |
The issue here is that I'm not able to reproduce the behavior you're seeing with the code you've provided.
I merely proposed a method which can work 🙂 I know it's far from ideal, but I figured it was worth mentioning since I knew it off the top of my head Are you able to reproduce this issue following your steps in a completely fresh project? |
Yes - I wrote the issue as I built the fresh project. I literally did what I wrote. I deployed the original code using CDK v1, followed the instructions to upgrade the code/stack to CDK v2 then attempted to deploy using v2. I should point out that if you deploy JUST using CDK v2, you won't see the problem. This only seems to be apparent when upgrading an existing stack that was deployed with v1.
That is worrying. I will go through it all again to make sure I haven't missed anything out or mistyped anything at my end. |
@peterwoodworth I've put together a git repository with two branches that definitely repros the issue: https://github.com/pcolmer/aws-cdk-20650 The If you still cannot reproduce it after that, then I don't know what to say. I'm open to running any extra commands or diagnostics if it helps unpack why the resource ID is getting changed. |
I see why you're running into this @pcolmer - This is where we calculate the logical ID - we actually override it ourselves - aws-cdk/packages/@aws-cdk/aws-lambda/lib/function.ts Lines 421 to 433 in ba91ca4
We override the last 32 characters based of the hash of the lambda function. The difference between your versions is only on the last 32 characters. I've also managed to reproduce this myself on my own TS library and also with your repo. The difference between v1 and v2 I think is due to the fact that the hash is based on the lambda function and its properties. There is a difference in how the S3key prop is built between the versions - but that's handled deep within our asset code
Without looking into it more I'm not super sure why there's a difference between versions. But this is what I've found so far |
@peterwoodworth Thank you for continuing to investigate and for sharing your findings so far. I am so relieved that you have been able to reproduce the problem now!
Ah! Upon re-reading the output from
and thinking that CDK was destroying I had completely misunderstood that output and now see that it is wanting to create Will you or someone on the CDK team be able to look into this further or is it something I've got to "live with" and just hack my code to get past the issue? |
@peterwoodworth @kaizencc would a feature flag for those coming from old versions help? or do we consider this a "This is a price you pay for updating"? |
@indrora This is definitely not a price that anyone is expecting to pay when they update, considering that the migration docs say:
I've been running into this issue myself. I'm still confused why the logical IDs are changing at all if neither the function configuration nor the function code have changed. @peterwoodworth do you have any other insight into that? |
This is a serious issue for us as well and prevents us from upgrading to v2. SecurityGroups get randomly removed and added back again with different names and various cross-stack references get renamed as well creating dead-locks prevents deployment of stacks. I would consider not being able to upgrade to v2 in scope. |
This is a known issue when migrating from CDK V1 to V2 and the workaround proposed here, seems to be the best options necessary to ensure that this issue is not a problem anymore. |
Describe the bug
Code that deploys a Lambda is generating a resource that references the current version. The name of that resource is changing when we migrate from CDK v1 to v2, resulting in CloudFormation wanting to destroy the existing resources but it can't because there are other stacks in the app that are dependent on those resources.
The only way I seem to be able to deploy the app using v2 CDK is to destroy it completely first which is undesirable.
Expected Behavior
I should be able to deploy/upgrade my app to v2 without problems and certainly without needing to destroy the entire deployment.
Current Behavior
Running
diff
results in the following:Reproduction Steps
hello-cdk
app.hello_cdk>hello_cdk_stack.py
thus:cdk1 deploy
pjctestheadersCurrentVersion6A41A374a584fa336027d0271a4c8a7f1566b8c0
cdk diff
This will produce output like this:
Note that setting
@aws-cdk/core:stackRelativeExports
tofalse
does not fix the issue.Possible Solution
None known.
Additional Information/Context
No response
CDK CLI Version
1.159.0 and 2.27.0
Framework Version
No response
Node.js Version
16.3.0
OS
Ubuntu 20.04.0
Language
Python
Language Version
No response
Other information
No response
The text was updated successfully, but these errors were encountered: