使用AWS SDK for JavaScript时,我想使用一个默认配置文件来承担角色。这与AWS CLI完美配合。使用node.js与SDK时不承担角色,而只使用访问密钥所属的AWS帐户的凭据。我找到了此文档,但它没有处理承担角色的问题:Loading Credentials in Node.js from the Shared Credentials File
有什么建议吗?
这是我的配置文件:
[default]
role_arn = arn:aws:iam::123456789:role/Developer
source_profile = default
output = json
region = us-east-1
4条答案
按热度按时间puruo6ea1#
使用sts获取跨帐户角色的凭据,并在每次需要使用该特定跨帐户角色对服务进行身份验证时使用这些凭据。
示例:
创建一个函数来获取交叉帐户凭据,如下所示:
然后,您可以使用它,而不会出现以下问题:
好处:
请勿使用
AWS.config.update
覆盖全局凭据AWS.config.credentials
!!!覆盖全局凭据是一种不好的做法!!这与@Brant批准的解决方案的情况相同,但它不是一种好的解决方案!原因如下:
问题:
AWS.config.credentials
或通过AWS.config.update
更新全局AWS.config.credentials
将覆盖当前凭据。AWS.config.credentials
,然后再次更新以恢复它。很难控制何时使用每个帐户,很难跟踪执行上下文,并且很容易由于针对错误的帐户而陷入混乱。同样,不要使用
AWS.config.update
覆盖全局凭据AWS.config.credentials
!!!如果您需要完全为另一个帐户执行代码而不切换凭据,您可以遵循@Kanak Singhal的建议,将role_arn存储在配置文件中,并将
AWS_SDK_LOAD_CONFIG="true"
与AWS_PROFILE="assume-role-profile"
一起添加到环境变量中。yeotifhr2#
找到了正确的方法!看看这个PR:https://github.com/aws/aws-sdk-js/pull/1391
只需将
AWS_SDK_LOAD_CONFIG="true"
与AWS_PROFILE="assume-role-profile"
沿着添加到环境变量中因此不需要任何代码更新😅
这是因为,SDK默认情况下仅加载
credentials
文件,而不是config
文件,但由于AWS role_arn存储在config
文件中,因此我们也必须启用加载config
文件。hfwmuf9z3#
CLI和SDK的工作方式不同,因为在使用SDK时必须显式地承担角色。SDK不会像CLI那样从配置中自动承担角色。
承担角色后,必须使用新凭据更新AWS. config。
这对我很有效:
3wabscal4#
虽然有点晚了,但现在最简单的方法可能是使用
AWS.ChainableTemporaryCredentials
它会自动刷新凭据,并可在多个图层中链接,或者使用默认凭据
https://docs.aws.amazon.com/AWSJavaScriptSDK/latest/AWS/ChainableTemporaryCredentials.html
我自己发现这个问题时,我想运行一个假定的角色,所以猜它仍然有一些搜索引擎优化的力量!