ローカルのファイル、画像、動画、その他のリソースを OSS にアップロードする場合や、大容量ファイルをアップロードする場合は、ossutil の cp コマンドを使用します。
重要事項
-
ファイルをアップロードするには、
oss:PutObject、oss:ListParts、およびoss:AbortMultipartUpload権限が必要です。詳細については、「RAM ユーザーへのカスタム権限ポリシーの付与」をご参照ください。 -
バッチアップロードは、ソースがディレクトリの場合にのみサポートされます。
-
-u, --updateオプションを使用すると、送信先オブジェクトの有無にかかわらず、各ファイルについて少なくとも 1 回の HEAD リクエストが送信され、送信先オブジェクトと比較されます。データの変更が頻繁でないシナリオでは、これにより多数の非効率なリクエストが発生し、パフォーマンスが低下したり、追加のリクエスト料金が発生したりする可能性があります。このオプションを使用する前に、ビジネス要件を慎重に評価し、不要なリソース消費を回避してください。
コマンド構文
ossutil cp source dest [flags]
|
パラメーター |
タイプ |
説明 |
|
source |
string |
ローカルファイルパス。相対パス、絶対パス、および |
|
dest |
string |
送信先バケット内のファイルパス。例: |
|
--acl |
string |
オブジェクトのアクセス権限。有効値:
|
|
--bandwidth-limit |
SizeSuffix |
ネットワーク帯域幅を制限してデータ転送レートをコントロールします。最小値は 1024 B/s です。デフォルト単位は B/s です。 このパラメーターを設定する際は、必要に応じて単位を指定してください。有効な単位は、B(バイト)、K(キロバイト)、M(メガバイト)、G(ギガバイト)です。たとえば、50 M は帯域幅制限を 50 MB/s に設定します。 |
|
--bigfile-threshold |
SizeSuffix |
大容量ファイルのフラグメントアップロード、ダウンロード、またはコピーを有効にするためのしきい値(バイト単位)。デフォルト値:104857600。 |
|
--cache-control |
string |
Web ブラウザーによるオブジェクトのダウンロード時のキャッシュ動作を指定します。 |
|
--content-disposition |
string |
オブジェクトの表示方法を指定します。 |
|
--content-encoding |
string |
オブジェクトのエンコーディング方式を宣言します。 |
|
--content-type |
string |
オブジェクトのコンテンツタイプ。 |
|
--copy-props |
string |
ソースオブジェクトからコピーするプロパティを決定します。有効値:
|
|
--checkpoint-dir |
string |
|
|
-d, --dirs |
string |
サブディレクトリ内のすべてのファイルを再帰的にリストすることなく、現在のディレクトリ内のファイルおよびサブディレクトリをリストします。 |
|
--encoding-type |
string |
入力オブジェクト名またはファイル名のエンコーディング方式。有効値:url。 |
|
--end-with |
string |
アルファベット順で指定された値より前または一致するオブジェクトを返します。 |
|
--exclude |
stringArray |
パスまたはファイル名に対する除外ルール。 |
|
--exclude-from |
stringArray |
ルールファイルから除外ルールを読み取ります。 |
|
--expires |
stringArray |
キャッシュされたコンテンツの絶対的な有効期限を指定します。 |
|
--files-from |
stringArray |
ファイルからソースファイル名のリストを読み取ります。空行およびコメント行は無視されます。フィルタリングシナリオでのみ適用されます。 |
|
--files-from-raw |
stringArray |
ファイルからソースファイル名のリストを読み取ります。フィルタリングシナリオでのみ適用されます。 |
|
--filter |
stringArray |
パスまたはファイル名に対するフィルタリングルール。 |
|
--filter-from |
stringArray |
ルールファイルからフィルタリングルールを読み取ります。 |
|
-f, --force |
/ |
確認のプロンプトを表示せずに強制的に操作を実行します。 |
|
--include |
stringArray |
パスまたはファイル名に対する包含ルール。 説明
フィルタリングオプションの詳細については、「フィルタリングオプション」をご参照ください。 |
|
--include-from |
stringArray |
ルールファイルから包含ルールを読み取ります。 |
|
-j, --job |
int |
同時タスク数。デフォルト値:3。 説明
このオプションは、 |
|
--listObjects |
/ |
ListObjects API を使用してオブジェクトをリストします。 |
|
--max-size |
SizeSuffix |
転送するファイルの最大サイズ。デフォルト単位はバイトです。接尾辞 B|K|M|G|T|P も使用できます。注:1K (KiB) = 1024B。 |
|
--metadata |
strings |
key=value 形式のオブジェクトのユーザー定義メタデータ。 |
|
--metadata-directive |
string |
送信先オブジェクトのメタデータの設定方法を指定します。有効値:
|
|
--metadata-exclude |
stringArray |
オブジェクトのメタデータに対する除外ルール。 |
|
--metadata-filter |
stringArray |
オブジェクトのメタデータに対するフィルタリングルール。 |
|
--metadata-filter-from |
stringArray |
ルールファイルからオブジェクトのメタデータフィルタリングルールを読み取ります。 |
|
--metadata-include |
stringArray |
オブジェクトのメタデータに対する包含ルール。 |
|
--min-age |
Duration |
指定された時間間隔より前に変更されたファイルのみをアップロードします。デフォルト単位は秒です。h(時間)などの接尾辞を使用できます。例:1h は 1 時間を意味します。 説明
|
|
--max-age |
Duration |
指定された時間間隔内に変更されたファイルのみをアップロードします。デフォルト単位は秒です。h(時間)などの接尾辞を使用できます。例:1h は 1 時間を意味します。 説明
|
|
--min-mtime |
Time |
指定された時刻以降に変更されたファイルのみをアップロードします。時刻形式:UTC(例:2006-01-02T15:04:05)。 説明
|
|
--max-mtime |
Time |
指定された時刻以前に変更されたファイルのみをアップロードします。時刻形式:UTC(例:2006-01-02T15:04:05)。 |
|
--min-size |
SizeSuffix |
転送するファイルの最小サイズ。デフォルト単位はバイトです。接尾辞 B|K|M|G|T|P も使用できます。注:1K (KiB) = 1024B。 |
|
--no-progress |
/ |
進行状況バーを表示しません。 |
|
--page-size |
int |
バッチアップロード中に 1 ページあたりにリストされるオブジェクトの最大数。デフォルト値:1000。有効範囲:1~1000。 |
|
--parallel |
int |
単一ファイルに対する内部操作の同時タスク数。 |
|
--part-size |
SizeSuffix |
フラグメントアップロード時のパーツサイズ。デフォルトでは、ossutil がファイルサイズに基づいて適切なパーツサイズを計算します。有効範囲:100 KiB~5 GiB。 |
|
-r, --recursive |
/ |
再帰的に操作を実行します。このオプションを指定すると、コマンドはバケット内のすべての一致するオブジェクトに対して操作を行います。指定しない場合は、パスで指定されたオブジェクトに対してのみ操作を行います。 |
|
--request-payer |
string |
リクエストの支払い方法。バケットがリクエスト元支払いモードを使用している場合にこのパラメーターを設定します。有効値:requester。 |
|
--size-only |
/ |
サイズが送信先ファイルと異なるソースファイルのみをアップロードします。 |
|
--storage-class |
string |
オブジェクトのストレージクラス。有効値:
|
|
--tagging |
strings |
key=value 形式のオブジェクトのタグ。 |
|
--tagging-directive |
string |
送信先オブジェクトのタグの設定方法を指定します。有効値:
|
|
-u, --update |
/ |
送信先にすでに存在し、かつソースファイルよりも新しい更新時刻を持つファイルをスキップします。 説明
送信先にすでに存在するファイルの更新時刻がソースファイルよりも古い場合は、そのファイルが更新されます。 |
|
--ignore-existing |
/ |
送信先にすでに存在するファイルをスキップします。 |
ossutil 2.3.0 以降では、--job、--parallel、--bigfile-threshold、--part-size、および --write-buffer-size オプションを設定ファイルで構成できます。設定ファイルの該当するプロファイルセクションに key=value 形式(例:job=10)で追記するか、ossutil config set を使用して設定してください。コマンドラインオプションは設定ファイルの設定よりも優先されます。
詳細については、「コマンドラインオプション」をご参照ください。
オブジェクトの命名規則は次のとおりです。
-
単一ファイルのアップロードにおいて、プレフィックスが空の場合、オブジェクト名はファイル名となります。
-
単一ファイルのアップロードにおいて、プレフィックスが "/" で終わる場合、オブジェクト名はプレフィックス + ファイル名となります。
-
バッチアップロードにおいて、プレフィックスが空の場合、オブジェクト名はソースファイルの相対パスとなります。
-
バッチアップロードにおいて、プレフィックスが "/" で終わる場合、オブジェクト名はプレフィックス + ソースファイルの相対パスとなります。
-
バッチアップロードにおいて、プレフィックスが "/" で終わらない場合、オブジェクト名はプレフィックス + "/" + ソースファイルの相対パスとなります。
ソースファイルの相対パスはルートディレクトリ以降から始まります。たとえば、cp /root/dir/ ... を実行する場合、ファイル /root/dir/subdir/test.txt の相対パスは subdir/test.txt です。
使用例
単一ファイルのアップロード
-
単一ファイルのアップロード
ローカルファイル examplefile.txt を examplebucket の desfolder フォルダにアップロードします。
ossutil cp D:/localpath/examplefile.txt oss://examplebucket/desfolder/
複数ファイルのアップロード
-
フォルダ内のファイルのみをアップロード
ローカルフォルダ localfolder 内のファイルを examplebucket の desfolder フォルダにアップロードします。
ossutil cp -r D:/localpath/localfolder/ oss://examplebucket/desfolder/ -
条件に一致するファイルをバッチアップロード
TXT ファイル形式のすべてのファイルをアップロードします。
ossutil cp -r D:/localpath/localfolder/ oss://examplebucket/desfolder/ --include "*.txt" -
10 個の同時タスクを使用してバッチアップロードを実行
ossutil cp -r D:/localpath/localfolder/ oss://examplebucket/desfolder/ -f -j 10
アップロード速度の制限
-
ローカルファイル upload.rar を examplebucket の desfolder フォルダに 20 MB/s でアップロードします。デフォルト単位は秒あたりバイト (B/s) です。
ossutil cp D:/upload.rar oss://examplebucket/desfolder/ --bandwidth-limit 20971520 -
ローカルファイル file.rar を examplebucket の desfolder フォルダにアップロードし、アップロード速度を 50 MB/s に制限します。単位を秒あたりメガバイト (MB/s) として指定します。
ossutil cp D:/file.rar oss://examplebucket/desfolder/ --bandwidth-limit 50M