Oracle Databaseの基本を身につけるBronze DBAの資格勉強をしたので、自分の理解を深めるためにも、その内容を数回に分けてまとめてみます!
まず1回目は、後述するOracle Databaseを使用する流れの「データベースを作成する」までをまとめたいと思います。
参考書
今回の資格勉強では、日本オラクル株式会社のオラクルマスター教科書「Oracle DBA Oracle Database Fundamentals」を使いました。
この記事では、この参考書で学習した内容をOracle Databaseを使用するときの流れに沿って整理していきたいと思います。
Oracle Databaseを使用する流れ(データベースの作成まで)
-
Oracle ソフトウェアをインストールする
1.1 インストールする前の準備
1.2 ソフトウェアをインストールするためのツール -
Oracleデータベースを作成する
2.1 Database Configuration Assistant (DBCA)
2.2 テンプレートの管理 - Bronze DBAの勉強をして感じたこと
1. Oracleソフトウェアをインストールする
1.1 インストールする前の準備
インストールするために必要な前提条件は次の4つ
- サポートされているバージョンであること
- 記憶域(ストレージ)の空き容量が十分にあること
- 物理メモリーサイズが十分にあること
- インストールに使用するOSユーザー、グループが存在すること
4つのうち、「インストールに使用するOSユーザー、グループが存在すること」以外の3つについては、Oracle Databaseインストレーション・ガイド(2024/2/12時点)に具体的な条件が記載されているため、こちらを参照して設定変更を行います。
インストール前に準備が必要なOSユーザー、OSグループが次の通りです。
OSユーザー | |
---|---|
Oracleソフトウェア所有者 |
・Oracleをインストール、管理するユーザー ・Oracleインベントリグループ、OSDBAグループに所属 ・通常、ユーザー名は「oracle」とする |
OSグループ | |
Oracleインベントリグループ |
・Oracleに関連するファイルを所有するOSグループ ・パッチの適用、既存インストールのアップグレード、Oracleソフトウェアの削除に使用する情報を格納 ・通常、グループ名は「oinstall」とする |
OSDBAグループ |
・Oracleの管理権限が付与されるグループ ・通常、グループ名は「dba」とする |
また、より細かい権限制御を行うためのOSグループも存在します。
(Bronze DBAの出題範囲は超えるそうです。。。)
その他のOSグループ
OSOPERグループ |
・SYSOPER権限が付与されるOSグループ ・通常、グループ名は「oper」とする |
OSBACKUPDBAグループ |
・SYSBACKUP権限(バックアップ、リカバリ関連の管理権限)が付与されるOSグループ ・通常、グループ名は「backupdba」とする |
OSDGDBAグループ |
・SYSDG権限(Data Guard関連の管理権限)が付与されるOSグループ ・通常、グループ名は「dgdba」とする |
OSKMDBAグループ |
・SYSKM権限(暗号化鍵関連の管理権限)が付与されるOSグループ ・通常、グループ名は「kmdba」とする |
OSRACDBAグループ |
・SYSRAC権限(RAC関連の管理権限)が付与されるOSグループ ・通常、グループ名は「racdba」とする |
ユーザー作成後、OSユーザーに以下の環境変数を設定します。
その前に注意点を2つ。
- 下の表の環境変数はLinux, UNIX環境のもの
- 環境変数はインストール後に設定することもできるが、先に設定しておくとデフォルト値として使用されるため便利
環境変数 | 説明 |
---|---|
ORACLE_BASE |
・Oracle関連ファイルの基準となるディレクトリのパスを設定 ・Oracleに関連するほとんどのファイルがORACLE_BASE以下に配置される |
ORACLE_HOME |
・Oracleのソフトウェアを配置するディレクトリのパスを設定する ・ORACLE_HOMEはORACLE_BASEのサブディレクトリに指定する |
ORACLE_SID |
・インスタンスの識別子であるSIDを設定する ・この環境変数により、接続先インスタンスを識別する |
1.2 ソフトウェアをインストールするためのツール
OracleソフトウェアのインストールにはOracle Universal Installer (OUI)を使います。OUIでは次のことが行えます。
- Oracleソフトウェアのインストール
- インストール済みのOracle製品の一覧表示
- インストール前の前提条件のチェック
- 使用しないOracle製品の削除
ソフトウェアインストールの手順
① ORACLE_HOMEに設定したディレクトリにインストールファイルを展開する
② ORACLE_HOMEディレクトリにあるrunInstallerを実行してOUIを起動
③ 構成オプションを選択
- Oracleのインストールのみを行うか、インストールと同時にデータベースも作成するかを選択する
- ソフトウェアインストール後にDBCAというツールでデータベースを作成することも可能
④ インストールオプションの選択
⑤ データベースエディションの選択
⑥ インストール場所の指定
- 「Oracleベース」にORACLE_BASEに設定したディレクトリのパスを指定
- 「ソフトウェアの場所」にORACLE_HOMEに設定したディレクトリのパスを指定
⑦ インベントリの作成
- 「oraInventoryグループ名」にOracleインベントリグループとして作成したOSグループを指定
⑧ 権限のあるオペレーティング・システム・グループを設定
- 1.1 インストールする前の準備の "その他のOSグループ" に記載したOSグループを設定
⑨ rootスクリプトの実行構成
スクリプト名 | 実行結果 |
---|---|
orainstRoot.sh | インベントリポインタファイル(インベントリの場所と管理グループが記録される)が作成される。 |
root.sh | oraenvスクリプト、coraenvスクリプト、dbhomeスクリプトが指定したディレクトリにコピーされる。 |
⑩ 前提条件が満たされているかがチェックされ、結果が表示される
⑪ サマリーにここまでのステップで入力した項目が表示される
⑫ 製品のインストール
⑬ 構成スクリプトの実行の確認
全ステップが正常に完了すると、「終了」画面が表示される。
2. Oracleデータベースを作成する
OUIでOracleソフトウェアをインストールした際、ソフトウェアのインストールのみでデータベースを作成しなかった場合、DBCAを使用してデータベースを作成します。
2.1 Database Configuration Assistant (DBCA)
データベースの作成には、Oracleソフトウェアに含まれるDatabase Configuration Assistant (DBCA)を使います。
DBCAを起動するには、コマンドプロンプトで以下のdbcaコマンドを実行します。
$ dbca
DBCAを用いたデータベース作成の手順
① 「データベース操作の選択」画面でDBCAで実行する操作を選択する
- 「データベースの作成」を選択する
② データベース作成モードを選択する
- 「標準構成」か「拡張構成」かを選択する
- 「標準構成」は一般的な構成で、DBCAでの入力項目が少なくなる
(標準構成では、下の表の項目を設定可能)
- 「拡張構成」は記憶域の場所、初期化パラメータ、管理オプション、データベースオプション、管理用ユーザーのパスワード、サンプルスキーマ、メモリ管理方式などをカスタマイズ可能
項目 | 説明 |
---|---|
グローバル・データベース名 |
・データベースを識別する名前 ・<データベース名>または<データベース名>.<ドメイン名>という形式で指定する |
記憶域タイプ |
・データベースファイルをどの記憶域に配置するかを指定する ・ファイルシステムまたは自動ストレージ管理を選択可能 - ファイルシステム:「データベース・ファイルの位置」で指定したディレクトリ以下にデータベースファイルを配置 - 自動ストレージ管理:ASMディスクグループにデータベースファイルを配置 |
データベース・ファイルの位置 |
・「記憶域タイプ」でファイルシステムを選択した場合は、データベースファイルを格納するディレクトリを指定する ・「記憶域タイプ」で自動ストレージ管理を選択した場合は、ASMディスクグループ名を指定する |
高速リカバリ領域 | ・バックアップおよびリカバリの領域を指定する |
データベース文字セット | ・データベースに使用するキャラクタセット(Oracleにおける文字コード)を選択する |
管理者パスワード |
・管理用ユーザー(SYS, SYSTEMなど)のパスワードを入力する ・管理用ユーザーはデータベース作成時に自動的に作成される |
コンテナ・データベースとして作成 | ・作成するデータベースをマルチテナントコンテナデータベースとして作成する場合は選択する - マルチテナントコンテナデータベース:1つのデータベースの中に複数の仮想的なデータベースを持つことができる構成 |
③ 「サマリー」画面でここまでの入力項目を確認する。
④ データベースの作成が開始されると「進行状況」ページが表示される。
⑤ データベース作成完了後、「Database Configuration Assistant」画面から次の2点の情報を確認できる。
- DBCAログファイルの場所
- グローバル・データベース名、SID、サーバーパラメータファイル名
2.2 テンプレートの管理
テンプレートとは・・・
DBCAでデータベースを作成する際のひな型。
データベースオプション、初期化パラメータ、記憶域属性(データファイル、表領域、制御ファイル、REDOログの属性)などの情報が含まれ、他のデータベースにコピーして共有することも可能。
種類 | 説明 |
---|---|
シード |
テンプレートにデータファイルが含まれ、シードデータベースの複製としてデータベースを新規作成する。 シードテンプレートを使用した際に、自分で変更できる項目は次の5つ。 ● データベースの名前 ● データファイルの格納先 ● 制御ファイルの数 ● REDOロググループの数 ● 初期化パラメータ |
非シード |
テンプレートにデータファイルが含まれず、新規作成するデータベースは柔軟に構成できる。 その代わり、作成に時間はかかる。 |
テンプレートの作成
データベース作成手順でも触れた「データベース操作の選択」画面で「テンプレートの管理」を選択すると作成可能。
既存のデータベースから作成されたテンプレートを使用すると、既存のデータベースの複製となるデータベースを作成することができる。
テンプレート作成のオプションは以下の3つ。
オプション | 説明 |
---|---|
既存のテンプレートからテンプレートを作成 |
・事前構成済みの設定に基づく新しいテンプレートを作成可能 ・初期化パラメータ、記憶域パラメータ、カスタムスクリプトを使用するかなどの設定を追加、変更できる |
既存のデータベースからテンプレートを作成 |
・既存のデータベースの構成情報(データベースオプション、表領域、データファイル、初期化パラメータなど)を持つ新しいテンプレートを作成可能 ・ユーザー定義のスキーマと、そのスキーマに格納されているデータは含まれない ・元のデータベースはリモートにあってもローカルにあっても構わない |
既存のデータベースからテンプレート作成 データファイルを含める |
・「既存のデータベースからテンプレートを作成」でテンプレートに含まれる要素に加えて、物理データファイルも含ませることができる (ユーザー定義のスキーマと、そのスキー目に格納されているデータが含まれる) ・このオプションで作成されたテンプレートを使用して作成したデータベースは、元のデータベースと同一になる ・元のデータベースはローカルにある必要がある |
テンプレートの削除
テンプレートの作成と同じく、「データベース操作の選択」画面で「データベース・テンプレートの削除」を選択すると、テンプレートを削除できる。
3. Bronze DBAの勉強をして感じたこと
勉強を始めたばかりの時は初めて聞くツールやパラメータが無限に出てきて、ひとつひとつを理解するのがとても大変でしたが、実際にデータベースを利用する際の流れに沿って理解することで、それぞれのツールなどの役割がはっきりして頭に入りやすくなりました。
また、業務中に勉強した単語を見たときはその意味が分かるだけでテンションが上がるので、そういったところもモチベーションアップにつながりました。
今後も上位資格への挑戦や、今回の記事の続きの作成に取り組んでいきたいと思います。