对 Amazon Systems Manager 进行身份和访问管理
Amazon Identity and Access Management(IAM)是一项 Amazon Web Services 服务,可以帮助管理员安全地控制对 Amazon 资源的访问。IAM 管理员控制谁可以通过身份验证(登录)和授权(具有权限)来使用 Systems Manager 资源。IAM 是一项无需额外费用即可使用的 Amazon Web Services 服务。
受众
您使用 Amazon Identity and Access Management(IAM)的方式因您的角色而异:
-
服务用户:如果您无法访问功能,请从管理员处请求权限(请参阅对 Amazon Systems Manager 身份和访问进行故障排除)
-
服务管理员:确定用户访问权限并提交权限请求(请参阅 Amazon Systems Manager 如何与 IAM 协同工作)
-
IAM 管理员:编写用于管理访问权限的策略(请参阅 Amazon Systems Manager 基于身份的策略示例)
使用身份进行身份验证
身份验证是您使用身份凭证登录 Amazon 的方法。您必须作为 Amazon Web Services 账户根用户、IAM 用户或通过代入 IAM 角色进行身份验证。
对于编程访问,Amazon 提供了 SDK 和 CLI 来对请求进行加密签名。有关更多信息,请参阅《IAM 用户指南》中的适用于 API 请求的 Amazon 签名版本 4。
Amazon Web Services 账户根用户
当您创建 Amazon Web Services 账户时,最初使用的是一个对所有 Amazon Web Services 服务和资源拥有完全访问权限的登录身份(称为 Amazon Web Services 账户根用户)。强烈建议您不要使用根用户执行日常任务。有关需要根用户凭证的任务,请参阅《IAM 用户指南》中的需要根用户凭证的任务。
IAM 用户和群组
IAM 用户是对单个人员或应用程序具有特定权限的身份。我们建议使用临时凭证,而非具有长期凭证的 IAM 用户。有关更多信息,请参阅《IAM 用户指南》中的要求人类用户使用带有身份提供商的联合身份验证才能使用临时凭证访问 Amazon。
IAM 组指定一组 IAM 用户,便于对大量用户进行权限管理。有关更多信息,请参阅《IAM 用户指南》中的 IAM 用户的使用案例。
IAM 角色
IAM 角色是具有特定权限的身份,可提供临时凭证。您可以通过从用户切换到 IAM 角色(控制台)或调用 Amazon CLI 或 Amazon API 操作来代入角色。有关更多信息,请参阅《IAM 用户指南》中的担任角色的方法。
IAM 角色对于联合用户访问、临时 IAM 用户权限、跨账户访问、跨服务访问以及在 Amazon EC2 上运行的应用程序非常有用。有关更多信息,请参阅《IAM 用户指南》中的 IAM 中的跨账户资源访问。
使用策略管理访问
您将创建策略并将其附加到 Amazon 身份或资源,以控制 Amazon 中的访问。策略定义与身份或资源关联时的权限。当主体发出请求时,Amazon 将评估这些策略。大多数策略在 Amazon 中存储为 JSON 文档。有关 JSON 策略文档的更多信息,请参阅《IAM 用户指南》中的 JSON 策略概述。
管理员使用策略,通过定义哪个主体可以对什么资源以及在什么条件下执行操作,来指定谁有权访问什么内容。
默认情况下,用户和角色没有权限。IAM 管理员创建 IAM 策略并将其添加到角色中,然后用户可以代入这些角色。IAM 策略定义权限,而不考虑您使用哪种方法来执行操作。
基于身份的策略
基于身份的策略是您附加到身份(用户、组或角色)的 JSON 权限策略文档。这些策略控制身份可在什么条件下对哪些资源执行什么操作。要了解如何创建基于身份的策略,请参阅《IAM 用户指南》中的使用客户管理型策略定义自定义 IAM 权限。
基于身份的策略可以是内联策略(直接嵌入到单个身份中)或托管式策略(附加到多个身份的独立策略)。要了解如何在托管式策略和内联策略之间进行选择,请参阅《IAM 用户指南》中的在托管式策略与内联策略之间进行选择。
有关适用于 Systems Manager 的 Amazon 托管式策略的信息,请参阅 Amazon Systems Manager 托管式策略。
基于资源的策略
基于资源的策略是附加到资源的 JSON 策略文档。示例包括 IAM 角色信任策略和 Amazon S3 存储桶策略。在支持基于资源的策略的服务中,服务管理员可以使用它们来控制对特定资源的访问。您必须在基于资源的策略中指定主体。
基于资源的策略是位于该服务中的内联策略。您不能在基于资源的策略中使用来自 IAM 的 Amazon 托管式策略。
策略条件键
用户和角色可以执行的操作以及可以执行这些操作的资源,可能会受到特定条件的进一步限制。
在 JSON 策略文档中,Condition 元素(或 Condition 块)可以指定语句生效的条件。Condition 元素是可选的。您可以创建使用条件运算符(例如 StringEquals 或 StringNotLike)的条件表达式,让策略中的条件与请求中的值相匹配。
如果您在一个语句中指定多个 Condition 元素,或在单个 Condition 元素中指定多个键,则 Amazon 使用逻辑 AND 运算评估它们。如果您为单个条件键指定多个值,则 Amazon 使用逻辑 OR 运算来评估条件。在授予语句的权限之前必须满足所有的条件。
在指定条件时,您也可以使用占位符变量。例如,只有在使用 IAM 用户名标记 IAM 用户时,您才能为其授予访问资源的权限。有关更多信息,请参阅《IAM 用户指南》中的 IAM 策略元素:变量和标签。
Amazon 支持全局条件键和特定于服务的条件键。有关更多信息,请参阅《IAM 用户指南》中的 Amazon 全局条件上下文键。
重要
如果使用 Systems Manager Automation,我们建议您不要在策略中使用 aws:SourceIp 条件键。此条件键的行为取决于多种因素,包括是否提供了用于 Automation 运行手册执行的 IAM 角色以及运行手册中使用的 Automation 操作。因此,条件键可能会产生意外的行为。因此,我们建议您不要使用它。
Systems Manager 支持众多自有的条件键。有关更多信息,请参阅《Service Authorization Reference》中的 Condition keys for Amazon Systems Manager。《Service Authorization Reference》中的 Resource types defined by Amazon Systems Manager 列出了可用于 Systems Manager 特定条件键的操作和资源。
如果策略必须依赖于 Systems Manager 服务拥有的服务主体名称,建议使用 aws:PrincipalServiceNamesList 多值条件键而不是 aws:PrincipalServiceName 条件键来检查其是否存在。aws:PrincipalServiceName 条件键仅包含服务主体名称列表中的一个条目,并且该条目不一定是您预期的服务主体名称。以下 Condition 块演示了检查 ssm.amazonaws.com 是否存在的过程。
{ "Condition": { "ForAnyValue:StringEquals": { "aws:PrincipalServiceNamesList": "ssm.amazonaws.com" } } }
要查看 Systems Manager 基于身份的策略的示例,请参阅 Amazon Systems Manager 基于身份的策略示例。
访问控制列表(ACL)
访问控制列表(ACL)控制哪些主体(账户成员、用户或角色)有权访问资源。ACL 与基于资源的策略类似,尽管它们不使用 JSON 策略文档格式。
Amazon S3、Amazon WAF 和 Amazon VPC 是支持 ACL 的服务示例。要了解有关 ACL 的更多信息,请参阅《Amazon Simple Storage Service 开发人员指南》中的访问控制列表(ACL)概览。
其他策略类型
Amazon 支持额外的策略类型,这些策略类型可以设置由更常用的策略类型授予的最大权限:
-
权限边界:设置基于身份的策略可以授予 IAM 实体的最大权限。有关更多信息,请参阅《IAM 用户指南》中的 IAM 实体的权限边界。
-
服务控制策略(SCP):指定 Amazon Organizations 中组织或组织单元的最大权限。有关更多信息,请参阅 Amazon Organizations 用户指南中的服务控制策略。
-
资源控制策略(RCP):设置对账户中资源的最大可用权限。有关更多信息,请参阅《Amazon Organizations User Guide》中的 Resource control policies (RCPs)。
-
会话策略:在为角色或联合用户创建临时会话时,作为参数传递的高级策略。有关更多信息,请参阅 IAM 用户指南中的会话策略。
多个策略类型
当多个类型的策略应用于一个请求时,生成的权限更加复杂和难以理解。要了解 Amazon 如何确定在涉及多种策略类型时是否允许请求,请参阅 IAM 用户指南中的策略评测逻辑。