はじめに
Oracle19cが発表されしばらくたちますが Oracle SE RACの非サポート、Oracle Faile Safe(OFS)の非推奨化 とOracleDB冗長化の実現方法にインパクトのある情報も多くありました。若干いまさらですがOracle19cにおけるDB冗長化パターンを比較してみました。
また、独断と偏見で、コスト、可用性、将来性、構築容易性について★で評価をつけてみたので、皆さんのご参考になれば幸いです。
1.OS仮想化(Soft Partitioning)を活用した冗長化
コスト★☆☆、可用性★★☆、将来性★★★、構築容易性★★★、Active/Standby
VMWare やHyper-V等による冗長化です。
Oracleの構築としてはシングルインスタンスを構築するだけなので非常に容易に構築が可能ですが、プロセス障害などの復旧には対応しておらず、HW故障時にはOS再起動による復旧になるため可用性は若干落ちます。
また、Oracle DataBaseの ライセンスは物理サーバ台数分 かかるのでOracleライセンスにかかるコストは比較的高くなります。
2.OS仮想化(Hard Partitioning)を活用した冗長化
コスト★☆☆、可用性★★☆、将来性★★★、構築容易性★★★、Active/Standby
基本的には1とのSoft Partitioningと同じです。
Oracleの構築としてはシングルインスタンスを構築するだけなので非常に容易に構築が可能ですが、プロセス障害などの復旧には対応しておらず、HW故障時にはOS再起動による復旧になるため可用性は若干落ちます。
また、Soft Partitioning のOS冗長化と異なり Oracle DataBaseのライセンスは仮想OS分しか必要ありません が、Hard PartitioningができるHardWareは比較的高価なのでコストはそれなりにかかります。
3.Oracle19c Oracle Fail Safe(OFS)
コスト★★☆、可用性★★☆、将来性☆☆☆、構築容易性★★☆、Active/Standby
2つのサーバにOracleDataBaseをインストールしOracle ClusterWareのインストールおよび設定が必要なので構築難易度はやや高めです。プロセス障害などの復旧にも対応していますが、フェールオーバー時にはOracleインスタンスの再起動が発生するためダウンタイムがあり、可用性は100%ではありません。Oracle Database Standard Editionでも構築が可能で フェイルオーバー構成になるため待機サーバ分のライセンスは不要 なためOracle Data Baseライセンスは安価ですみますが、サーバー2台とiSCSI等の共有ディスクが必要になるためHWコストは若干かかります。
また、Oracle社より Oracle19cではOFSは非推奨 と案内が出ており将来性に不安があるため、同一サーバ構成でOracleのバージョンアップを考えている場合は採用を控えたほうが良いと思われます。
4.Oracle Real Application Cluster (RAC)
コスト☆☆☆、可用性★★★、将来性★★★、構築容易性★☆☆、Active/Active
これまで紹介した構成に比べると、複数サーバへのOracleインストール、複数IPアドレスの準備、ASM共有ディスクの準備など、DBの構築難易度は最も高いです。プロセス障害にも対応しており、フェールオーバー時にもDBのダウンタイムがないため可用性はピカイチと言えます。
冒頭で案内した通り、Oracle 19cからはSE RACがサポート対象外になりRACを組む場合はEnterPriseEditionが必須になったためOracleDataBaseのライセンス費用は最も高くなりますし、iSCSI等の共有ディスクが必要になるためHWコストもかかります。
私見ですが、これまでの冗長化機能のサポート打ち切りの方針を見ているとRACに力を入れているように見えるので、将来性については問題ないと思われます。
5.Oracle19c Standard Edtion High Availavility(SEHA)
コスト★★☆、可用性★★☆、将来性★★★、構築容易性☆☆☆、Active/Standby
Oracle19cからサポートされた構成ですが、RACのアーキテクチャを利用したActive/Stanby構成。RACとOFSを足して2で割った感じという印象です。
構築では複数サーバへのOracleインストール、複数IPアドレスの準備、ASM共有ディスクの準備等、DBの構築難易度は最も高く、また情報や実績もまだ少ないため個人的にRACよりも難易度を高く設定しました。
プロセス障害にも対応していますが、フェールオーバー時にはインスタンスの再起動が発生するため可用性はOFSとほぼ同じと考えてよいでしょう。コスト面ではこちらも フェイルオーバー構成となるためOFSと同じく待機サーバのOracleライセンスは不要 、HW構成もほぼ同じ条件になるためOFSと同じと言えます。Oracle19cからサポートされだした構成なので将来性もしばらくは問題ないでしょう。
6.Oracle19 CDB/PDBホットクローン
コスト★★☆、可用性★☆☆、将来性★★★、構築容易性★☆☆、Active/Standby
こちらは若干トリッキーな構成になります。テスト環境利用で使うことを想定されたPDBクローン機能 を使って、手動フェールオーバーによる半冗長化を実現します。
構築では複数サーバへのOracleインストール、PDBクローンの設定、アーカイブログモード運用の実施など比較的構築難易度は高いです。プロセス障害にも対応していますが、フェールオーバー時にはインスタンスの再起動やインスタンスの切替などのオペレーションが発生し、自動フェールオーバーはされないため可用性はやや低めです。
OracleDataBaseライセンスは複数サーバ分必要ですが、HWに共有ディスクが必要ないため全体的なコストはOFSやSEHAと同じぐらいでしょう。
7.サードベンダー(ClusterPro、LifeKeeper等)の冗長化ソフト
コスト ?、可用性 ?、将来性 ?、構築容易性 ?
サードベンダーの冗長化製品の技術者がいれば現実的な選択肢になります。
一方で冗長化の仕組みも共有ディスク方式、データレプリケーション方式など複数の構成が取れるため、コスト、可用性、構築容易性も一概に説明しずらいため。ここでの説明は割愛させてください。
8.コールドスタンバイ、DMPデータコピー方式
コスト★★★、可用性☆☆☆、将来性★★★、構築容易性★★★、Active/Standby
ダウンタイムが長いためこれを冗長化に含めることに否定的な意見もあるかと思いますが、要件によっては検討の余地があると思っているため、最後の候補としてリストアップしました。
構築ではサーバーを2台準備してOracleDataBaseサーバを2台分インストールしアクティブサーバではDMPを定期的にバックアップ取得しておきます。スタンバイサーバは通常時はサーバーを停止しておき、アクティブサーバに障害が発生した際に、コピーしておいたDMPをインポートして復旧します。手動リカバリーが必要になりインポート時間もかかるため可用性は低いですが、ライセンスも1台分ですみ、共有ディスクも不要なため低コストです。
HW故障によりシステムが2~3日停止したら困るが、1日程度だったら問題ないという要件なら採用の余地ありでしょう。特別な技術や機能を使っていないため将来性にも全く問題ありませんし、構築も容易です。
まとめ
Oracle12c以前でSE RACやOFSを採用していた場合、Oracle19cにおいての最有力候補はSEHAではないでしょうか。
しかし、システムにおける可用性要件とかけられるコストやインフラエンジニアの運用エンジニアのスキル等様々な条件があるので、どの構成が一概に良いとは言えないので自分たちのシステムに求める可用性要件等を考慮して、冗長化を検討していただければと思います。