本文属于机器翻译版本。若本译文内容与英语原文存在差异,则一律以英文原文为准。
故障排除 AWS Secrets Manager
使用此处的信息可帮助您诊断和修复您在使用 Secrets Manager 时可能遇到的问题。
有关轮换的问题,请参阅 排除 AWS Secrets Manager 轮换故障。
主题
“访问被拒绝”消息
当你API拨打 Secrets GetSecretValue Manager 之类的电话时,你必须拥有拨打该电话的IAM权限。 CreateSecret 当您使用控制台时,控制台会代表您API拨打相同的呼叫,因此您还必须拥有IAM权限。管理员可以通过将IAM策略附加到您的IAM用户或您所属的群组来授予权限。如果授予这些权限的政策声明包含任何条件,例如 time-of-day或 IP 地址限制,则您在发送请求时也必须满足这些要求。有关查看或修改IAM用户、组或角色策略的信息,请参阅《IAM用户指南》中的使用策略。有关 Secrets Manager 所需权限的信息,请参阅 AWS Secrets Manager 的身份验证和访问控制。
如果您在不使用的情况下手动签署API请求,请验证您是否正确签署了请求。AWS SDKs
对于临时安全凭证的“拒绝访问”
请确认用于发出请求的 IAM 用户或角色具有正确的权限。临时安全凭证的权限来自于 IAM 用户或角色。这意味着,权限仅限于为 IAM 用户或角色授予的权限。有关如何确定临时安全证书权限的更多信息,请参阅IAM用户指南中的控制临时安全证书的权限。
确认已正确对请求进行签名,并且请求格式正确无误。有关详细信息,请参阅您选择的工具包
验证您的临时安全凭证没有过期。有关更多信息,请参阅IAM用户指南中的申请临时安全证书。
有关 Secrets Manager 所需权限的信息,请参阅 AWS Secrets Manager 的身份验证和访问控制。
并非始终立即显示我所做的更改。
Secrets Manager 使用名为最终一致性
在设计全球应用程序时应考虑到这些可能的延迟。此外,确保应用程序可以按预期工作,即使在一个位置进行的更改不能立即在其他位置可见。
有关最终一致性如何影响其他一些 AWS 服务的更多信息,请参阅:
-
Amazon Redshift 数据库开发人员指南中的管理数据一致性
-
Amazon Simple Storage Service 用户指南中的 Amazon S3 数据一致性模型
-
在 AWS 大数据博客中@@ 使用 Amazon S3 和 Amazon EMR 处理ETL工作流程时确保一致性
创建密钥时 “无法使用非对称KMS密钥生成数据密钥”
Secrets Manager 使用与密KMS钥关联的对称加密密钥为每个密钥值生成数据密钥。您不能使用非对称KMS密钥。确认您使用的是对称加密KMS密钥而不是非对称KMS密钥。有关说明,请参阅识别非对称KMS密钥。
O AWS CLI R AWS SDK 操作无法从部分内容中找到我的秘密 ARN
在许多情况下,Secrets Manager 可以从部分ARN而不是全部中找到你的秘密ARN。但是,如果你的密钥名称以连字符结尾,后面跟着六个字符,那么 Secrets Manager 可能无法仅从密钥的一部分中找到秘密。ARN相反,我们建议您使用密钥的完整名称ARN或名称。
更多详细信息
Secrets Manager 在机密名称的末尾包含六个随机字符,以帮助确保密钥的ARN唯一性。如果删除了原始密钥,然后使用相同的名称创建了新密钥,则ARNs由于这些字符,这两个密钥会有所不同。有权访问旧密钥的用户不会自动获得对新密钥的访问权限,因为两ARNs者不同。
Secr ARN ets Manager 使用区域、帐户、机密名称,然后是连字符和另外六个字符构造一个代表机密,如下所示:
arn:aws:secretsmanager:us-east-2:111122223333:secret:
SecretName
-abcdef
如果你的密钥名称以连字符和六个字符结尾,那么在 Secrets Manager ARN 看来,只使用其中一部分就好像你在指定完整名称一样。ARN例如,你可能有一个名MySecret-abcdef
为 ARN
arn:aws:secretsmanager:us-east-2:111122223333:secret:MySecret-abcdef-nutBrk
如果您调用以下操作,该操作仅使用部分密钥ARN,那么 Secrets Manager 可能找不到该密钥。
$
aws secretsmanager describe-secret --secret-id
arn:aws:secretsmanager:us-east-2:111122223333:secret:MySecret-abcdef
此密钥由 AWS 服务管理,您必须使用该服务对其进行更新。
如果您在尝试修改密钥时遇到此消息,则只能使用消息中列出的管理服务来更新密钥。有关更多信息,请参阅 由其他 AWS 服务托管的 AWS Secrets Manager 密钥。
要确定谁管理密钥,您可以查看密钥名称。由其他服务管理的密钥以该服务的 ID 作为前缀。或者,在中 AWS CLI,调用 d escribe-secret,然后查看该字段。OwningService
使用时 Python 模块导入失败 Transform:
AWS::SecretsManager-2024-09-16
如果您使用的是 Transform:,AWS::SecretsManager-2024-09-16
并且在轮换 Lambda 函数运行时遇到 Python 模块导入失败,则问题可能是由不兼容Runtime
的值引起的。使用此转换版本, AWS CloudFormation 可以为您管理运行时版本、代码和共享目标文件。你不需要自己管理这些。