Situation
Need Transfer S3 Object To Another Account's S3 Bucket
How To
Part Account A (Source Account) Step 1
In IAM Service Create New Role For DataSync
data:image/s3,"s3://crabby-images/99ef0/99ef04136b7870faec49b0c251331a0e7a2aedf0" alt=""
data:image/s3,"s3://crabby-images/2af41/2af414150cbdf42277ea092eb6107a7b35113182" alt=""
data:image/s3,"s3://crabby-images/9a440/9a44070f017d19e60655f2fab1bc5d3e0cd056c7" alt=""
data:image/s3,"s3://crabby-images/442a0/442a079f65d941ad01b31b016cf78cacc6373e17" alt=""
After Created Role, Add Custom Policy, Change "arn:aws:s3:::<destination-bucket-name>
& "arn:aws:s3:::<destination-bucket-name>/*"
{
"Version": "2012-10-17",
"Statement": [
{
"Action": [
"s3:GetBucketLocation",
"s3:ListBucket",
"s3:ListBucketMultipartUploads"
],
"Effect": "Allow",
"Resource": "arn:aws:s3:::<destination-bucket-name>"
},
{
"Action": [
"s3:AbortMultipartUpload",
"s3:DeleteObject",
"s3:GetObject",
"s3:ListMultipartUploadParts",
"s3:PutObject",
"s3:GetObjectTagging",
"s3:PutObjectTagging"
],
"Effect": "Allow",
"Resource": "arn:aws:s3:::<destination-bucket-name>/*"
}
]
}
Part Of Account B (Destination Account) Step 2
Create S3 Bucket For Destination, And Add Bucket Policy Source Account Role Name
data:image/s3,"s3://crabby-images/250f7/250f796c3772ea061843273d6c7ce5d702ddce33" alt=""
Bucket Policy
{
"Version": "2008-10-17",
"Statement": [
{
"Sid": "DataSyncCreateS3LocationAndTaskAccess",
"Effect": "Allow",
"Principal": {
"AWS": "arn:aws:iam::120340392319:role/gw-demo-datasync"
},
"Action": [
"s3:GetBucketLocation",
"s3:ListBucket",
"s3:ListBucketMultipartUploads",
"s3:AbortMultipartUpload",
"s3:DeleteObject",
"s3:GetObject",
"s3:ListMultipartUploadParts",
"s3:PutObject",
"s3:GetObjectTagging",
"s3:PutObjectTagging"
],
"Resource": [
"arn:aws:s3:::gw-demo-des-bucket",
"arn:aws:s3:::gw-demo-des-bucket/*"
]
},
{
"Sid": "DataSyncCreateS3Location",
"Effect": "Allow",
"Principal": {
"AWS": "arn:aws:iam::<account_id>:role/role-name"
},
"Action": "s3:ListBucket",
"Resource": "arn:aws:s3:::gw-demo-des-bucket"
}
]
}
Part Account A (Source Account) Step 3
Change Custom Policy And Create DataSync Location
Source Account Location
data:image/s3,"s3://crabby-images/8c49c/8c49cdc6fa3faaf1cd418d29db79da0c2e65e583" alt=""
Create Destination Location
aws datasync create-location-s3 \
--s3-bucket-arn arn:aws:s3:::<destination-bucket> \
--region <destination-bucket-region> \
--s3-config '{
"BucketAccessRoleArn":"arn:aws:iam::<source-account-id>:role/<source-datasync-role>"
}'
After Create, You Can See Location Have Two Hosts
data:image/s3,"s3://crabby-images/4527b/4527bfa300160ed9fd9c767512d6c050c8548682" alt=""
Part Account A (Source Account) Step 4
Then Create Tasks, Run That
data:image/s3,"s3://crabby-images/d2dbf/d2dbfee79fb627c23a132511ef8d5b97533d5bec" alt=""
data:image/s3,"s3://crabby-images/52a6c/52a6cbcb89e102c6b71196eb14e8689b0150dd29" alt=""
data:image/s3,"s3://crabby-images/d7a82/d7a82789bf1b7f19d1be8bbdcc629f5bd74c146a" alt=""
data:image/s3,"s3://crabby-images/c6204/c6204d14cf9517b6c2b71210120fbed0123a62fb" alt=""
data:image/s3,"s3://crabby-images/8f6c4/8f6c4bf6a1faa73ef791c039d1fa18365994f02e" alt=""
data:image/s3,"s3://crabby-images/6333e/6333e9d7f6e3679d73a25b5c0a343dc90f37ff43" alt=""
Part Of Account B (Destination Account) Step 5
Verify Sync After Finished
data:image/s3,"s3://crabby-images/94c2f/94c2f6ef2865c31a1cf49c81a08a9937fe0e439e" alt=""
Top comments (0)