一般来说,访问和解密 AWS SSM 参数存储值需要这 3 个权限:
ssm:DescribeParameters
ssm:GetParameters
kms:Decrypt
-
这是一个真实世界的示例,它只允许访问与我的 lambda 函数相关的 SSM 参数(通过遵循通用命名约定/模式来区分) - 它在以下情况下有效:
- SecureString 值使用默认的 AWS SSM 加密密钥进行加密。
-
所有参数都使用以下命名约定
一个。 /${app-name-or-app-namespace}/serverless/${lambda-function-name/then/whatever/else/you/want
b.${lambda-function-name}必须以sls-开头
假设我有一个名为 myCoolApp 的应用程序和一个名为 sls-myCoolLambdaFunction 的 Lambda 函数。也许我想保存数据库配置值,例如用户名和密码。
我将创建两个 SSM 参数:
/myCoolApp/serverless/sls-myCoolLambdaFunction/dev/database/username(明文)
/myCoolApp/serverless/sls-myCoolLambdaFunction/dev/database/password(安全字符串)
{
"Version": "2012-10-17",
"Statement": [
{
"Effect": "Allow",
"Action": [
"ssm:DescribeParameters"
],
"Resource": [
"arn:aws:ssm:${region-or-wildcard}:${aws-account-id-or-wildcard}:*"
]
},
{
"Effect": "Allow",
"Action": [
"ssm:GetParameter"
],
"Resource": [
"arn:aws:ssm:${region-or-wildcard}:${aws-account-id-or-wildcard}:parameter/myCoolApp/serverless/sls-*"
]
},
{
"Effect": "Allow",
"Action": [
"kms:Decrypt"
],
"Resource": [
"arn:aws:kms:*:${aws-account-id}:key/alias/aws/ssm"
]
}
]
}
然后在我的 serverless.yml 文件中,我可能会像这样引用这两个 SSM 值作为函数级环境变量
environment:
DATABASE_USERNAME: ${ssm:/myCoolApp/serverless/sls-myCoolLambdaFunction/dev/database/username}
DATABASE_PASSWORD: ${ssm:/myCoolApp/serverless/sls-myCoolLambdaFunction/dev/database/password~true}
或者,更好的是,如果我想在不同阶段有不同配置值的情况下变得超级动态,我可以像这样设置环境变量
environment:
DATABASE_USERNAME: ${ssm:/myCoolApp/serverless/sls-myCoolLambdaFunction/${self:provider.stage}/database/username}
DATABASE_PASSWORD: ${ssm:/myCoolApp/serverless/sls-myCoolLambdaFunction/${self:provider.stage}/database/password~true}
对于上述示例,如果我有两个阶段 - dev 和 prod,也许我会创建以下 SSM 参数:
/myCoolApp/serverless/sls-myCoolLambdaFunction/dev/database/username(明文)
/myCoolApp/serverless/sls-myCoolLambdaFunction/dev/database/password(安全字符串)
/myCoolApp/serverless/sls-myCoolLambdaFunction/prod/database/username(明文)
/myCoolApp/serverless/sls-myCoolLambdaFunction/prod/database/password(安全字符串)