Dev AWS ice Farm 中的身份和访问管理 - AWS Device Farm

本文属于机器翻译版本。若本译文内容与英语原文存在差异,则一律以英文原文为准。

Dev AWS ice Farm 中的身份和访问管理

受众

你使用 AWS Identity and Access Management (IAM) 的方式会有所不同,具体取决于你在 Device Farm 中所做的工作。

服务用户 – 如果使用 Device Farm 服务来完成任务,则您的管理员会为您提供所需的凭证和权限。当您使用更多 Device Farm 功能来完成工作时,您可能需要额外权限。了解如何管理访问权限有助于您向管理员请求适合的权限。如果您无法访问 Device Farm 中的功能,请参阅 对 Dev AWS ice Farm 身份和访问进行故障排除

服务管理员 – 如果您在公司负责管理 Device Farm 资源,则您可能具有 Device Farm 的完全访问权限。您有责任确定您的服务用户应访问哪些 Device Farm 功能和资源。然后,您必须向 IAM 管理员提交请求,这样才能更改您的服务用户的权限。查看此页面的信息,了解 IAM 的基本概念。要详细了解贵公司如何与 Device Farm IAM 配合使用,请参阅Dev AWS ice Farm 是如何使用的 IAM

IAM管理员-如果您是IAM管理员,则可能需要详细了解如何编写策略来管理 Device Farm 的访问权限。要查看可在中使用的基于 Device Farm 身份的策略示例IAM,请参阅。AWSDevice Farm 基于身份的策略示例

使用身份进行身份验证

身份验证是您 AWS 使用身份凭证登录的方式。您必须以 AWS 账户根用户、IAM用户身份或通过担任IAM角色进行身份验证(登录 AWS)。

您可以使用通过身份源提供的凭据以 AWS 联合身份登录。 AWS IAM Identity Center (IAM身份中心)用户、贵公司的单点登录身份验证以及您的 Google 或 Facebook 凭据就是联合身份的示例。在您以联合身份登录时,您的管理员以前使用 IAM 角色设置了身份联合验证。当你使用联合访问 AWS 时,你就是在间接扮演一个角色。

根据您的用户类型,您可以登录 AWS Management Console 或 AWS 访问门户。有关登录的更多信息 AWS,请参阅《AWS 登录 用户指南》中的如何登录到您 AWS 账户的。

如果您 AWS 以编程方式访问,则会 AWS 提供软件开发套件 (SDK) 和命令行接口 (CLI),以便使用您的凭据对请求进行加密签名。如果您不使用 AWS 工具,则必须自己签署请求。有关使用推荐的方法自行签署请求的更多信息,请参阅《IAM用户指南》中的API请求AWS 签名版本 4

无论使用何种身份验证方法,您都可能需要提供其他安全信息。例如, AWS 建议您使用多重身份验证 (MFA) 来提高账户的安全性。要了解更多信息,请参阅用户指南中的多因素身份验证AWS IAM Identity Center 用户指南IAM中的AWS 多因素身份验证。IAM

AWS 账户 root 用户

创建时 AWS 账户,首先要有一个登录身份,该身份可以完全访问账户中的所有资源 AWS 服务 和资源。此身份被称为 AWS 账户 root 用户,使用您创建账户时使用的电子邮件地址和密码登录即可访问该身份。强烈建议您不要使用根用户执行日常任务。保护好根用户凭证,并使用这些凭证来执行仅根用户可以执行的任务。有关需要您以根用户身份登录的任务的完整列表,请参阅《IAM 用户指南》中的需要根用户凭证的任务

IAM用户和群组

IAM用户是您内部 AWS 账户 对个人或应用程序具有特定权限的身份。在可能的情况下,我们建议使用临时证书,而不是创建拥有密码和访问密钥等长期凭证的IAM用户。但是,如果您有需要IAM用户长期凭证的特定用例,我们建议您轮换访问密钥。有关更多信息,请参阅《IAM 用户指南》中的对于需要长期凭证的使用场景定期轮换访问密钥

IAM 组 是指定一个 IAM 用户集合的身份。您不能使用组的身份登录。您可以使用组来一次性为多个用户指定权限。如果有大量用户,使用组可以更轻松地管理用户权限。例如,您可以拥有一个名为的群组,IAMAdmins并授予该群组管理IAM资源的权限。

用户与角色不同。用户唯一地与某个人员或应用程序关联,而角色旨在让需要它的任何人代入。用户具有永久的长期凭证,而角色提供临时凭证。要了解更多信息,请参阅《IAM用户指南》中的IAM用户用例

IAM 角色

IAM角色是您内部具有特定权限 AWS 账户 的身份。它类似于 IAM 用户,但未与特定人员关联。要在中临时扮IAM演角色 AWS Management Console,可以从用户切换到IAM角色(控制台)。您可以通过调用 AWS CLI 或 AWS API操作或使用自定义操作来代入角色URL。有关使用角色的方法的更多信息,请参阅《IAM用户指南》中的代入角色的方法

具有临时凭证的 IAM 角色在以下情况下很有用:

  • 联合用户访问 – 要向联合身份分配权限,请创建一个角色,并为该角色定义权限。当联合身份进行身份验证时,该身份将与角色相关联并被授予由此角色定义的权限。有关用于联合身份验证的角色的信息,请参阅《IAM用户指南》中的为第三方身份提供商(联合)创建角色。如果您使用 IAM Identity Center,则需要配置权限集。为了控制您的身份在进行身份验证后可以访问的内容,Ident IAM ity Center 会将权限集关联到中的IAM角色。有关权限集的信息,请参阅《AWS IAM Identity Center 用户指南》中的权限集

  • 临时IAM用户权限-IAM 用户或角色可以代入一个IAM角色,为特定任务临时获得不同的权限。

  • 跨账户存取 - 您可以使用 IAM 角色允许其他账户中的某个人(可信任主体)访问您账户中的资源。角色是授予跨账户存取权限的主要方式。但是,对于某些资源 AWS 服务,您可以将策略直接附加到资源(而不是使用角色作为代理)。要了解角色和基于资源的跨账户访问策略之间的区别,请参阅IAM用户指南IAM中的跨账户资源访问权限

  • 跨服务访问 — 有些 AWS 服务 使用其他 AWS 服务服务中的功能。例如,当您在服务中拨打电话时,该服务通常会在 Amazon 中运行应用程序EC2或在 Amazon S3 中存储对象。服务可能会使用发出调用的主体的权限、使用服务角色或使用服务相关角色来执行此操作。

    • 转发访问会话 (FAS)-当您使用IAM用户或角色在中执行操作时 AWS,您被视为委托人。当你使用某些服务时,你可能会执行一个操作,然后在不同的服务中启动另一个操作。 FAS使用调用委托人的权限 AWS 服务以及 AWS 服务 向下游服务发出请求的请求。 FAS只有当服务收到需要与其他 AWS 服务 或资源交互才能完成的请求时,才会发出请求。在这种情况下,您必须具有执行这两项操作的权限。有关提出FAS请求时的政策详情,请参阅转发访问会话

    • 服务角色-服务IAM角色是服务代替您执行操作的角色。IAM 管理员可以在 IAM 中创建、修改和删除服务角色。有关更多信息,请参阅《IAM用户指南》 AWS 服务中的创建角色以向委派权限

    • 服务相关角色-服务相关角色是一种与服务相关联的服务角色。 AWS 服务服务可以代入代表您执行操作的角色。服务相关角色出现在您的中 AWS 账户 ,并且归服务所有。IAM 管理员可以查看但不能编辑服务相关角色的权限。

  • 在 Amazon 上运行的应用程序 EC2 — 您可以使用IAM角色管理在EC2实例上运行并发出 AWS CLI 或 AWS API请求的应用程序的临时证书。这优先于在 EC2 实例中存储访问密钥。要为EC2实例分配 AWS 角色并使其可供其所有应用程序使用,您需要创建一个附加到该实例的实例配置文件。实例配置文件包含角色,并使 EC2 实例上运行的程序能够获得临时凭证。有关更多信息,请参阅IAM用户指南中的使用IAM角色向在 Amazon EC2 实例上运行的应用程序授予权限

使用策略管理访问

您可以 AWS 通过创建策略并将其附加到 AWS 身份或资源来控制中的访问权限。策略是其中的一个对象 AWS ,当与身份或资源关联时,它会定义其权限。 AWS 在委托人(用户、root 用户或角色会话)发出请求时评估这些策略。策略中的权限确定是允许还是拒绝请求。大多数策略都以JSON文档的 AWS 形式存储在中。有关JSON策略文档结构和内容的更多信息,请参阅IAM用户指南》中的JSON策略概述

管理员可以使用 AWS JSON策略来指定谁有权访问什么。也就是说,哪个主体可以对什么资源执行操作,以及在什么条件下执行。

默认情况下,用户和角色没有权限。要授予用户对所需资源执行操作的权限,IAM 管理员可以创建 IAM 策略。管理员随后可以向角色添加 IAM 策略,用户可以代入这些角色。

IAM 策略定义操作的权限,无论您使用哪种方法执行操作。例如,假设您有一个允许 iam:GetRole 操作的策略。拥有该策略的用户可以从 AWS Management Console AWS CLI、或中获取角色信息 AWS API。

基于身份的策略

基于身份的策略是可以附加到身份(例如IAM用户、用户组或角色)的JSON权限策略文档。这些策略控制用户和角色可在何种条件下对哪些资源执行哪些操作。要了解如何创建基于身份的策略,请参阅IAM用户指南中的使用客户托管策略定义自定义IAM权限

基于身份的策略可以进一步归类为内联策略托管式策略。内联策略直接嵌入单个用户、组或角色中。托管策略是独立的策略,您可以将其附加到中的多个用户、群组和角色 AWS 账户。托管策略包括 AWS 托管策略和客户托管策略。要了解如何在托管策略或内联策略之间进行选择,请参阅《IAM用户指南》中的在托管策略和内联策略之间进行选择。

下表概述了 Device Farm AWS 托管策略。

更改 描述 日期

AWSDeviceFarmFullAccess

提供对 Dev AWS ice Farm 所有操作的完全访问权限。

2015 年 7 月 15 日

AWSServiceRoleForDeviceFarmTestGrid

允许 Device Farm 代表您访问AWS资源。

2021 年 5 月 20 日

其他策略类型

AWS 支持其他不太常见的策略类型。这些策略类型可以设置更常用的策略类型向您授予的最大权限。

  • 权限边界-权限边界是一项高级功能,您可以在其中设置基于身份的策略可以向IAM实体(IAM用户或角色)授予的最大权限。您可为实体设置权限边界。这些结果权限是实体基于身份的策略及其权限边界的交集。在 Principal 中指定用户或角色的基于资源的策略不受权限边界限制。任一项策略中的显式拒绝将覆盖允许。有关权限边界的更多信息,请参阅《IAM 用户指南》中的 IAM 实体的权限边界

  • 服务控制策略 (SCPs)-SCPs 是为中的组织或组织单位 (OU) 指定最大权限的JSON策略 AWS Organizations。 AWS Organizations 是一项用于对您的企业拥有的多 AWS 账户 项进行分组和集中管理的服务。如果您启用组织中的所有功能,则可以将服务控制策略 (SCPs) 应用于您的任何或所有帐户。对成员账户中的实体(包括每个实体)的权限进行了SCP限制 AWS 账户根用户。有关 Organization SCPs s 和的更多信息,请参阅《AWS Organizations 用户指南》中的服务控制策略

  • 资源控制策略 (RCPs) — RCPs 这些JSON策略可用于设置账户中资源的最大可用权限,而无需更新附加到您拥有的每项资源的IAM策略。这会RCP限制成员账户中资源的权限,并可能影响身份(包括身份)的有效权限 AWS 账户根用户,无论这些身份是否属于您的组织。有关 Organizations 的更多信息RCPs,包括 AWS 服务 该支持的列表RCPs,请参阅《AWS Organizations 用户指南》中的资源控制策略 (RCPs)

  • 会话策略:会话策略是当您以编程方式为角色或联合用户创建临时会话时作为参数传递的高级策略。结果会话的权限是用户或角色的基于身份的策略和会话策略的交集。权限也可以来自基于资源的策略。任一项策略中的显式拒绝将覆盖允许。有关更多信息,请参阅《IAM 用户指南》中的会话策略

多个策略类型

当多个类型的策略应用于一个请求时,生成的权限更加复杂和难以理解。要了解在涉及多种策略类型时如何 AWS 确定是否允许请求,请参阅IAM用户指南中的策略评估逻辑