すべてのプロダクト
Search
ドキュメントセンター

Object Storage Service:cp (ファイルのアップロード)

最終更新日:Jun 13, 2026

ローカルのファイル、画像、動画、その他のリソースを OSS にアップロードする場合や、大容量ファイルをアップロードする場合は、ossutil の cp コマンドを使用します。

重要事項

  • ファイルをアップロードするには、oss:PutObjectoss:ListParts、および oss:AbortMultipartUpload 権限が必要です。詳細については、「RAM ユーザーへのカスタム権限ポリシーの付与」をご参照ください。

  • バッチアップロードは、ソースがディレクトリの場合にのみサポートされます。

  • -u, --update オプションを使用すると、送信先オブジェクトの有無にかかわらず、各ファイルについて少なくとも 1 回の HEAD リクエストが送信され、送信先オブジェクトと比較されます。データの変更が頻繁でないシナリオでは、これにより多数の非効率なリクエストが発生し、パフォーマンスが低下したり、追加のリクエスト料金が発生したりする可能性があります。このオプションを使用する前に、ビジネス要件を慎重に評価し、不要なリソース消費を回避してください。

コマンド構文

ossutil cp source dest [flags]

パラメーター

タイプ

説明

source

string

ローカルファイルパス。相対パス、絶対パス、および - をサポートします。- に設定すると、標準入力からデータを読み取ります。

dest

string

送信先バケット内のファイルパス。例:oss://bucket[/prefix]

--acl

string

オブジェクトのアクセス権限。有効値:

  • private:非公開。

  • public-read:公開読み取り。

  • public-read-write:公開読み書き。

  • default:バケットから継承。

--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

ソースオブジェクトからコピーするプロパティを決定します。有効値:

  • none

  • metadata

  • default

--checkpoint-dir

string

  • チェックポイントディレクトリパスを指定しない場合、再開可能なアップロードは無効になります。

  • ディレクトリを指定した場合、再開可能なアップロードが有効になり、チェックポイントファイルは指定されたパス下の .ossutil_checkpoint サブディレクトリに保存されます。

-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。

説明

このオプションは、-f--update--size-only、または --ignore-existing のいずれかを同時に指定した場合にのみ有効です。

--listObjects

/

ListObjects API を使用してオブジェクトをリストします。

--max-size

SizeSuffix

転送するファイルの最大サイズ。デフォルト単位はバイトです。接尾辞 B|K|M|G|T|P も使用できます。注:1K (KiB) = 1024B。

--metadata

strings

key=value 形式のオブジェクトのユーザー定義メタデータ。

--metadata-directive

string

送信先オブジェクトのメタデータの設定方法を指定します。有効値:

  • COPY

  • REPLACE

--metadata-exclude

stringArray

オブジェクトのメタデータに対する除外ルール。

--metadata-filter

stringArray

オブジェクトのメタデータに対するフィルタリングルール。

--metadata-filter-from

stringArray

ルールファイルからオブジェクトのメタデータフィルタリングルールを読み取ります。

--metadata-include

stringArray

オブジェクトのメタデータに対する包含ルール。

--min-age

Duration

指定された時間間隔より前に変更されたファイルのみをアップロードします。デフォルト単位は秒です。h(時間)などの接尾辞を使用できます。例:1h は 1 時間を意味します。

説明

--min-age 1h は、1 時間以上前に変更されたファイルのみをアップロードします。

--max-age

Duration

指定された時間間隔内に変更されたファイルのみをアップロードします。デフォルト単位は秒です。h(時間)などの接尾辞を使用できます。例:1h は 1 時間を意味します。

説明

--max-age 1h は、過去 1 時間以内に変更されたファイルのみをアップロードします。

--min-mtime

Time

指定された時刻以降に変更されたファイルのみをアップロードします。時刻形式:UTC(例:2006-01-02T15:04:05)。

説明

--min-mtime "2006-01-02T15:04:05" は、協定世界時 (UTC) で 2006 年 1 月 2 日 15 時 4 分 5 秒以降に変更されたファイルのみをアップロードします。

--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

オブジェクトのストレージクラス。有効値:

  • Standard:標準ストレージ。

  • IA:低頻度アクセスストレージ。

  • Archive:アーカイブストレージ。

  • ColdArchive:コールドアーカイブストレージ。

  • DeepColdArchive:ディープコールドアーカイブストレージ。

--tagging

strings

key=value 形式のオブジェクトのタグ。

--tagging-directive

string

送信先オブジェクトのタグの設定方法を指定します。有効値:

  • COPY

  • REPLACE

-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