Copying, moving, and renaming objects
The CopyObject
operation creates a copy of an object that is already
stored in Amazon S3.
You can create a copy of an object up to 5 GB in a single atomic operation. However, to copy an object that is larger than 5 GB, you must use a multipart upload. For more information, see Copying an object using multipart upload.
Using the CopyObject
operation, you can:
-
Create additional copies of objects.
-
Rename objects by copying them and deleting the original ones.
-
Copy or move objects from one bucket to another, including across AWS Regions (for example, from
us-west-1
toeu-west-2
). When you move an object, Amazon S3 copies the object to the specified destination and then deletes the source object.Note
Copying or moving objects across AWS Regions incurs bandwidth charges. For more information, see Amazon S3 Pricing
. -
Change object metadata. Each Amazon S3 object has metadata. This metadata is a set of name-value pairs. You can set object metadata at the time you upload an object. After you upload the object, you cannot modify the object metadata. The only way to modify object metadata is to make a copy of the object and set the metadata. To do so, in the copy operation, set the same object as the source and target.
Some object metadata is system metadata and other is user-defined. You can control some of the system metadata. For example, you can control the storage class and the type of server-side encryption to use for the object. When you copy an object, user-controlled system metadata and user-defined metadata are also copied. Amazon S3 resets the system-controlled metadata. For example, when you copy an object, Amazon S3 resets the creation date of the copied object. You don't need to set any of these system-controlled metadata values in your copy request.
When copying an object, you might decide to update some of the metadata values. For example, if your source object is configured to use S3 Standard storage, you might choose to use S3 Intelligent-Tiering for the object copy. You might also decide to alter some of the user-defined metadata values present on the source object. If you choose to update any of the object's user-configurable metadata (system or user-defined) during the copy, then you must explicitly specify all of the user-configurable metadata present on the source object in your request, even if you are changing only one of the metadata values.
For more information about the object metadata, see Working with object metadata.
Copying archived and restored objects
If the source object is archived in S3 Glacier Flexible Retrieval or S3 Glacier Deep Archive, you must first restore a temporary copy before you can copy the object to another bucket. For information about archiving objects, see Transitioning to the S3 Glacier Flexible Retrieval and S3 Glacier Deep Archive storage classes (object archival).
The Copy operation in the Amazon S3 console isn't supported for restored objects in the S3 Glacier Flexible Retrieval or S3 Glacier Deep Archive storage classes. To copy these restored objects, use the AWS Command Line Interface (AWS CLI), the AWS SDKs, or the Amazon S3 REST API.
Copying encrypted objects
Amazon S3 automatically encrypts all new objects that are copied to an S3 bucket. If you don't specify encryption information in your copy request, the encryption setting of the target object is set to the default encryption configuration of the destination bucket. By default, all buckets have a base level of encryption configuration that uses server-side encryption with Amazon S3 managed keys (SSE-S3). If the destination bucket has a default encryption configuration that uses server-side encryption with an AWS Key Management Service (AWS KMS) key (SSE-KMS), or a customer-provided encryption key (SSE-C), Amazon S3 uses the corresponding KMS key, or a customer-provided key to encrypt the target object copy.
When copying an object, if you want to use a different type of encryption setting for the target object, you can request that Amazon S3 encrypt the target object with a KMS key, an Amazon S3 managed key, or a customer-provided key. If the encryption setting in your request is different from the default encryption configuration of the destination bucket, the encryption setting in your request takes precedence. If the source object for the copy is encrypted with SSE-C, you must provide the necessary encryption information in your request so that Amazon S3 can decrypt the object for copying. For more information, see Protecting data with encryption.
Using checksums when copying objects
When copying objects, you can choose to use a different checksum algorithm for the object. Whether you choose to use the same algorithm or a new one, Amazon S3 calculates a new checksum value after the object is copied. Amazon S3 does not directly copy the value of the checksum. The checksum value of objects that were loaded by using multipart uploads might change. For more information about how the checksum is calculated, see Using part-level checksums for multipart uploads.
Copying multiple objects in a single request
To copy more than one Amazon S3 object with a single request, you can also use S3 Batch Operations. You provide S3 Batch Operations with a list of objects to operate on. S3 Batch Operations calls the respective API operation to perform the specified operation. A single Batch Operations job can perform the specified operation on billions of objects containing exabytes of data.
The S3 Batch Operations feature tracks progress, sends notifications, and stores a detailed completion report of all actions, providing a fully managed, auditable, serverless experience. You can use S3 Batch Operations through the Amazon S3 console, AWS CLI, AWS SDKs, or REST API. For more information, see S3 Batch Operations basics.
Copying objects to directory buckets
For information about copying an object to a directory bucket, see Copying an object to a directory bucket. For information about using the Amazon S3 Express One Zone storage class with directory buckets, see What is S3 Express One Zone? and Directory buckets.
To copy an object
To copy an object, use the following methods.
Note
-
When copying an object by using the Amazon S3 console, you must have the
s3:ListAllMyBuckets
permission. The console needs this permission to validate the Copy operation. For example policies that grant this permission, see Identity-based policy examples for Amazon S3.If you're copying an object that has user-defined tags, you must also have the
s3:GetObjectTagging
permission. If you're copying an object that doesn't have user-defined tags but is over 16 MB in size, you must also have the s3:GetObjectTagging
permission.If the destination bucket policy denies the
s3:GetObjectTagging
action, the object will be copied without the user-defined tags, and you will receive an error. -
Objects encrypted with customer-provided encryption keys (SSE-C) cannot be copied by using the S3 console. To copy objects encrypted with SSE-C, use the AWS CLI, AWS SDK, or the Amazon S3 REST API.
-
Cross-Region copying of objects encrypted with SSE-KMS is not supported by the Amazon S3 console. To copy objects encrypted with SSE-KMS across Regions, use the AWS CLI, AWS SDK, or the Amazon S3 REST API.
To copy an object
Sign in to the AWS Management Console and open the Amazon S3 console at https://console.aws.amazon.com/s3/
. -
In the left navigation pane, choose Buckets, and then choose the General purpose buckets tab. Navigate to the Amazon S3 bucket or folder that contains the objects that you want to copy.
-
Select the check box to the left of the names of the objects that you want to copy.
-
On the Actions menu, choose Copy from the list of options that appears.
-
Select the destination type and destination account. To specify the destination path, choose Browse S3, navigate to the destination, and select the check box to the left of the destination. Choose Choose destination in the lower-right corner.
Alternatively, enter the destination path.
-
If you do not have bucket versioning enabled, you might be asked to acknowledge that existing objects with the same name are overwritten. If this is OK, select the check box and proceed. If you want to keep all versions of objects in this bucket, select Enable Bucket Versioning. You can also update the default encryption and S3 Object Lock properties.
-
Under Additional checksums, choose whether you want to copy the objects using the existing checksum function or replace the existing checksum function with a new one. When you uploaded the objects, you had the option to specify the checksum algorithm that was used to verify data integrity. When copying the object, you have the option to choose a new function. If you did not originally specify an additional checksum, you can use this section of the copy options to add one.
Note
Even if you opt to use the same checksum function, your checksum value might change if you copy the object and it is over 16 MB in size. The checksum value might change because of how checksums are calculated for multipart uploads. For more information about how the checksum might change when copying the object, see Using part-level checksums for multipart uploads.
To change the checksum function, choose Replace with a new checksum function. Choose the new checksum function from the box. When the object is copied over, the new checksum is calculated and stored using the specified algorithm.
-
Choose Copy in the bottom-right corner. Amazon S3 copies your objects to the destination.
The examples in this section show how to copy objects up to 5 GB in a single operation. To copy objects larger than 5 GB, you must use a multipart upload. For more information, see Copying an object using multipart upload.
This example describes how to copy an object by using the Amazon S3 REST API. For more information about the REST API, see CopyObject.
This example copies the flotsam
object from the
bucket to the amzn-s3-demo-bucket1
jetsam
object of the
bucket, preserving
its metadata.amzn-s3-demo-bucket2
PUT /jetsam HTTP/1.1 Host:
amzn-s3-demo-bucket2
.s3.amazonaws.com x-amz-copy-source: /amzn-s3-demo-bucket1
/flotsam Authorization: AWS AKIAIOSFODNN7EXAMPLE:ENoSbxYByFA0UGLZUqJN5EUnLDg= Date: Wed, 20 Feb 2008 22:12:21 +0000
The signature was generated from the following information.
PUT\r\n \r\n \r\n Wed, 20 Feb 2008 22:12:21 +0000\r\n x-amz-copy-source:/
amzn-s3-demo-bucket1
/flotsam\r\n /amzn-s3-demo-bucket2
/jetsam
Amazon S3 returns the following response that specifies the ETag of the object and when it was last modified.
HTTP/1.1 200 OK x-amz-id-2: Vyaxt7qEbzv34BnSu5hctyyNSlHTYZFMWK4FtzO+iX8JQNyaLdTshL0KxatbaOZt x-amz-request-id: 6B13C3C5B34AF333 Date: Wed, 20 Feb 2008 22:13:01 +0000 Content-Type: application/xml Transfer-Encoding: chunked Connection: close Server: AmazonS3 <?xml version="1.0" encoding="UTF-8"?> <CopyObjectResult> <LastModified>2008-02-20T22:13:01</LastModified> <ETag>"7e9c608af58950deeb370c98608ed097"</ETag> </CopyObjectResult>
You can also use the AWS Command Line Interface (AWS CLI) to copy an S3 object. For more
information, see copy-object
For information about the AWS CLI, see What is the AWS Command Line Interface? in the AWS Command Line Interface User Guide.
To move an object
To move an object, use the following methods.
Note
-
If you're moving an object that has user-defined tags, you must have the
s3:GetObjectTagging
permission. If you're moving an object that doesn't have user-defined tags but is over 16 MB in size, you must also have the s3:GetObjectTagging
permission.If the destination bucket policy denies the
s3:GetObjectTagging
action, the object will be moved without the user-defined tags, and you will receive an error. -
Objects encrypted with customer-provided encryption keys (SSE-C) cannot be moved by using the Amazon S3 console. To move objects encrypted with SSE-C, use the AWS CLI, AWS SDKs, or the Amazon S3 REST API.
-
When moving folders, wait for the Move operation to finish before making additional changes in the folders.
-
You can't use S3 access point aliases as the source or destination for Move operations in the Amazon S3 console.
To move an object
-
Sign in to the AWS Management Console and open the Amazon S3 console at https://console.aws.amazon.com/s3/
. -
In the left navigation pane, choose Buckets, and then choose the General purpose buckets tab. Navigate to the Amazon S3 bucket or folder that contains the objects that you want to move.
-
Select the check box to the left of the names of the objects that you want to move.
-
On the Actions menu, choose Move.
-
To specify the destination path, choose Browse S3, navigate to the destination, and select the check box to the left of the destination. Choose Choose destination in the lower-right corner.
Alternatively, enter the destination path.
-
If you do not have bucket versioning enabled, you might be asked to acknowledge that existing objects with the same name are overwritten. If this is OK, select the check box and proceed. If you want to keep all versions of objects in this bucket, select Enable Bucket Versioning. You can also update the default encryption and Object Lock properties.
-
Choose Move in the bottom-right corner. Amazon S3 moves your objects to the destination.
Note
-
This action creates a copy of all specified objects with updated settings, updates the last-modified date in the specified location, and adds a delete marker to the original object.
-
This action updates metadata for bucket versioning, encryption, Object Lock features, and archived objects.
You can also use the AWS Command Line Interface (AWS CLI) to move an S3 object. For more
information, see mv
For information about the AWS CLI, see What is the AWS Command Line Interface? in the AWS Command Line Interface User Guide.
To rename an object
To rename an object, use the following procedure.
Note
-
Renaming an object creates a copy of the object with a new last-modified date, and then adds a delete marker to the original object.
-
Bucket settings for default encryption are automatically applied to any specified object that is unencrypted.
-
You can't use the Amazon S3 console to rename objects with customer-provided encryption keys (SSE-C) . To rename objects encrypted with SSE-C, use the AWS CLI, AWS SDKs, or the Amazon S3 REST API to copy those objects with new names.
-
If this bucket uses the bucket owner enforced setting for S3 Object Ownership, object access control lists (ACLs) won't be copied.
-
If you're renaming an object that has user-defined tags, you must have the
s3:GetObjectTagging
permission. If you're renaming an object that doesn't have user-defined tags but is over 16 MB in size, you must also have the s3:GetObjectTagging
permission.If the destination bucket policy denies the
s3:GetObjectTagging
action, the object will be renamed, but the user-defined tags will be removed from the object, and you will receive an error.
To rename an object
Sign in to the AWS Management Console and open the Amazon S3 console at https://console.aws.amazon.com/s3/
. -
In the left navigation pane, choose Buckets, and then choose the General purpose buckets tab. Navigate to the Amazon S3 bucket or folder that contains the object that you want to rename.
-
Select the check box to the left of the name of the object that you want to rename.
-
On the Actions menu, choose Rename object.
-
In the New object name box, enter the new name for the object.
-
Choose Save changes in the bottom-right corner. Amazon S3 renames your object.