インスタンスが一時的なAPIクレデンシャル(アクセスキー、シークレットキー、セキュリティトークン)を使用して特定のリソースにアクセスできるようにするAWSIAMロールを使用しています。
このrubyスクリプトを使用して一時的な資格情報をテストすると、問題なく実行されます。
require 'rubygems'
require 'aws-sdk'
AWS.config(
:access_key_id => "MY ACCESS KEY GOES HERE",
:secret_access_key => "MY SECRET KEY GOES HERE",
:session_token => "MY TOKEN GOES HERE")
s3 = AWS::S3.new()
myfile = s3.buckets['My-Config'].objects["file.sh"]
File.open("/tmp/file.sh", "w") do |f|
f.write(myfile.read)
end
しかし、コマンドラインを使用してcfn-describe-stacksを実行すると、エラーが発生します。
export AWS_CREDENTIAL_FILE=aws_credentials.cfg
cfn-describe-stacks
cfn-describe-stacks: Refused: The security token included in the request is invalid
これが私のaws_credentials.cfgです:
AWSAccessKeyId=MY ACCESS KEY
AWSSecretKey=My SECRET KEY
AWSToken="MY TOKEN=="
だから私はここで何が欠けていますか?ありがとうございました!