I'm trying to copy a file from a private s3-bucket via cli to my ec2 instance. The ec2 is in the same region as the bucket and has the following IAM role attached (AmazonS3FullAccess):
{
"Version": "2012-10-17",
"Statement": [
   {
     "Effect": "Allow",
     "Action": "s3:*",
     "Resource": "*"
   }
 ]
}
But the command:
aws s3 cp s3://[BUCKETNAME]/index.html /var/www/html/
fails with the error:
A client error (400) occurred when calling the HeadObject operation: Bad Request Completed 1 part(s) with ... file(s) remaining.
I already double checked the spelling of the bucket name...
I added the --region option to the statement and everything is working now:
aws s3 cp s3:/[BUCKETNAME]/ . --recursive --region [REGION]
This error also happens when your session has expired if using temporary security credentials with an assumed role. Not a forbidden or unknown id as you would expect.
The --region parameter did not work for me. 
I tried using --profile, and it worked all fine.
aws s3api head-bucket --bucket xxxx --profile dev-profile
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With