Oracle Data Pumpの使用
Oracle Data Pumpは、Oracleデータベースと専用Exadataインフラストラクチャ上のAutonomous Database間で、データおよびメタデータの非常に高速な一括移動を提供します。
Data Pump Importを使用すると、Oracle Cloud Infrastructure Object StorageおよびOracle Cloud Infrastructure Object Storage ClassicにあるData Pumpファイルからデータをインポートできます。データをクラウド・オブジェクト・ストアに保存し、Oracle Data Pumpを使用してデータをAutonomous Databaseにロードできます。
- 既存のOracle Databaseからのデータのエクスポート
まず、Oracle Data Pump Exportを使用して既存のOracle Databaseスキーマをエクスポートします。次に、Oracle Data Pump Importを使用してAutonomous Databaseに移行します。 - クラウド・オブジェクト・ストレージへのエクスポート・ファイルのアップロード
ソースOracle Databaseからエクスポートしたデータをインポートする前に、エクスポート・ファイルをクラウド・オブジェクト・ストレージにアップロードする必要があります。 - Oracle Data Pumpを使用したデータのインポート
Data PumpファイルのデータをAutonomous Databaseにインポートする場合は、最新のOracle Data Pumpバージョンを使用することをお薦めします。これには操作性向上のための拡張機能と修正が含まれています。 - Data Pump Importのログ・ファイルへのアクセス
Data Pump Import操作のログ・ファイルは、データ・ポンプのimpdp
directoryパラメータで指定したディレクトリに格納されます。
親トピック: Autonomous Databaseへのデータの移動
既存のOracle Databaseからのデータのエクスポート
まず、Oracle Data Pump Exportを使用して既存のOracle Databaseスキーマをエクスポートします。次に、Oracle Data Pump Importを使用してAutonomous Databaseに移行します。
高速かつ簡単にAutonomous Databaseに移行できるように、次のData Pump Exportパラメータを使用することをお薦めします:
exclude=cluster, db_link parallel=n schemas=schema name dumpfile=export%u.dmp
Oracle Data Pump Exportには、複数のエクスポート・モードが用意されています。Autonomous Databaseに移行する場合は、スキーマ・モードの使用をお薦めします。エクスポートするスキーマは、schemasパラメータを使用してリストできます。
移行を高速化するには、スキーマを複数のData Pumpファイルにエクスポートして、並列処理を使用します。使用するダンプ・ファイル名のフォーマットは、dumpfileパラメータを使用して指定できます。parallelパラメータをAutonomous DatabaseのCPUの数以上に設定します。
excludeパラメータおよびdata_optionsパラメータを使用することで、Autonomous Databaseで使用できないオブジェクト・タイプはエクスポートされず、表パーティションは、Autonomous Databaseに高速にインポートできるようにグループ化されます。
expdp
コマンドを実行する前に、最新の統計を収集することをお薦めします。dbms_stats
パッケージには、最新の統計を収集するための複数のプロシージャが用意されています。統計はエクスポート・ダンプ・ファイルに自動的に追加され、インポート中のオブジェクトのサイズの判別および並列度の最適化に役立ちます。詳細は、DBMS_STATSの操作ノートを参照してください。
次の例では、16個のCPUを持つAutonomous Databaseに移行するために、ソースOracle DatabaseからSHスキーマをエクスポートします:
expdp sh/sh@orcl \
exclude=cluster, db_link \
parallel=16 \
schemas=sh \
dumpfile=export%u.dmp
要件に応じて、compression
などの他のData Pump Exportパラメータを使用できます。Oracle Data Pump Exportの詳細は、『Oracle Databaseユーティリティ』を参照してください。
親トピック: Oracle Data Pumpの使用
クラウド・オブジェクト・ストレージへのエクスポート・ファイルのアップロード
ソースOracle Databaseからエクスポートしたデータをインポートする前に、エクスポート・ファイルをクラウド・オブジェクト・ストレージにアップロードする必要があります。
エクスポート・ファイルは、Oracle Cloud Infrastructure Object Storageの既存のストレージ・バケットまたはOracle Cloud Infrastructure Object Storage Classicの既存のストレージ・コンテナにアップロードできます。または、次の手順を使用して、新しいストレージ・バケットを作成し、そこにエクスポート・ファイルをアップロードします。
-
cloud.oracle.comでOracle Cloudアカウントにサインインします。
-
Oracle Cloud Infrastructureの左側のナビゲーション・リストから「オブジェクト・ストレージ」を選択し、サブリストから「オブジェクト・ストレージ」を選択します。
-
ストレージ・バケットを作成するコンパートメントを選択します。
-
「バケットの作成」をクリックします。
-
「バケットの作成」ダイアログで、バケットに名前を付けて、「バケットの作成」をクリックします。
-
バケットが作成されたら、バケットのリストでその名前をクリックして、その「バケット詳細」ページを表示します。
-
「オブジェクト」ボックスで、「オブジェクトのアップロード」をクリックします。
-
「オブジェクトのアップロード」ダイアログで、「コンピュータからのファイルの選択」ボックスの「ファイルの選択」リンクをクリックします。
-
ファイル・ブラウザで、エクスポート・ファイルに移動して選択します。次に、「開く」をクリックします。
-
「オブジェクトのアップロード」ダイアログで、「オブジェクトのアップロード」をクリックして、選択したファイルのアップロードを開始します。
-
アップロードが完了したら、「オブジェクトのアップロード」ダイアログを閉じます。
親トピック: Oracle Data Pumpの使用
Oracle Data Pumpを使用したデータのインポート
Data PumpファイルのデータをAutonomous Databaseにインポートする場合は、最新のOracle Data Pumpバージョンを使用することをお薦めします。これには操作性向上のための拡張機能と修正が含まれています。
「Oracle Instant Clientのダウンロード」から、使用しているプラットフォーム用の最新バージョンのOracle Instant Client Basicパッケージおよびツール・パッケージ(Oracle Data Pumpが含まれる)をダウンロードします。Oracle Instant Clientをダウンロードした後に必要なインストール・ステップについては、プラットフォーム・インストールのダウンロード・ページでインストールの手順を参照してください。
Oracle Data Pumpバージョン18.3以降では、credential
引数により、ソース・ファイルに使用しているクラウド・オブジェクト・ストレージ・サービスに対してData Pumpが認証されます。dumpfile
引数は、Data PumpファイルのURLをカンマで区切ったリストです。
Data Pump Importバージョン12.2.0.1以前には、credential
パラメータがありません。古いバージョンのData Pump Importを使用している場合は、Autonomous Databaseにデフォルトの資格証明プロパティを定義し、dumpfile
パラメータでdefault_credential
キーワードを使用する必要があります。
Oracle Data Pumpで、ソース・ファイルがOracle Cloud Infrastructure Object Storageに存在する場合は、Oracle Cloud InfrastructureのネイティブURIまたはSwift URIを使用できます。これらのURIフォーマットの詳細は、クラウド・オブジェクト・ストレージのURIフォーマットを参照してください。
親トピック: Oracle Data Pumpの使用
Data Pump Importのログ・ファイルへのアクセス
Data Pump Import操作のログ・ファイルは、データ・ポンプのimpdp
directoryパラメータで指定したディレクトリに格納されます。
ログ・ファイルにアクセスするには、プロシージャDBMS_CLOUD.PUT_OBJECT
を使用してログ・ファイルをクラウド・オブジェクト・ストレージに移動する必要があります。たとえば、次のPL/SQLブロックでは、import.log
ファイルがクラウド・オブジェクト・ストレージに移動されます:
BEGIN
DBMS_CLOUD.PUT_OBJECT
(
credential_name => 'DEF_CRED_NAME',
object_uri => 'https://objectstorage.us-ashburn-1.oraclecloud.com/n/namespace-string/b/bucketname/o/import.log',
directory_name => 'DATA_PUMP_DIR',
file_name => 'import.log');
END;
/
この例では、namespace-string
はOracle Cloud Infrastructureオブジェクト・ストレージ・ネームスペースで、bucketname
はバケット名です。詳細は、オブジェクト・ストレージ・ネームスペースの理解を参照してください。
詳細は、オブジェクトおよびファイルのDBMS_CLOUDを参照してください。
親トピック: Oracle Data Pumpの使用