Cluster Server 7.3.1 Agent for Oracle インストール/設定ガイド - Linux

Last Published:
Product(s): InfoScale & Storage Foundation (7.3.1)
  1. Cluster Server agent for Oracle の概要
    1. Cluster Server agent for Oracle について
      1.  
        Oracle ASM のエージェントについて
    2.  
      Oracle の VCS エージェントのサポート対象ソフトウェア
    3.  
      7.3.1 リリースで導入された変更点
    4. エージェントが Oracle の高可用性を保証するしくみ
      1.  
        Oracle エージェントと Netlsnr エージェントがインテリジェントなリソース監視をサポートするしくみ
      2.  
        エージェントが Oracle ASM インスタンスの高可用性を確保する方法
      3.  
        Oracle 12C におけるエージェントの CDB と PDB のサポート方法
    5. Oracle 用 Cluster Server エージェント関数について
      1. Oracle エージェント関数
        1.  
          Oracle エージェントの起動オプションと停止オプション
        2.  
          PDB の起動オプションと停止オプション
        3.  
          コンテナデータベース(CDB)の起動モードに基づくプラグ可能なデータベース(PDB)の推奨起動モード
        4.  
          従来のデータベースおよびコンテナデータベース内の Oracle エージェントに対する監視オプション
        5.  
          プラグ可能なデータベースの監視
        6.  
          詳細監視での Oracle エラーコードの操作
        7.  
          Cluster Server agent for Oracle の Info エントリポイント
        8.  
          Cluster Server agent for Oracle の Action エントリポイント
        9. Oracle エージェントによる診断監視のサポートのしくみ
          1.  
            Oracle 診断監視に必要な実行可能ファイルの生成
          2.  
            build_oraapi.sh スクリプトを実行する際の注意事項
          3.  
            build_oraapi.sh スクリプトを使った Oracle エージェントの実行可能ファイルの構築
      2.  
        Netlsnr エージェント関数
      3. ASMInst エージェント関数
        1.  
          ASMInst エージェントの起動オプション
        2.  
          ASMInst エージェントのシャットダウンオプション
        3.  
          ASMInst エージェントの監視オプション
      4.  
        ASMDG エージェント関数
    6.  
      VCS クラスタの標準的な Oracle 設定
    7.  
      VCS クラスタでの Oracle 設定について
  2. Oracle のインストールと設定
    1.  
      VCS 環境での Oracle のインストールについて
    2.  
      VCS 環境に Oracle をインストールする前に
    3. Oracle のインストールのための VCS の必要条件について
      1.  
        $ORACLE_HOME の場所
      2.  
        ホットバックアップ中に VCS ノードに障害が発生した後の Oracle のフェールオーバー
    4. VCS のための Oracle インストールタスクについて
      1.  
        共有ディスクで行う $ORACLE_HOME のインストールタスク
      2.  
        ローカルディスクで行う $ORACLE_HOME のインストールタスク
      3.  
        ASM を使用する Oracle のインストールタスク
    5. Oracle 11gR2 または 12c の ASM バイナリの VCS 環境へのインストール
      1.  
        Oracle Restart 機能をサポートするための VCS 設定
    6. クラスタの最初のノードでの Oracle ASM の設定
      1.  
        ASM で管理されたデータベースのためのクラスタデーモンの有効化
      2.  
        Oracle Cluster Synchronization Service デーモンの自動起動の有効化
    7.  
      11gR2 または 12c の残りのノードでの ASM の設定と起動
    8. クラスタの最初のノードへの Oracle バイナリのインストール
      1.  
        Oracle 10g またはそれ以降用のクラスタデーモンの無効化
    9.  
      Oracle データベースの設定
    10.  
      $ORACLE_BASE/admin/SID ディレクトリのコピー
    11.  
      Oracle ASM の初期化パラメータファイルのコピー
    12.  
      Oracle データベースへのアクセスの確認
  3. Oracle 用エージェントのインストールと削除
    1.  
      Oracle 用エージェントをインストールまたはアップグレードする前に
    2.  
      VCS agent for Oracle ソフトウェアのインストール
    3. VCS agent for Oracle のアップグレード
      1.  
        VCS 7.3.1 で使うための VCS agent for Oracle のアップグレード
    4.  
      Cluster Server agent for Oracle の無効化
    5.  
      Cluster Server agent for Oracle の削除
  4. Oracle のための VCS サービスグループの設定
    1.  
      Oracle 用サービスグループの設定について
    2. VCS における Oracle インスタンスの設定
      1.  
        VCS における単一の Oracle インスタンスの設定
      2.  
        VCS における複数の Oracle インスタンス(単一リスナー)の設定
      3.  
        VCS における複数の Oracle インスタンス(複数リスナー)の設定
      4.  
        VCS における共有サーバーサポートの Oracle インスタンスの設定
    3. Oracle の VCS サービスグループを設定する前に
      1.  
        Cluster Server agent for Oracle のタイプ定義ファイルのインポート
    4. Oracle のための VCS サービスグループの設定
      1.  
        Cluster Manager(Java コンソール)を使った Oracle 用 VCS サービスグループの設定
      2. コマンドラインを使った Oracle 用 VCS サービスグループの設定
        1.  
          Oracle データベースのユーザーパスワードとリスナーパスワードの暗号化
    5. VCS agent for Oracle の詳細監視の設定
      1. Oracle に対する詳細監視の設定
        1.  
          Oracle リソースに対する詳細監視の有効化と無効化
      2.  
        Netlsnr に対する詳細監視の設定
    6. エージェントに対するインテリジェントなリソース監視の手動による有効化と無効化
      1.  
        AMF カーネルドライバの管理
  5. Veritas High Availability 設定ウィザードを使った Oracle 用 VCS サービスグループの設定
    1.  
      仮想環境の標準 VCS クラスタ設定
    2.  
      VMware 用 High Availability ソリューションを使用したアプリケーション監視の設定について
    3.  
      ウィザードを使用した VCS サービスグループの設定の準備
    4.  
      アプリケーション監視を設定する前に
    5.  
      High Availability 設定ウィザードの起動
    6.  
      Oracle を監視するためのエージェントの設定
    7. サービスグループの設定について
      1.  
        リソースの依存関係(Resource Dependency)
      2.  
        サービスグループの依存関係
      3.  
        インフラサービスグループ
    8. 設定シナリオについて
      1.  
        VCS で単一インスタンス/複数のインスタンスを設定する
      2.  
        ウィザードの複数実行機能を使って VCS で Oracle の複数インスタンスを設定する
      3.  
        複数のアプリケーションを設定する
    9.  
      High Availability 設定ウィザードの制限事項
    10. トラブルシューティング
      1.  
        High Availability 設定ウィザードで空白のパネルが表示される
      2.  
        High Availability 設定ウィザードに「hadiscover は内部コマンドまたは外部コマンドとして認識されていません (hadiscover is not recognized as an internal or external command)」というエラーが表示される
      3.  
        hastop - all コマンドを実行すると、仮想ディスクが切断される
      4.  
        ログファイル
    11. 設定例
      1.  
        単一 Oracle インスタンス用の VCS 設定ファイルの例(VxVM)
      2.  
        単一 Oracle インスタンス用の VCS 設定ファイルの例(LVM)
  6. Oracle 用 VCS サービスグループの管理
    1.  
      VCS サービスグループの管理について
    2.  
      サービスグループのオンライン化
    3.  
      サービスグループのオフライン化
    4.  
      サービスグループの切り替え
    5.  
      サービスグループ設定の修正
  7. プラグ可能データベース (PDB) の移行
    1.  
      コンテナデータベース (CDB) 間でのプラグ可能データベース (PDB) の移行
  8. Cluster Server agent for Oracle のトラブルシューティング
    1.  
      Cluster Server agent for Oracle のトラブルシューティングについて
    2.  
      Oracle と Netlsnr エージェントに共通のエラーメッセージ
    3.  
      Oracle エージェント固有のエラーメッセージ
    4.  
      Netlsnr エージェント固有のエラーメッセージ
    5.  
      ASMInst エージェント固有のエラーメッセージ
    6.  
      ASMDG エージェント固有のエラーメッセージ
    7.  
      VCS 環境における Oracle 固有の問題のトラブルシューティング
    8. Oracle 診断バイナリと Oracle のインスタンスの意図的なオフライン化の検証
      1.  
        VCS Oracle エージェントの意図的なオフライン動作の検証
    9.  
      PDB リソースの IMF の無効化
  9. 付録 A. リソースの種類の定義
    1.  
      リソースタイプの定義と属性の定義について
    2. Oracle エージェントのリソースタイプ定義
      1.  
        systemD サポート用のソースタイプ定義
      2.  
        Oracle エージェントの属性定義
      3.  
        ポリシー管理データベースの Sid 属性について
      4. Oracle アプリケーションサービスでの systemD 属性の使用
        1.  
          キーと値のペアの SystemDAttrList 属性への追加
        2.  
          systemD 属性を使用した Oracle サービスユニットファイルのカスタマイズ
      5.  
        Linux 上の Oracle への HugePages の設定
    3. Netlsnr エージェントのリソースタイプ定義
      1.  
        Netlsnr エージェントの属性定義
    4. ASMInst エージェントのリソースタイプ定義
      1.  
        systemD をサポートする ASMInst エージェントのリソースタイプ定義
      2.  
        ASMInst エージェントの属性定義
    5. ASMDG エージェントのリソースタイプ定義
      1.  
        ASMDG エージェントの属性定義
  10. 付録 B. 設定例
    1.  
      Oracle エンタープライズエージェント の設定例について
    2. 単一の Oracle インスタンスの設定例
      1.  
        単一 Oracle インスタンスの VCS 設定ファイルの例
    3. 複数の Oracle インスタンス(単一リスナー)の設定例
      1.  
        複数の Oracle インスタンス(単一リスナー)の VCS 設定ファイルの例
    4. 複数のインスタンス(複数リスナー)の設定例
      1.  
        複数の Oracle インスタンス(複数リスナー)の VCS 設定ファイルの例
    5. 共有サーバーサポートの Oracle の設定例
      1.  
        共有サーバーサポートで設定された Oracle インスタンスの VCS 設定ファイルの例
    6. Oracle ASM の設定例
      1. RAW ディスクとしての ASM ディスクの設定例
        1.  
          ASM で管理された Oracle インスタンスの VCS 設定ファイルの例
      2. VxVM ボリュームとしての ASM ディスクの設定例
        1.  
          VxVM ディスクとしての ASM ディスクの VCS 設定ファイル例
      3. CVM ボリュームとしての ASM ディスクの設定例
        1.  
          CVM ボリュームを使う ASM の VCS 設定ファイルの例
    7.  
      main.cf の Oracle プラグ可能なデータベース(PDB)リソースの設定例
    8.  
      main.cf の移行可能な Oracle プラグ可能データベース (PDB) リソースの設定例
    9.  
      systemD でサポートされる Oracle の設定例
    10.  
      systemD でサポートされる ASMInst の設定例
  11. 付録 C. ベストプラクティス
    1.  
      VCS 環境で複数の Oracle インスタンスを設定する場合のベストプラクティス
  12. 付録 D. Oracle の VCS クラスタでの SPFILE の使用
    1.  
      Oracle 初期化パラメータファイルについて
    2.  
      Oracle インスタンスの起動
    3.  
      VCS クラスタでの SPFILE の使用
  13. 付録 E. 単一インスタンスのデータベース環境での OHASD
    1.  
      単一インスタンスのデータベース環境での OHASD について
    2.  
      OHASD の高可用性を確保するための Application エージェントの設定

Oracle に対する詳細監視の設定

Oracle リソースの詳細監視では、データベース内のテーブルに対して更新トランザクションを実行することによって、トランザクションに対するデータベースの準備が整っているかどうかを確認します。この更新アクションは、Cluster Server agent for Oracle に付属する 2 つのスクリプト、SqlTest.plSimpleTest.pl によって実行されます。これらのスクリプトは、/opt/VRTSagents/ha/bin/Oracle/ ディレクトリの下にあります。どちらのスクリプトも、データベースを監視するためにタイムスタンプを更新します。

SqlTest.pl スクリプトは、タイムスタンプを更新する前に、データベースがオープンしているかどうかチェックします。データベースが制限モード、非活動モードまたはサスペンドモードであることが判明した場合も、監視成功と返されます。この場合は、基本監視のみが行われます。SimpleTest.pl スクリプトは、データベースのチェックは行わず、テーブルに対する更新ステートメントを実行するだけです。

Oracle に対して詳細監視を有効にするには、Oracle データベースにテストテーブル(タイムスタンプ付きの)を作成する必要があります。エージェントはこのテストテーブルを内部の目的で使用します。 テストテーブルではその他のトランザクションを実行しないことをお勧めします。詳細監視用スクリプト MonScript が存在し、root にこのスクリプトの実行許可がある必要があります。ユーザーが監視スクリプトを作成するか、エージェント付属のスクリプトを使えます。監視スクリプトのリターンコード 100 は、異常終了を意味します。リターンコードの 101 - 110 は、正常終了を意味します。

詳細監視の設定例では、付属のスクリプトを基に、詳細監視で使うテーブルの作成とテストの方法と詳細監視を有効にする方法を示します。

Oracle に対する詳細監視を設定するには

  1. VCS 設定を書き込み可能にします。
    # haconf -makerw
  2. 不完全な再設定によって VCS が自動的に処理を行うのを避けるために、サービスグループをフリーズします。
    # hagrp -freeze service_group
  3. Oracle ユーザーでログインします。
    # su - <Owner>
  4. ORACLE_HOME と ORACLE_SID の環境変数を設定します。
    # export ORACLE_HOME=<Home>
    # export ORACLE_SID=<Sid>
  5. sqlplus ユーティリティを起動してデータベーステーブルを設定します。
    $ORACLE_HOME/bin/sqlplus /nolog
  6. データベース管理者として、sqlplus プロンプトに次の文を挿入してテストテーブルを作成します。

    従来のデータベースおよびコンテナデータベースの場合:

    connect / as sysdba
    
    create user  <User>
    identified by <Pword> 
    default tablespace USERS
    temporary tablespace TEMP   
    quota 100K on USERS;
    
    grant create  session to <User>;
    
    create table <User>.<Table> (  tstamp date );
    insert into <User>.<Table> (tstamp) values  (SYSDATE);

    メモ:

    CDB リソースの場合、ユーザー名の先頭に C## を付加する必要があります。

    PDB の詳細監視を有効にするには、sqlplus プロンプトに次の文を挿入してテストテーブルを作成します。

    $ORACLE_HOME/bin/sqlplus /nolog
    connect / as sysdba
    

    CDB の共通ユーザーを作成してない場合は作成します。

    create user <User>
    identified by <Pword>
    default tablespace USERS
    temporary tablespace TEMP
    quota 100K on USERS;
    grant connect to <User> container=all;
    alter session set container=PDBName
    create table <User>.<Table> ( tstamp date );
    insert into <User>.<Table> (tstamp) values (SYSDATE);

    メモ:

    PDB の詳細監視を行わない場合でも、VCS Agent for Oracle には CDB と PDB 両方の詳細監視の共通ユーザーが必要です。

  7. データベーステーブルが使えることをテストするには、CDB または従来のデータベースで次の操作をします。
    $ORACLE_HOME/bin/sqlplus /nolog
    connect / as sysdba
    connect  <User>/<Pword>
    update <User>.<Table> set(tstamp)=SYSDATE;
    select TO_CHAR(tstamp, 'MON DD, YYYY HH:MI:SS AM')
    from <User>.<Table>;

    PDB の場合

    alter session set container=PDBName;
    update <User>.<Table> set (  tstamp ) = SYSDATE;
    select TO_CHAR(tstamp, 'MON DD, YYYY HH:MI:SS  AM') 
    from <User>.<Table>;
    exit
  8. 次の VCS コマンドを使って Oracle リソースに対する詳細監視を有効にします。
    # hares -modify OracleResource User <User>
    # hares -modify OracleResource Pword <Pword>
    # hares -modify OracleResource Table <Table>
    # hares -modify OracleResource MonScript "./bin/Oracle/SqlTest.pl"

    # hares -override OracleResource LevelTwoMonitorFreq
    # hares -modify OracleResource LevelTwoMonitorFreq 1
    # haconf -dump  -makero
    # hagrp -unfreeze service_group

    Cluster Manager(Java コンソール)を使ってこれらの属性を設定することもできます。