- Newest
- Most votes
- Most comments
Hello,
If you’re trying to make cold starts quicker or prevent cold starts by running code in your handler’s initialization code during the provisioned concurrency boot the code looks fine.
For your handler, since all methods of the client can be suspended, you’ll need a runBlocking around the entire handler logic. The handler should be synchronous because anything that has not finished executing before the handler returns will be frozen until the Lambda is re-triggered (or may never re-run if the lambda shuts down before being retriggered since it’s never guaranteed you’ll re-invoke the same lambda execution environment).
If you peek at this link, AWS Lambda execution environment - Shutdown phase - https://docs.aws.amazon.com/lambda/latest/dg/lambda-runtime-environment.html#runtimes-lifecycle-shutdown , it mentions the following:
• Background processes or callbacks that were initiated by your Lambda function and did not complete when the function ended resume if Lambda reuses the execution environment. Make sure that any background processes or callbacks in your code are complete before the code exits.
As far as any Kotlin specific questions, I’d recommend getting consults from the Kotlin SDK Team on GitHub: https://github.com/awslabs/aws-sdk-kotlin . You’ll get the information directly from the source there!
It’s currently in developer preview and not intended for production workloads, so if you’re running into issues that don’t operate with exact parity as other AWS SDKs, this could be why and we’d certainly like to hear about it by having a GitHub issue raised: https://github.com/awslabs/aws-sdk-kotlin/issues
Relevant content
- asked 2 years ago
- asked 2 years ago
- AWS OFFICIALUpdated 8 months ago
- AWS OFFICIALUpdated 3 years ago
- AWS OFFICIALUpdated 3 years ago