リリース3.0以降からこのリリースへのアップグレード

リリース3以降からこのリリースへのストアのアップグレードは、一度に1つのストレージ・ノードに対して実行できます。これは、2つのリリースが混在する複数のストレージ・ノードを同じストアで同時に実行できるためです。これにより、最も効率的な方法でストレージ・ノードを戦略的にアップグレードできます。

注意:

1.0または2.0のストアをリリース4に直接アップグレードすることできません。まずリリース3にアップグレードしてから、リリース4にアップグレードする必要があります。詳細は、管理者ガイド リリース3を参照してください。

注意:

ストアに多数のストレージ・ノードが含まれている場合、スクリプトを使用してアップグレードを実行することもできます。スクリプトを使用したリリース4へのアップグレードを参照してください。

潜在的な問題を回避するために、新しいCLIコマンドを使用して、ノードを同時にアップグレードするタイミングを特定できます。このようなコマンドについては、次の手順で説明します。

ストアをアップグレードするには、最初に最新のソフトウェアをインストールして管理CLIをアップグレードします。次に、アップグレードしたCLIを使用して、すべてのストレージ・ノードが基本要件に違反していないことを確認します。

kv-> verify prerequisite
...
Verification complete, no violations.  

すべての違反(見つかった場合)を修正したら、管理サービスを実行しているストレージ・ノードに最新のソフトウェアをインストールします。

次の手順を実行します。

  1. リリース3以降の管理サービスを実行しているストレージ・ノードにおいて:

    1. 更新されたソフトウェアを、管理サービスを実行しているストレージ・ノード上の新規KVHOMEディレクトリに配置します。ここでは、新規KVHOMEディレクトリはNEW_KVHOMEとします。ノードでNFSを使用してこのディレクトリを共有する場合、これは、共有ディレクトリごとに一度のみ行う必要があります。

    2. リリース3以降のCLIを使用してストレージ・ノードを停止します。この手順を実行すると、そのストレージ・ノード上の管理サービスがシャットダウンされます。

      /etc/init.d、Upstartまたは他のメカニズムを使用して再起動時にストレージ・ノード・エージェントを自動的に起動するようにノードを構成している場合は、まずそのスクリプトをNEW_KVHOMEを指すように変更します。

      そのスクリプトを変更した後、ストレージ・ノードをシャットダウンします。

      java -Xmx64m -Xms64m \
      -jar KVHOME/lib/kvstore.jar stop -root <kvroot>
    3. リリース4コードを使用してストレージ・ノードを再起動します。

      注意:

      SNAを開始する前に、各ノードで環境変数MALLOC_ARENA_MAX1に設定します。こうすることで、メモリー使用量が指定されたヒープ・サイズに制限されます。

      nohup java -Xmx64m -Xms64m \
      -jar NEW_KVHOME/lib/kvstore.jar start -root <kvroot> & 

      (ストレージ・ノード・エージェントを自動的に再起動するようにシステムが構成されている場合、このステップは不要です。)

    4. CLIを使用して、リリース4コードを実行しているストレージ・ノードに接続します。

      java -Xmx64m -Xms64m \
      -jar NEW_KVHOME/lib/kvstore.jar runadmin -port 5000 -host node1 \
      -security USER/security/admin/security
    5. ストア内のすべてのストレージ・ノードで、リリース4へのアップグレードに必要とされる適切なソフトウェア・レベルが実行されていることを確認します。マイナー・リリースやパッチ・リリースを含め、リリース3のすべてのバージョンがソフトウェア・レベルの最小要件を満たしていることに注意してください。

      kv-> verify prerequisite
      Verify: starting verification of mystore based upon topology
      sequence #315
      300 partitions and 6 storage nodes.
      Time: 2016-11-21 13:40:37 UTC Version: 12.1.4.3.5
      See node1:<KVROOT>/mystore/log/mystore_{0..N}.log for progress
      messages
      Verify prerequisite: Storage Node [sn3] on node3:5000
      Zone: [name=Boston id=zn1 type=PRIMARY allowArbiters=false]
        Status: RUNNING
      Ver: 12cR1.3.5.2 2016-03-09 04:37:46 UTC  Build id: 0c693aa1a5a0
      
      ...
      
      Verification complete, no violations.  

      注意:

      ここに示すのは、検証コマンドの出力例の一部のみです。重要な部分は最後の行です。違反はありません。

      違反の理由として最も可能性が高いのは、リリース・レベルを(誤って)ダウングレードしようとしたことです。たとえば、上位のマイナー・リリースから下位のマイナー・リリースにダウングレードすることはできません。この違反は、ストア内の他のノードのリリース・レベルより低いマイナー・リリース・レベルのパッケージを使用してCLIコマンドを実行しているために発生した可能性があります。

      注意:

      上位のパッチ・レベルから下位のパッチレベルにダウングレードすることは可能です。したがって、たとえば2.1.4から2.1.3にダウングレードすることはできますが、2.1.3から2.0.39にダウングレードすることはできません。

      また、1.0または2.0のノードをリリース4に直接アップグレードしようとすると、違反が発生します。この場合、まずリリース3にアップグレードしてから、リリース4にアップグレードする必要があります。詳細は、セキュリティ・ガイドリリース3を参照してください。

      いずれにしても、verify prerequisiteコマンドが違反を示す場合は、状況を解決してから、識別されたそのノードのアップグレードを試行します。

    6. アップグレードするノードの順序付きリストを取得します。

      kv-> show upgrade-order
      Calculating upgrade order, target version: 12.1.4.3.5,
      prerequisite: 12.1.3.0.5
      sn3 sn4
      sn2 sn5
      sn6

      このコマンドでは、1つ以上のストレージ・ノードが1行に表示されます。1行に複数のストレージ・ノードが表示される場合、スペースで区切られます。1行に複数のストレージ・ノードが表示されている場合、必要であればそのノードをまとめて安全にアップグレードできます。複数のノードをまとめてアップグレードする場合、すべてのノードのアップグレードが完了してからでなければ、リストの次のノードはアップグレードできません。ある時点で次にアップグレードするノードのグループがわからなくなった場合は、show upgrade-orderコマンドをいつでも再実行できます。

      1行にまとめられたストレージ・ノードは、同時にアップグレードできます。したがって、この出力ではsn3とsn4をアップグレードします。その後、sn2とsn5をアップグレードします。最後に、sn6をアップグレードします。

      注意:

      次のグループに進む前に、ノードのグループを完全にアップグレードする必要があります。つまり、sn3とsn4をアップグレードしてから、sn2、sn5またはsn6のアップグレードに進みます。
  2. アップグレードするストレージ・ノードの最初のグループ(この例ではsn3とsn4)の各ストレージ・ノードに対して、次の手順を実行します。

    1. リリース4ソフトウェアを新規KVHOMEディレクトリに置きます。ここでは、新規KVHOMEディレクトリはNEW_KVHOMEとします。ノードでNFSを使用してこのディレクトリを共有する場合、これは、共有ディレクトリごとに一度のみ行う必要があります。

    2. リリース3以降のユーティリティを使用してストレージ・ノードを停止します。

      /etc/init.d、Upstartまたは他のメカニズムを使用して再起動時にストレージ・ノード・エージェントを自動的に起動するようにノードを構成している場合は、まずそのスクリプトをNEW_KVHOMEを指すように変更します。

      スクリプトを変更したら、古いコードを使用してストレージ・ノードをシャットダウンします。

      java -Xmx64m -Xms64m \
      -jar KVHOME/lib/kvstore.jar stop -root <kvroot>
    3. 新しいコードを使用してストレージ・ノードを再起動します。

      注意:

      SNAを開始する前に、各ノードで環境変数MALLOC_ARENA_MAX1に設定します。こうすることで、メモリー使用量が指定されたヒープ・サイズに制限されます。

      nohup java -Xmx64m -Xms64m \
      -jar NEW_KVHOME/lib/kvstore.jar start -root <kvroot> & 

      (ストレージ・ノード・エージェントを自動的に再起動するようにシステムが構成されている場合、このステップは不要です。)

  3. ノードの次のセットをアップグレードする前に、アップグレードを検証します。このコマンドは、正常にアップグレードされたノード、および引き続きアップグレードが必要なノードを示します。

    kv-> verify upgrade
    Verify: starting verification of mystore based upon topology
    sequence #315
    300 partitions and 6 storage nodes.
    Time: 2016-03-09 04:37:46 UTC Version: 12.1.4.3.5
    See node1:<KVROOT>/mystore/log/mystore_{0..N}.log for progress
    messages
    Verify upgrade: Storage Node [sn3] on node3:5000
    Zone: [name=Boston id=zn1 type=PRIMARY]    Status: RUNNING
    Ver: 12cR1.4.3.5 2016-11-21 13:40:37 UTC  Build id: 35728a5c21b1
    
    ...
    
    Verify: sn2: Node needs to be upgraded from 12.1.3.5.2 to
    version 12.1.4.3.5 or newer
    
    ...
    
    Verification complete, 0 violations, 3 notes found.
    Verification note: [sn2]    Node needs to be upgraded from
    12.1.3.5.2 to version 12.1.4.3.5 or newer
    Verification note: [sn5]    Node needs to be upgraded from
    12.1.3.5.2 to version 12.1.4.3.5 or newer
    Verification note: [sn6]    Node needs to be upgraded from
    12.1.3.5.2 to version 12.1.4.3.5 or newer 

    見やすさとスペースの関係で、verify upgradeコマンドによって生成された出力の一部のみを示しています。アップグレードされたノードは、現在のソフトウェア・バージョン番号を含む検証メッセージで識別されます。

    Verify upgrade: Storage Node [sn3] on node3:5000
    Zone: [name=Boston id=zn1 type=PRIMARY allowArbiters=false]
    Status: RUNNING
    Ver: 12cR1.4.3.5 2016-11-21 13:40:37 UTC  Build id: 35728a5c21b1 

    引き続きアップグレードが必要なノードは、2種類の方法で識別されます。まず、ノードの検証メッセージは、引き続きアップグレードが必要であることを示します。

    Verify: sn2: Node needs to be upgraded from 12.1.3.5.2 to
    version 12.1.4.3.5 or newer 

    次に、検証出力の末尾には、引き続きアップグレードが必要なすべてのノードが示されます。

    Verification complete, 0 violations, 3 notes found.
    Verification note: [sn2]    Node needs to be upgraded from
    12.1.3.5.2 to version 12.1.4.3.5 or newer
    Verification note: [sn5]    Node needs to be upgraded from
    12.1.3.5.2 to version 12.1.4.3.5 or newer
    Verification note: [sn6]    Node needs to be upgraded from
    12.1.3.5.2 to version 12.1.4.3.5 or newer 

    注意:

    アップグレードしたと思われるノードが、引き続きアップグレードが必要であることを検証が示す場合は、ストア内の他のノードをアップグレードする前にその問題を解決する必要があります。サニティ・チェックの一種として、アップグレードが完了したばかりのノードのみを検証できます。

    kv-> verify upgrade -sn sn3 -sn sn4
    Verify: starting verification of mystore based upon topology
    sequence #315
    ...
    Verification complete, no violations.
  4. show upgrade-orderコマンドで識別されたストレージ・ノードのグループのアップグレードを続行できます。前述の手順に従います。リリース3以降の停止コマンドを使用してリリース3以降のストレージ・ノードを停止した後、リリース4の起動コマンドを使用してストレージ・ノードを再起動します。すべてのストレージ・ノードがアップグレードされるまでこれを続行します。

    ある時点で次にアップグレードするノードのグループがわからなくなった場合は、show upgrade-orderコマンドをいつでも再実行できます。

    kv-> show upgrade-order
    Calculating upgrade order, target version: 12.1.4.3.5,
    prerequisite: 12.1.3.0.5
    sn2 sn5
    sn6 
  5. ストレージ・ノードのアップグレードがすべて完了した後、verify upgradeコマンドを実行すると、出力の末尾に検証に関する注意事項は表示されません。

    kv-> verify upgrade
    Verify: starting verification of mystore based upon topology
    sequence #315
    ...
    Verification complete, no violations. 

スクリプトを使用したリリース4へのアップグレード

多数のストレージ・ノードが含まれるデプロイメントの場合、前述の手動によるアップグレード手順は問題をはらみます。その場合、スクリプトを使用してストアをアップグレードする必要があります。

リリース4ディストリビューションでの検証にはサンプル・スクリプト(bashシェル・スクリプト)を使用できます。次の場所にあります。

<KVHOME>/examples/upgrade/onlineUpgrade

このスクリプトには、この項の前半で説明したものと同じアップグレード制限があります。リリース3以降のインストールからリリース4へのアップグレードのみ可能となり、アップグレード・プロセス中にストアを使用するには、ストアのレプリケーション係数が少なくとも3である必要があります。

提供されているスクリプトはサンプルにすぎません。インストール環境で適切に機能するためには、スクリプトを変更する必要があります。

スクリプトではソフトウェア・プロビジョニングは実行されないことに注意してください。つまり、インストール・ソフトウェアのために使用するいかなる場所のホスト・マシンへのリリース4パッケージの配置も自分で行う必要があります。ただし、スクリプトはsshを使用してホスト・マシンと通信するため、scpを使用してスクリプトでマシンをプロビジョニングすることもできます。

スクリプトはsshを使用するため、スクリプトが機能するためには、自動ログイン(つまり、パスワードなしのssh経由によるログイン)を許可するようにマシンを構成する必要があります。sshでは公開/秘密キー認証をサポートしているため、これは通常は安全な動作方法です。

このようにsshを構成する方法の詳細は、https://www.linuxproblem.org/art_9.htmlを参照してください。sshおよびsshサーバーをインストールして構成する方法の詳細は、オペレーティング・システムのドキュメントを参照してください。