我正在使用无服务器框架来部署和编程我的 aws lambda 函数,由于我的函数已准备好投入生产,我需要删除敏感密钥并决定使用 aws 系统管理器(ssm 参数存储)以安全的方式使用这些密钥,但在部署时,我收到以下与这些密钥的使用相关的错误消息。我认为这可能与我手动与 lambda 关联的 Iam 角色有关,但我不确定它会发生什么。
错误:
Serverless Information ----------------------------------
##########################################################################################
# 47555: 0 of 2 promises have settled
# 47555: 2 unsettled promises:
# 47555: ssm:mg-production-domain~true waited on by: undefined
# 47555: ssm:mg-production-api-key~true waited on by: undefined
# This can result from latent connections but may represent a cyclic variable dependency
##########################################################################################
YAML:
provider:
name: aws
runtime: nodejs10.x
stage: dev
region: us-east-1
environment:
MG_PRODUCTION_DOMAIN: ${ssm:mg-production-domain~true}
MG_PRODUCTION_API_KEY: ${ssm:mg-production-api-key~true}
这是我添加到 lambda 的 Iam 角色策略,但我相信通过 YAML 文件添加 Iam 角色可能有更好的方法:
{
"Version": "2012-10-17",
"Statement": [
{
"Sid": "VisualEditor0",
"Effect": "Allow",
"Action": "ssm:DescribeParameters",
"Resource": "*"
},
{
"Sid": "VisualEditor1",
"Effect": "Allow",
"Action": "ssm:GetParameters",
"Resource": "arn:aws:ssm:us-east-1:*account-id*:parameter/*"
},
{
"Sid": "VisualEditor2",
"Effect": "Allow",
"Action": "ssm:GetParameter",
"Resource": "arn:aws:ssm:us-east-1:*account-id*:parameter/*"
}
]
}