VMware環境における2ノードOracle 19c RACのプロビジョニング手順
本稿では、VMware仮想化プラットフォーム上に2ノードのOracle 19c Real Application Clusters (RAC) データベース環境を構築するための、仮想マシンの作成、OS設定、共有ストレージ構成、ASMLibのプロビジョニング、およびGrid Infrastructureの初期セットアップ手順について記述します。
1. 仮想マシンのプロビジョニング (ノード1: ORA191)
最初のノード(ホスト名: ORA191)をベースライン仮想マシンとして作成します。
1.1. ハードウェア仕様およびVM設定
- VM名:
ORA191 - プロセッサ: 8 vCPU(並列処理およびクラスタのオーバーヘッドに対応するため)
- メモリ: 12 GB(Oracle Grid InfrastructureおよびDatabaseインスタンスの最小要件を満たすため)
- ネットワーク: 1次ネットワークアダプタは外部接続(パッケージダウンロード用)のためにNATに設定
- I/Oコントローラ: LSI Logic SAS(推奨デフォルト)
- 仮想ディスクタイプ: SCSI
- ディスク容量:
- システム領域として50 GBの単一仮想ディスクファイル(
.vmdk)を割り当て - 💡 データベース作成やパッチ適用時の容量不足を防ぐため、実際の検証環境では100 GB以上の割り当てを推奨します。
- ディスクは「単一ファイルとして格納」を選択し、パフォーマンス向上のために事前割り当て(Pre-allocate)オプションの適用を検討します。
2. OSのインストールと基本設定
Oracle LinuxまたはCentOSを仮想マシンにインストールします。
2.1. ローカリゼーションとソフトウェア選択
- 言語: English (United States)
- 日付と時刻: タイムゾーンを Asia/Seoul に設定し、システムクロックを同期
- ソフトウェア選択: OUIやGrid Setupなどのグラフィカルツールを使用するため、Server with GUI を選択。さらに以下のパッケージグループを追加します。
- KDE(または任意のデスクトップ環境)
- Compatibility Libraries
- Development Tools
- System Administration Tools
2.2. 手動ディスクパーティショニング
50 GBの仮想ディスク(sda)に対して手動パーティショニングを実行します。
パーティション構成:
/boot: 1000 MB(標準パーティション、ext4またはxfs)swap: 24000 MB(24 GB、12 GBのRAM要件に対応するため)/(ルート): 残りの全容量
⚠️ パーティショニング時に既存のパーティションテーブルを消去する警告が表示される場合がありますが、新規インストールの場合はそのまま進行して問題ありません。
2.3. ネットワークとホスト名の設定
ネットワーク設定画面で、プライマリインターフェース(ens33)の「Configure」を選択します。
- Generalタブ: “Automatically connect to this network when it is available” にチェックを入れ、起動時に自動接続されるようにします。
- 接続優先度: 優先度(Connection Priority)はデフォルトの
0のままとします。 - ホスト名: 静的ホスト名を
ora191に設定し、適用します。
3. OSインストール後のカスタマイズ
3.1. VMware共有フォルダの設定
ホストOSとゲストOS間でのインストールメディア等のファイル転送を容易にするため、VMwareの設定から「Shared Folders」を「Always enabled」に設定し、ホスト側のディレクトリをマウントします。
3.2. Oracle Pre-installation RPMの実行
oracle-database-preinstall-19c パッケージを使用して、カーネルパラメータ、リソース制限(limits.conf)、および必要なOSユーザーとグループの作成を自動化します。パッケージマネージャー(yum)がバックグラウンドプロセスによってロックされている場合は、以下の手順でプロセスを終了させてから実行します。
rm -f /var/run/yum.pid
yum install -y oracle-database-preinstall-19c
3.3. ユーザーおよびグループのカスタマイズ
プリインストールRPMによって作成された oracle ユーザーに加え、Grid Infrastructure用の grid ユーザーを手動で作成し、グループ構成を調整します。
groupadd -g 54321 oinstall
groupadd -g 54322 dba
groupadd -g 54323 oper
useradd -u 1200 -g oinstall -G dba,oper grid
usermod -u 1201 -g oinstall -G dba,oper oracle
設定の確認:
id oracle コマンドを実行し、マッピングが正確に行われているか確認します。
uid=1201(oracle)gid=54321(oinstall)groups=54321(oinstall),54322(dba),54323(oper)
4. 環境変数とシェル制限の設定
4.1. Oracleユーザーの環境変数 (/home/oracle/.bash_profile)
oracle ユーザーの .bash_profile に以下の設定を追加します。
export ORACLE_BASE=/u01/app/oracle
export ORACLE_HOME=$ORACLE_BASE/product/19.3.0/dbhome_1
export ORACLE_SID=ORA191
export PATH=$ORACLE_HOME/bin:$PATH
umask 022
ORACLE_SID: 2ノードRACではノードごとに一意である必要があります。umask 022: 新規作成されるファイルおよびディレクトリのデフォルト権限を制御します。
4.2. Gridユーザーの環境変数 (/home/grid/.bash_profile)
grid ユーザーの .bash_profile に以下の設定を追加します。
export ORACLE_BASE=/u01/app/grid
export ORACLE_HOME=/u01/app/19.3.0/grid
export ORACLE_SID=+ASM1
export PATH=$ORACLE_HOME/bin:$PATH
umask 022
ORACLE_SID: ノード1のASMインスタンス識別子として+ASM1を指定します。
5. ディレクトリ構造の作成と権限設定
root ユーザーでログインし、マウントポイントを作成して所有権と権限を割り当てます。
mkdir -p /u01/app/19.3.0/grid
mkdir -p /u01/app/grid
mkdir -p /u01/app/oracle
chown -R grid:oinstall /u01
chown -R oracle:oinstall /u01/app/oracle
chmod -R 775 /u01
6. ネットワーク設計と名前解決
6.1. インターフェースの確認
ip addr コマンドでプライマリインターフェースの状態を確認します。
ip addr show ens33
<up,lower_up> フラグにより、物理層および論理層がアクティブであることを確認します。
6.2. 静的な名前解決設定 (/etc/hosts)
DNSサーバーを使用しない環境向けに、両ノードの /etc/hosts に以下のマッピングを追加します。
# Public
192.168.10.11 ora191
192.168.10.12 ora192
# Private
172.16.40.11 ora191-priv
172.16.40.12 ora192-priv
# Virtual IP (VIP)
192.168.10.21 ora191-vip
192.168.10.22 ora192-vip
# SCAN
192.168.10.31 ora-scan
- Private IP: ノード間のインターコネクトおよびCache Fusion専用の帯域です。
- Virtual IP (VIP): Oracle Clusterwareが管理する高可用性IP。
- SCAN (Single Client Access Name): クライアントがクラスタへ接続するための共通エントリポイントです。
6.3. ホスト名と時刻同期の設定
静的ホスト名を設定し、不要なファイアウォールを無効化します。また、ノード間の時刻ズレによるクラスタ強制終了(Eviction)を防ぐため、NTPを設定します。
hostnamectl set-hostname ora191
systemctl stop firewalld
systemctl disable firewalld
7. ノードのクローン作成とノード2の個別設定
シャットダウンしたノード1(ORA191)をベースに、ノード2(ORA192)をクローン作成します。
7.1. フルクローンの実行
- VMwareの管理メニューから「Clone」を選択します。
- 「Clone from current state」を選択します。
- Clone Type: Full Clone を選択します。
- 移行先VM名を
ORA192に指定します。
7.2. ノード2のホスト名および環境変数のカスタマイズ
ORA192 を起動し、root ユーザーでログインして個別設定を行います。
hostnamectl set-hostname ora192
grid ユーザーの /home/grid/.bash_profile のASM SIDを修正します。
sed -i 's/+ASM1/+ASM2/g' /home/grid/.bash_profile
oracle ユーザーの /home/oracle/.bash_profile のデータベースSIDを修正します。
sed -i 's/ORA191/ORA192/g' /home/oracle/.bash_profile
8. ASMLibのインストール
ASMディスクの管理を容易にするため、両方のノードで以下のパッケージをインストールします。
yum install -y oracleasm-support kmod-oracleasm
yum install -y oracleasmlib
9. 共有ストレージ設定 (VMware VMXファイルの編集)
Oracle RACでは、両ノードから同時に読み書き可能な共有ディスクが必要です。
9.1. ノード1 (ORA191) への共有ディスク追加
ORA191の設定画面から「Add > Hard Disk」を選択。- SCSI を選択し、必要な容量を割り当てます。
- 追加した各ディスクの「Advanced」プロパティを開き、Independent および Persistent にチェックを入れます。
9.2. .vmx 設定ファイルの編集
両方のVMがロック競合を起こさずに同一ディスクにアクセスできるよう、各ノードの .vmx ファイルを編集します。両方のファイルの末尾に以下のパラメータを追加します。
disk.locking = "FALSE"
diskLib.dataCacheMaxSize = "0"
scsi0.sharedBus = "virtual"
disk.locking = "FALSE": VMwareによるディスクロックを無効化します。scsi0.sharedBus = "virtual": 複数VM間でのSCSIバス共有を可能にします。
10. プライベートネットワークアダプタの追加
ノード間のインターコネクト用に、2枚目のネットワークアダプタを追加します。
ORA191の設定から「Add > Network Adapter」を選択。- ネットワーク接続タイプを Host-only に設定。
- 「Advanced」から「Generate」をクリックし、一意のMACアドレスを生成します。
ORA192に対しても同様の手順を実行し、必ずMACアドレスを再生成してください。
11. プライベートネットワークインターフェースの設定 (ens36)
11.1. ノード1 (ORA191) の設定
IPv4設定を「Manual」に変更し、以下のように設定します。
- Address:
172.16.40.11 - Netmask:
255.255.255.0
11.2. ノード2 (ORA192) の設定
- Address:
172.16.40.12 - Netmask:
255.255.255.0
12. ASMディスクのプロビジョニング
12.1. ASMLibの初期化 (両ノード)
両方のノードで root ユーザーとして初期化ユーティリティを実行します。
oracleasm configure -i
- Owner user:
grid - Owner group:
dba - Start on boot:
y - Scan on boot:
y
oracleasm init
12.2. ディスクパーティショニング (ノード1のみ)
追加した共有ディスクを、ノード1のみでパーティショニングします。
fdisk /dev/sdb
# n -> p -> 1 -> default -> default -> w
12.3. ASMディスクの作成 (ノード1のみ)
oracleasm createdisk ASMDISK01 /dev/sdb1
12.4. ノード2でのディスクスキャン
作成したディスクをノード2に認識させるため、スキャンを実行します。
# Node 1
oracleasm scandisks
# Node 2
oracleasm scandisks
oracleasm listdisks
13. Grid Infrastructureのインストール
13.1. インストール前処理
DNS競合を防ぐため、両ノードで avahi-daemon を停止します。
systemctl stop avahi-daemon
systemctl disable avahi-daemon
ノード1の grid ユーザーでインストールメディアを展開します。
cd $ORACLE_HOME
unzip -q /mnt/hgfs/shared/LINUX.X64_193000_grid_home.zip
./gridSetup.sh
13.2. セットアップウィザードの要点
- Cluster Type: Configure a Standalone Cluster を選択。
- Cluster Node Information: ノード2 (
ora192,ora192-vip) を追加。 - SSH Connectivity:
gridユーザーのパスワードを入力し「Setup」を実行。 - Network Interface:
ens33を Public、ens36を 1st Private に設定。 - Storage: Use ASM を選択し、Discovery Path を
/dev/oracleasm/disks/*に設定。
Operational Notes
本手順で構築した環境は、VMware Workstation等のハイパーバイザー上で動作する2ノードRACの最小構成モデルです。実稼働環境への適用にあたっては、共有ストレージの物理的な冗長化(SAN/NASマルチパス設定)や、ネットワークのチーミング(Bonding)を別途検討する必要があります。特に .vmx における disk.locking = "FALSE" 設定は、Clusterwareが停止している状態で両ノードから直接マウントを行うとデータ破損を招くリスクがあるため、運用管理には細心の注意を払ってください。</up,lower_up>