By using AWS re:Post, you agree to the Terms of Use
/Do we need Lambda extensions for accessing AWS Secrets Manager ?/

Do we need Lambda extensions for accessing AWS Secrets Manager ?


Do we need Lambda extensions for accessing AWS Secrets Manager ? I explored Vault, Lambda provides vault extensions, which can optimize the secrets fetching -

The extension can retrieve multiple secrets from Vault, if configured to do so, and writes the full JSON response from HashiCorp Vault to the configured destination. Before a Lambda function is invoked, extensions are initialized and given the opportunity to perform tasks before signaling their readiness

Do we need similar setup in AWS Secrets Manager ? Or Fetching secrets from AWS Secret Manager already optimised for Lambda ?

3 Answers

In order to access secrets manager you only need to define the security policy in your lambda and it should then be able to access it from your code.

More info here

answered 18 days ago
  • I understand, will it cause any performance issues while getting the secrets for every invocation ? I see that the Lambda extensions for vault does some work before lambda gets initialised.


You do not need a Lambda extension to retrieve a secret from AWS Secrets Manager in a serverless workload. You should retrieve the secret as a global variable, not in the handler, to maximize performance. To learn more, see

answered 18 days ago

This link - provides a way to run local host to cache the secrets.

This setup is not necessary at all the times. Accessing Secrets Manager from Lambda can be done via the boto3 API, but the pattern above is considered best practice as it prevent cold start, increase speed of retrieval and keep the costs for Secrets Manager access low (in cases where you expect a lot of invocations).

answered 16 days 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