我正在尝试使用write_using()
包中的aws.s3
在EC2中从R读取/写入S3。
EC2附带了一个IAM,可以对specific AWS S3 bucket
进行读/写。我已将IAM与EC2相关联。我还创建了一个存储桶(在此示例中,请假定其名为my-unique-bucket
)
当我进入EC2并打开R时,然后运行类似s3write_using(mtcars, FUN = write.csv, object = "mtcars.csv", bucket = "my-unique-bucket")
我知道
List of 4
$ Code : chr "AccessDenied"
$ Message : chr "Access Denied"
$ RequestId: chr "3B942C125C154B49"
$ HostId : chr "0dgc4Iuv3EXdQxMgkh4Qkxt+aADzxsVYp6pq2k3/OjSztFlV1nftjn4MkIvNZ+wCVqzeJsttY44="
- attr(*, "headers")=List of 6
..$ x-amz-request-id : chr "3B942C125C154B49"
..$ x-amz-id-2 : chr "0dgc4Iuv3EXdQxMgkh4Qkxt+aADzxsVYp6pq2k3/OjSztFlV1nftjn4MkIvNZ+wCVqzeJsttY44="
..$ content-type : chr "application/xml"
..$ transfer-encoding: chr "chunked"
..$ date : chr "Tue, 18 Jun 2019 12:57:45 GMT"
..$ server : chr "AmazonS3"
..- attr(*, "class")= chr [1:2] "insensitive" "list"
- attr(*, "class")= chr "aws_error"
NULL
Error in parse_aws_s3_response(r, Sig, verbose = verbose) :
Forbidden (HTTP 403).
我希望这能奏效吗?相反,它看起来像是身份验证问题
我不确定下一步该怎么做,因为我希望以上方法能奏效。
如果没有,我是否需要对EC2(或在EC2上运行的R会话)进行身份验证?我认为使用根凭据进行身份验证会破坏IAM的目的(因为根用户具有所有权限,而与实例关联的IAM仅具有对S3的读/写权限)。因此,我不确定这是正确的做法(似乎会有更好的方法-即让S3知道EC2具有允许其访问的IAM的方法)。但是我不确定如何执行此操作,或者在尝试此操作时哪里出错了
答案 0 :(得分:0)
这将在任何地方(例如Windows,mac等,无论是在EC2上还是其他版本上运行)中运行。您需要在R中使用以下代码:
key <- "ALIAVI5FAYD9B(8MVJZ" # Substitute with your own (see below)
secret <- "ePy7jMlRj5jTVAruqmb3uap9bHXmnsSHI+zqfdmHL" # (see below)
Sys.setenv("AWS_ACCESS_KEY_ID" = key,
"AWS_SECRET_ACCESS_KEY" = secret)
bucketlist() # This returns a list of all your buckets if authentication was successful
要使其正常工作,您需要使用唯一的key
和secret
进行潜入。这样做仅需1分钟,请执行以下操作:
# Write to your S3 bucket
s3write_using(mtcars, FUN = write.csv, object = "mtcars.csv", bucket = "your-bucket-name")
# Read from your S3 bucket
myfile <- s3read_using(FUN = read.csv, object = "mtcars.csv", bucket = "your-bucket-name")
# In case you need to remove an environment variable AWS_SESSION_TOKEN, this will clear it
Sys.unsetenv("AWS_SECRET_ACCESS_KEY")
答案 1 :(得分:0)
您需要使用aws.ec2metadata并确保指定正确的s3存储桶区域以使用ec2或ecs任务IAM角色。
library(aws.s3)
library(aws.ec2metadata)
Sys.setenv("AWS_DEFAULT_REGION" = 'us-west-2')
这里没有什么值得研究的。
根据https://cran.r-project.org/web/packages/aws.s3/readme/README.html,它使用https://github.com/cloudyr/aws.signature/进行AWS Auth,您需要使用 aws.ec2metadata
aws s3 ls s3://my_bucket/directory/
aws s3 cp s3://my_bucket/directory/myfile /tmp/
aws s3 cp /tmp/test s3://my_bucket/directory/ # check this only if you need write access