本文属于机器翻译版本。若本译文内容与英语原文存在差异,则一律以英文原文为准。
先决条件
在AWS使用进行设置之前AWS CLI,您需要创建一个 Amazon S3 存储桶、一个 Amazon SNS 主题和一个将附加策略作为先决条件的 IAM 角色。然后,您可以使用 AWS CLI 为 AWS Config 指定存储桶、主题和角色。请按照以下步骤设置您的先决条件AWS Config。
创建 Amazon S3 存储桶
如果您的账户中已有Amazon S3 存储桶并要使用它,请跳过此步骤,并转到创建 Amazon SNS 主题。
创建桶
通过以下网址打开 Amazon S3 控制台:https://console.aws.amazon.com/s3/
。 -
选择 Create bucket (创建存储桶)。
-
在 Bucket name(桶名称)中,输入符合 DNS 标准的桶名称。
桶名称必须满足以下要求:
-
在所有 Amazon S3 中是唯一的。
-
长度必须介于 3 到 63 个字符之间。
-
不包含大写字符。
-
以小写字母或数字开头。
创建存储桶后,便无法再更改其名称。确保所选的存储桶名称在 Amazon S3 内所有现有存储桶名称中唯一。有关存储桶命名规则和惯例的更多信息,请参阅《亚马逊简单存储服务用户指南》中的存储桶限制和限制。
重要
避免在存储桶名称中包含敏感信息,如账号。桶名称会显示在指向桶中的对象的 URL 中。
-
-
对于 Region(区域),选择要放置存储桶的AWS区域。
请选择一个靠近您的区域可最大程度地减少延迟和成本以及满足法规要求。在某一地区存储的对象将一直留在该地区,除非您特意将其转移到其他地区。有关 Amazon S3 AWS 区域的列表,请参阅中的AWS服务终端节点Amazon Web Services 一般参考。
-
在 Bucket settings for Block Public Access(阻止公有访问的桶设置)中,请选择要应用于桶的 Block Public Access(阻止公有访问)设置。
我们建议您将所有设置保持为启用状态,除非您知道您需要为您的使用案例关闭其中一个或多个设置,例如托管公共网站。您为存储桶启用的阻止公有访问设置也将为您在存储桶上创建的所有访问点启用。有关阻止公有访问的更多信息,请参阅 Amazon Simp le Storage Service 用户指南中的使用 Amazon S3 阻止公有访问。
-
(可选)如果要启用 S3 对象锁定:
-
请选择 Advanced settings (高级设置),然后阅读显示的消息。
重要
您只能在创建存储桶时为其启用 S3 对象锁定。如果您为存储桶启用了对象锁定,则以后无法禁用它。启用对象锁定还会启用存储桶的版本控制。为存储桶启用对象锁定后,必须先配置对象锁定设置,然后才能保护存储桶中的任何对象。有关配置对象保护的更多信息,请参阅使用 Amazon S3 控制台配置 S3 对象锁定。
-
如果要启用对象锁定,请在文本框中输入 enable 并选择 Confirm (确认)。
有关 S3 对象锁定功能的更多信息,请参阅 Amazon Simp le Storage Service 用户指南中的使用 Amazon S3 对象锁定对象。
-
-
请选择 Create bucket(创建桶)。
使用 AWS 软件开发工具包创建桶时,您必须先创建一个客户端,然后使用该客户端发送创建桶的请求。作为最佳做法,您应在同一 AWS 区域 中创建客户端和桶。如果您在创建客户端或桶时未指定区域,Amazon S3 将使用默认区域美国东部(弗吉尼亚北部)。
要创建客户端来访问双堆栈终端节点,则必须指定 AWS 区域。有关更多信息,请参阅 Amazon S3 双堆栈终端节点。有关可用 AWS 区域的列表,请参阅《AWS 一般参考》中的区域和端点。
创建客户端时,区域映射到特定于区域的终端节点。客户端使用此终端节点与 Amazon S3 进行通信:s3.
。如果您的区域是在 2019 年 3 月 20 日之后启动的,则您的客户端和桶必须位于同一区域。不过,您可以使用美国东部(弗吉尼亚北部)区域中的客户端在 2019 年 3 月 20 日之前启动的任何区域中创建桶。有关更多信息,请参阅传统端节点。<region>
.amazonaws.com
这些 AWS 软件开发工具包代码示例执行以下任务:
-
通过明确指定 AWS 区域 创建客户端 – 在本示例中,客户端使用
s3.us-west-2.amazonaws.com
终端节点与 Amazon S3 通信。您可以指定任意 AWS 区域。有关 AWS 区域 的列表,请参阅《AWS 一般参考》中的区域和终端节点。 -
通过仅指定桶名称来发送创建桶请求 — 客户端向 Amazon S3 发送请求,请求在您创建客户端的区域中创建桶。
-
检索有关桶位置的信息 — Amazon S3 将桶位置信息存储在与桶关联的位置子资源中。
您也可以使用AWS Command Line Interface(AWS CLI)创建 S3 桶。有关更多信息,请参阅《AWS CLI 命令参考》中的 create-bucket。
有关 AWS CLI 的更多信息,请参阅《AWS Command Line Interface 用户指南》中的什么是 AWS Command Line Interface?。
注意
您也可以使用其他账户的 Amazon S3 存储桶,但可能需要为该存储桶创建一个向其授予访问权限的策略AWS Config。有关向 Amazon S3 存储桶授予权限的信息Amazon S3 存储桶的权限,请参阅,然后转至创建 Amazon SNS 主题。
创建 Amazon SNS 主题
如果您的账户中已有Amazon SNS 主题并要使用此主题,请跳过此步骤,并转到创建 IAM 角色。
创建 Amazon SNS 主题
通过以下网址打开 Amazon SNS 控制台:https://console.aws.amazon.com/sns/v3/home
。 -
请执行下列操作之一:
-
如果之前未在您的 AWS 账户 下创建主题,请阅读主页上的 Amazon SNS 的描述。
-
如果之前已在您的 AWS 账户 下创建主题,请在导航面板上选择 Topics(主题)。
-
-
在 Topics(主页)页面上,选择 Create topic(创建主题)。
-
在 Create topic(创建主题)页面上,在 Details(详细信息)部分中,执行以下操作:
-
对于 Type(类型),选择主题类型(标准或者FIFO)。
-
输入主题的名称。对于 FIFO 主题,将 .fifo 添加到名称的末尾。
-
(可选)输入主题的显示名称。
-
(可选)对于 FIFO 主题,您可以选择基于内容的消息重复数据删除以启用默认的消息重复数据删除。有关,请参阅 FIFO 主题的邮件重复数据删除。
-
-
(可选)展开加密部分并执行以下操作。有关更多信息,请参阅静态加密。
-
选择 Enable encryption (启用加密)。
-
指定客户主密钥 (CMK)。有关更多信息,请参阅关键术语。
对于每个 CMK 类型,都会显示 Description (描述)、Account (账户) 和 CMK ARN。
重要
如果您不是 CMK 的拥有者,或者您登录的账户没有
kms:ListAliases
和kms:DescribeKey
权限,则无法在 Amazon SNS 控制台上查看有关 CMK 的信息。要求 CMK 拥有者授予您这些权限。有关更多信息,请参阅 AWS Key Management Service 开发人员指南中的 AWS KMS API 权限:操作和资源参考。
-
默认情况下,Amazon SNS 的 AWS 托管 CMK(默认)alias/aws/sns 被选择。
注意
记住以下内容:
-
第一次使用 AWS Management Console 为主题指定 Amazon SNS 的 AWS 托管 CMK 时,AWS KMS 创建 Amazon SNS 的 AWS 托管 CMK。
-
或者,您第一次对启用了 SSE 的主题使用
Publish
操作时,AWS KMS 创建 Amazon SNS 的 AWS 托管 CMK。
-
-
要从您的 AWS 账户中使用已定义 CMK,请选择 Customer master key (CMK)(客户主密钥 (CMK))字段,然后从列表中选择自定义 CMK。
注意
有关创建自定义 CMK 的说明,请参阅 AWS Key Management Service 开发人员指南中的创建密钥
-
要从您的 AWS 账户或另一个 AWS 账户中使用使用自定义 CMK ARN,请将其输入到 Customer master key (CMK)(客户主密钥 (CMK))字段中。
-
-
-
(可选)默认情况下,只有主题拥有者才能发布或订阅主题。要配置其他访问权限,请展开访问策略部分。有关更多信息,请参阅 Amazon SNS 中的Identity and Acccc cccccccccccccccc
注意
使用控制台创建主题时,默认策略使用
aws:SourceOwner
条件键。此密钥类似于aws:SourceAccount
。 -
(可选)要配置 Amazon SNS 重试失败消息传输尝试的方式,请展开 Delivery retry policy (HTTP/S)(传输重试策略 (HTTP/S))部分。有关,请参阅 Amazon SNS 消息传输重试。
-
(可选)要配置 Amazon SNS 记录消息传输的方式,请展开 Delivery CloudWatch Stats logging(传输状态日志记录)部分 有关更多信息,请参阅 Amazon SNS 消息传输状态。
-
(可选)要将元数据标签添加到主题中,请展开标签部分,输入一个键和值(可选),然后选择添加标签。有关更多信息,请参阅 Amazon SNS 主题标记。
-
选择 Create topic(创建主题)。
主题已创建并显示
MyTopic
页面。主题的名称、ARN、(可选)显示名称和主题所有者的 AWS 账户 ID 将显示在 Details(详细信息)部分中。
-
将主题 ARN 复制到剪贴板,例如:
arn:aws:sns:us-east-2:123456789012:MyTopic
要以电子邮件地址订阅到 Amazon SNS 主题
通过以下网址打开 Amazon SNS 控制台:https://console.aws.amazon.com/sns/v3/home
。 -
在左侧导航窗格中,选择订阅。
-
在 Subscriptions(订阅)页面上,选择 Create subscription(创建订阅)。
-
在 Create subscription(创建订阅)页上的 Details(详细信息)部分中,执行以下操作:
-
对于 Topic ARN(主题 ARN),选择主题的 Amazon Resource Name (ARN)。
-
对于 Endpoint(终端节点),输入终端节点值,例如电子邮件地址或 Amazon SQS 队列的 ARN。
-
仅限于 Kinesis Data Firehose 终端节点:对于 Subscription role ARN(订阅角色 ARN),指定您为写入到 Kinesis Data Firehose 传输流创建的 IAM 角色的 ARN。有关更多信息,请参阅订阅 Kinesis Data Firehose 传输流订阅 Amazon SNS 主题的先决条件。
-
(可选)对于 Kinesis Data Firehose、Amazon SQS、HTTP/S 终端节点,您还可以启用原始消息传输。有关更多信息,请参阅 Amazon SNS 原始消息传输。
-
(可选)要配置筛选策略,请展开 Subscription filter policy(订阅筛选策略)部分。有关,请参阅 Amazon SNS 订阅筛选器策略。
-
(可选)要为订阅配置死信队列,请展开 Redrive policy (dead-letter queue)(重新驱动策略(死信队列))部分。有关,请参阅 Amazon SNS 死信队列 (DLQ)。
-
选择 Create subscription(创建订阅)。
控制台将创建订阅并打开订阅的 Details(详细信息)页面。
-
要使用 AWS 开发工具包,您必须使用您的凭证对其进行配置。有关更多信息,请参阅 AWS 开发工具包和工具参考指南中的共享配置和凭证文件。
以下代码示例显示如何创建 Amazon SNS 主题。
您也可以使用 AWS Command Line Interface (AWS CLI) 创建 Amazon SNS 主题。有关更多信息,请参阅《AWS CLI命令参考》中的 create- topic。
有关 AWS CLI 的更多信息,请参阅《AWS Command Line Interface 用户指南》中的什么是 AWS Command Line Interface?。
注意
您也可以在其他账户中使用 Amazon SNS 主题,但在这种情况下,您可能需要为主题创建一个向其授予访问权限的策略AWS Config。有关向 Amazon SNS 主题授予权限的信息,请参阅,Amazon SNS 主题的权限然后转至创建 IAM 角色。
创建 IAM 角色
您可以使用 IAM 控制台创建 IAM 角色,该角色授予访问您的 Amazon S3 存储桶、访问您的 Amazon SNS 主题以及获取支持AWS资源的配置详细信息的AWS Config权限。在您使用控制台创建 IAM 角色时,AWS Config会自动为您添加所需的权限。
注意
如果您使用了使用AWS Config(例如 S AWS ecurity Hub 或 AWS Cont AWS Config rol Tower)的AWS服务,并且已经创建了角色,则应确保在设置时使用的 IAM 角色与已创建的AWS Config角色AWS Config保持相同的最低权限,以便其他AWS服务继续按预期运行。
例如,如果 AWS Control Tower 有一个AWS Config允许读取 Amazon S3 对象的 IAM 角色,则您应保证在设置时使用的 IAM 角色中授予相同的权限AWS Config。否则,它可能会干扰AWS控制塔的运营。
有关 IAM 角色的更多信息,请参阅 Ident AWSity AWS Config and Acccccccccc
为AWS服务创建角色
登录AWS Management Console,然后通过以下网址打开 IAM 控制台:https://console.aws.amazon.com/iam/
。 -
在 IAM 控制台的导航窗格中,选择 Roles,然后选择 Create role。
-
对于选择可信实体,选择 AWS 服务。
-
选择您想要的用例AWS Config:Config-可自定义、Config- Organiz ati ons、Confi g 或Config-一致性包。然后选择下一步。
-
在名称、查看和创建页面上,查看有关您的角色的详细信息,然后选择创建角色。
要使用 AWS 开发工具包,您必须使用您的凭证对其进行配置。有关更多信息,请参阅 AWS 开发工具包和工具参考指南中的共享配置和凭证文件。
以下代码示例显示如何创建 IAM 角色。
您也可以使用 AWS Command Line Interface (AWS CLI) 创建 IAM 角色。有关更多信息,请参阅《AWS CLI命令参考》中的 create- role。然后,您可以使用attach-role-policy命令以将策略附加到角色。
有关 AWS CLI 的更多信息,请参阅《AWS Command Line Interface 用户指南》中的什么是 AWS Command Line Interface?。