Fargate 不会自动承担跨账户角色。幸运的是,您无需在另一个帐户中担任角色即可从该帐户的 ECR 存储库中提取图像。
要在 ECR 中启用对图像的跨账户访问,请在账户 A 的存储库中添加账户 B 的访问权限(通过设置存储库策略),然后在账户 B 中指定有权从 ECR 中提取的 TaskExecutionRole(“ecr:GetDownloadUrlForLayer” 、“ecr:BatchGetImage”、“ecr:BatchCheckLayerAvailability”)。
例如,在账户 A 中的存储库上设置存储库策略,如下所示:
{
"Version": "2008-10-17",
"Statement": [
{
"Sid": "AllowCrossAccountPull",
"Effect": "Allow",
"Principal": {
"AWS": "arn:aws:iam::ACCOUNT_B_ID:root"
},
"Action": [
"ecr:GetDownloadUrlForLayer",
"ecr:BatchCheckLayerAvailability",
"ecr:BatchGetImage"
]
}
]
}
然后,将账户 B 中的 TaskExecutionRole 设置为具有如下策略:
{
"Version": "2012-10-17",
"Statement": [
{
"Effect": "Allow",
"Action": [
"ecr:GetAuthorizationToken",
"ecr:BatchCheckLayerAvailability",
"ecr:GetDownloadUrlForLayer",
"ecr:BatchGetImage"
],
"Resource": "*"
}
]
}
或者,您可以为 TaskExecutionRole 使用托管策略AmazonECSTaskExecutionRolePolicy,而不是定义自己的策略。