はじめに
2023/11/9 に Amazon RDS for Oracleでマルチテナント構成のサポートが発表されました。
RDS for Oracleでは以前(2021/5)より マルチテナントアーキテクチャを利用した単一のプラガブルデータベース構成 はサポートされていましたが、文字通りのマルチテナント構成は今回のアップデートで初めて利用できるようになりました。マルチテナントアーキテクチャにおける単一のプラガブルデータベース構成自体はあまり意味がある構成ではなかったため、今回のアップデートで本格的にマルチテナントの恩恵を受けることができるようになると考えてます。
以下で、マルチテナント構成を実際に試して、何ができるようになったか、また、何ができないのかを確認していきます。
マルチテナント構成を作成してみる
RDSの作成において、Oracle Databaseを選択すると、以下のようなアーキテクチャ設定において、シングルテナントかマルチテナントを選択することができます。記載あるように、シングルテナントからマルチテナントへの変更は可能ですが、マルチテナントからシングルテナントへの変更はNGになります。
マルチテナント設定をすると、テナント側のデータベースの設定(PDB:プラガブルDB)の名前、マスタユーザ・パス、文字セットを選択することができます。
データベースを作成すると、以下のようにインスタンスとテナントデータベースが作成されます。
マルチテナント構成のデータベースの確認
作成されたデータベースを確認すると、以下のように「テナントデータベース」のタブが新しくできていることがわかります。
テナントデータベースでは以下のように インスタンスデータベース や テナントデータベース が確認できます。Oracle Databaseの正式な名称では、インスタンスデータベース は コンテナデータベース(CDB)、テナントデータベース は プラガブルデータベース(PDB) になります。今回は以下のような形ですね。
- インスタンスデータベース:CDB
- mtestdb1
- テナントデータベース:PDB
- PDB01
テナントデータベース(PDB)に対してのアクションは現時点では名称の変更とマスターユーザのパスワード変更、そして削除のみが許可されています。
削除については、一つしかテナントデータベース(PDB)がない場合には以下のようなエラーが出て削除できません。
テナントデータベース(PDB)の追加
インスタンスデータベース(CDB)のアクションを確認すると、以下のようにテナントデータベース(PDB)を追加することができます。
初期作成時と同様に、テナントデータベース(PDB)の名称、マスターユーザー名・パス、データベース文字セットを設定することができます。
作成すると、以下のような状態になります。既存のテナントデータベース(PDB)は利用可能な状態です。
ここで、アラートログを確認すると、以下のような形で作成されていることがわかります。
CREATE PLUGGABLE DATABASE PDB02 AS CLONE USING '/rdsdbdata/tmp/tdbtemplates/pdbtemplate/pdbtemplate.19.0.0.0.base.pdb'
作成が完了すると、以下のようになります。
テナントデータベース(PDB)の管理
マルチテナント構成のOracle Databaseは、通常は各テナントデータベース(PDB)の停止や切り離し(Unplug)、追加(Plug)やリソースケージング(PDB毎のリソース制限)、PDB毎のリソース監視、PDB毎のPITR(Point In Time Recovery)を行うことができます。
RDS for Oracleの場合、インスタンス(CDB)にアクセスできず、また、GUI上のアクションで該当のコマンドが現時点(2023/11/11)では提供されていないため、各テナントデータベース(PDB)の管理は行えません。
まとめ
今までのRDS for Oracleではマルチテナントアーキテクチャを用いてはいましたが、シングルテナントのみしか利用できず、マルチテナントアーキテクチャのメリットを活用できていませんでした。
今回、テナントデータベース(PDB)を複数利用できるようになったため、マルチテナントの恩恵であるデータベースレベルでの分離を行うことができるようになりました。
ただ、現時点ではテナントデータベース(PDB)個別の管理がほぼできないため、活用するユースケースは絞られると考えています。しかしながら、今後拡張されていることは想像に難くないため、今のうちからマルチテナントアーキテクチャが利用できるようになったときにどのように自社のシステムに適用できるか、考えておくとよいと思います。
また、RDS Custom for Oracleではすでにマルチテナント構成がサポートされています。