Synchronously Uploading Incremental Objects
Function
You can use this command to synchronize all content in a local source path to the specified target OBS bucket to ensure data consistency. Incremental synchronization has the following meanings:
- "Incremental" means that the local source files are compared with their counterparts in the destination bucket and only those with content changes are uploaded.
- "Synchronization" means that after the command is executed, all source files in the local path have their counterparts in the target OBS bucket.
 
 
  - Do not change the local file or folder during synchronization. Otherwise, the synchronization may fail or data may be inconsistent.
- Each file can be synchronously uploaded only when it does not exist in the bucket, its size is different from the namesake one in the bucket, or it has the latest modification time.
 
 
  When you compare each local file with data in the bucket, a billable HEAD request is generated. For details, see Requests.
Command Line Structure
- In Windows
    - Uploading a file synchronously
      obsutil sync file_url obs://bucket[/key] [-arcDir=xxx] [-dryRun] [-link] [-vlength] [-vmd5] [-p=1] [-threshold=5248800] [-acl=xxx] [-sc=xxx] [-meta=aaa:bbb#ccc:ddd] [-ps=auto] [-o=xxx] [-cpd=xxx] [-fr] [-config=xxx] [-e=xxx] [-i=xxx] [-k=xxx] [-t=xxx] 
- Uploading a folder synchronously
      obsutil sync folder_url obs://bucket[/key] [-arcDir=xxx] [-dryRun] [-link] [-vlength] [-vmd5] [-j=1] [-p=1] [-threshold=52428800] [-acl=xxx] [-sc=xxx] [-meta=aaa:bbb#ccc:ddd] [-ps=auto] [-include=*.xxx] [-exclude=*.xxx] [-timeRange=time1-time2] [-at] [-mf] [-o=xxx] [-cpd=xxx] [-config=xxx] [-e=xxx] [-i=xxx] [-k=xxx] [-t=xxx] 
 
- Uploading a file synchronously
      
- In Linux or macOS
    - Uploading a file synchronously
      ./obsutil sync file_url obs://bucket[/key] [-arcDir=xxx] [-dryRun] [-link] [-vlength] [-vmd5] [-p=1] [-threshold=5248800] [-acl=xxx] [-sc=xxx] [-meta=aaa:bbb#ccc:ddd] [-ps=auto] [-o=xxx] [-cpd=xxx] [-fr] [-config=xxx] [-e=xxx] [-i=xxx] [-k=xxx] [-t=xxx] 
- Uploading a folder synchronously
      ./obsutil sync folder_url obs://bucket[/key] [-arcDir=xxx] [-dryRun] [-link] [-vlength] [-vmd5] [-j=1] [-p=1] [-threshold=52428800] [-acl=xxx] [-sc=xxx] [-meta=aaa:bbb#ccc:ddd] [-ps=auto] [-include=*.xxx] [-exclude=*.xxx] [-timeRange=time1-time2] [-at] [-mf] [-o=xxx] [-cpd=xxx] [-config=xxx] [-e=xxx] [-i=xxx] [-k=xxx] [-t=xxx] 
 
- Uploading a file synchronously
      
Examples
- Take the Windows OS as an example. Run the obsutil sync d:\temp\test.txt obs://bucket-test/key command to synchronously upload a file.
    obsutil sync d:\temp\test.txt obs://bucket-test/key Start at 2024-09-25 04:48:10.1147483 +0000 UTC Parallel: 5 Jobs: 5 Threshold: 50.00MB PartSize: auto VerifyLength: false VerifyMd5: false CheckpointDir: C:\Users\Administrator\.obsutil_checkpoint [====================================================] 100.00% 1.68 MB/s 8.46MB/8.46MB 5s Upload successfully, 8.46MB, d:\temp\test.txt --> obs://bucket-test/key, cost [55], status [200], request id [00000192421F4E224012B8470C0CCCDC] 
- Take the Windows OS as an example. Run the obsutil sync d:\temp obs://bucket-test/temp command to synchronously upload a folder.
    obsutil sync d:\temp obs://bucket-test/temp Start at 2024-09-25 04:48:10.1147483 +0000 UTC Parallel: 5 Jobs: 5 Threshold: 50.00MB PartSize: auto VerifyLength: false VerifyMd5: false CheckpointDir: C:\Users\Administrator\.obsutil_checkpoint Task id: 104786c8-27c2-48fc-bc6a-5886596fb0ed OutputDir: C:\Users\Administrator\.obsutil_output [========================================================] 100.00% tps:35.71 2.02 KB/s 7.20MB/7.20MB 0s Succeed count: 5 Failed count: 0 Succeed bytes: xxxx Metrics [max cost:90 ms, min cost:45 ms, average cost:63.80 ms, average tps:35.71, transferred size: 7.20MB] Task id: 104786c8-27c2-48fc-bc6a-5886596fb0ed 
- For more examples, see Synchronous Upload.
Parameter Description
| Parameter | Optional or Mandatory | Description | 
|---|---|---|
| file_url | Mandatory for uploading a file synchronously | The local file path | 
| folder_url | Mandatory for uploading a folder synchronously | The local folder path | 
| bucket | Mandatory | The bucket name | 
| key | Optional | The object name or object name prefix specified when uploading a file synchronously, or the object name prefix specified when uploading a folder synchronously The rules are as follows: 
 
         NOTE: 
         
 | 
| fr | Optional for synchronously uploading a file (additional parameter) | Generates an operation result file when synchronously uploading a file. | 
| arcDir | Optional (additional parameter) | The path to which the synchronously uploaded files are archived | 
| dryRun | Optional (additional parameter) | Conducts a dry run. | 
| link | Optional (additional parameter) | The actual path of a symbolic link for a file or folder 
         NOTICE: 
         
 | 
| vlength | Optional (additional parameter) | After the synchronous upload is complete, checks whether the sizes of the objects in the bucket are the same as those of the local files. | 
| vmd5 | Optional (additional parameter) | After the synchronous upload is complete, checks whether the MD5 values of the objects in the bucket are the same as those of the local files. 
         NOTE: 
         
 
         CAUTION: 
         If your object needs encryption, do not use this parameter. | 
| p | Optional (additional parameter) | The maximum number of concurrent multipart upload tasks when uploading a file. The default value is the value of defaultParallels in the configuration file. | 
| threshold | Optional (additional parameter) | The threshold for enabling multipart upload, in bytes. The default value is the value of defaultBigfileThreshold in the configuration file. 
         NOTE: 
         
 | 
| acl | Optional (additional parameter) | The access control policies that can be specified when synchronously uploading files. Possible values are: 
 
         NOTE: 
         The preceding four values indicate private read and write, public read, public read and write, and bucket owner full control. | 
| sc | Optional (additional parameter) | The storage classes of objects that can be specified when synchronously uploading files. Possible values are: 
 | 
| meta | Optional (additional parameter) | The customized metadata that can be specified when uploading files. The format is key1:value1#key2:value2#key3:value3. 
         NOTE: 
         The preceding value indicates that the object in the bucket contains three groups of customized metadata after the file is uploaded: key1:value1, key2:value2, and key3:value3. | 
| ps | Optional (additional parameter) | The size of each part in a multipart upload task, in bytes. The value ranges from 100KB to 5GB. The default value is the value of defaultPartSize in the configuration file. 
         NOTE: 
         
 | 
| cpd | Optional (additional parameter) | The folder where the part records reside. The default value is .obsutil_checkpoint, the subfolder in the home directory of the user who executes obsutil commands. 
         NOTE: 
         A part record is generated during a multipart upload and saved to the upload subfolder. After the upload succeeds, its part record is deleted automatically. If the upload fails or is suspended, the system attempts to resume the task according to its part record when you perform the upload the next time. | 
| j | Optional for synchronously uploading a folder (additional parameter) | The maximum number of concurrent tasks for uploading a folder synchronously. The default value is the value of defaultJobs in the configuration file. 
         NOTE: 
         The value is ensured to be greater than or equal to 1. | 
| exclude | Optional for synchronously uploading a folder (additional parameter) | The file matching patterns that are excluded, for example: *.txt 
         NOTE: 
         
 
         NOTICE: 
         
 | 
| include | Optional for synchronously uploading a folder (additional parameter) | The file matching patterns that are included, for example: *.jpg 
         NOTE: 
         
 
         NOTICE: 
         
 | 
| at | Optional for synchronously uploading a folder (additional parameter) | Indicates that when synchronously uploading a folder, only the files whose latest access time is within the value of timeRange are uploaded. 
         NOTE: 
         
 | 
| disableDirObject | Optional for synchronously uploading folders (additional parameter) | Indicates the folders themselves are not uploaded as an object. Configuring this parameter can avoid uploading empty folders to a bucket. If a folder contains files, the files will be uploaded and the original path format is retained. | 
| timeRange | Optional for synchronously uploading a folder (additional parameter) | The time range matching pattern when synchronously uploading files. Only files whose latest modification time is within the configured time range are uploaded. This pattern has a lower priority than the file matching patterns (exclude/include). That is, the time range matching pattern is executed after the configured file matching patterns. 
         NOTE: 
         
 
         NOTICE: 
         Time in the matching pattern is the UTC time. | 
| mf | Optional (additional parameter) | Indicates that the name matching pattern (include or exclude) and the time matching pattern (timeRange) also take effect on folders. | 
| o | Optional (additional parameter) | The folder that stores the result files. After the command is executed, result files (possibly success, failure, and warning files) will be created in the specified folder. The default value is .obsutil_output, a subfolder in the user's home directory where obsutil commands are executed. 
         NOTE: 
         
 | 
| config | Optional (additional parameter) | The user-defined configuration file for executing the current command. To learn the parameters that can be configured in this file, see Configuration Parameters. | 
| e | Optional (additional parameter) | The endpoint | 
| i | Optional (additional parameter) | The user's AK | 
| k | Optional (additional parameter) | The user's SK | 
| t | Optional (additional parameter) | The user's security token | 
Response
Refer to Response for uploading an object.
Feedback
Was this page helpful?
Provide feedbackThank you very much for your feedback. We will continue working to improve the documentation.
 
    