目次にジャンプページナビゲーションにジャンプ: 前のページ[アクセスキーp]/次のページ[アクセスキーn]
documentation.suse.com / SUSE Linux Enterprise Serverマニュアル / アップグレードガイド / オンラインでのアップグレード
適用項目 SUSE Linux Enterprise Server 15 SP6

5 オンラインでのアップグレード

SUSEは、動作中のシステムを新しいサービスパックにアップグレードするための直感的なグラフィカルツールとシンプルなコマンドラインツールを提供します。両方のツールは、サービスパックのロールバックなどをサポートしています。この章では、これらのツールを使用してサービスパックのアップグレードを実行する方法を段階的に説明します。

5.1 概念の概要

SUSEは、SUSE Linux Enterpriseファミリ用の新しいサービスパックを定期的にリリースしています。お客様が新しいサービスパックに容易にマイグレートしてダウンタイムを最小限に抑えることができるよう、SUSEはシステム実行中のオンラインマイグレーションをサポートしています。

SLE 12から、YaST WagonはYaSTマイグレーション(GUI)およびZypperマイグレーション(コマンドライン)に置き換えられました。これには以下のような利点があります。

  • 最初のRPMが更新されるまで、システムは常に定義済みの状態

  • 最初のRPMが更新されるまでは、キャンセルが可能.

  • エラーが発生した場合に簡単に回復

  • システムツールを介してロールバックを実行可能 - バックアップや復元は必要ない

  • アクティブなすべてのリポジトリを使用.

  • サービスパックをスキップ可能

警告
警告: メジャーリリースのオンラインマイグレーションはサポート対象外

オンラインマイグレーションは、サービスパック間のマイグレーションでのみサポートされています。オンラインマイグレーションは、新しいメジャーリリースへのアップグレードではサポートされていません。詳細については、第2章 「アップグレードパスと方法を参照してください。

新しいメジャーリリースにアップグレードする場合は、オフラインマイグレーションを使用します。詳細については、第4章 「オフラインでのアップグレードを参照してください。

重要
重要: SUSE Managerクライアントのアップグレード

アップグレードするシステムがSUSE Managerクライアントの場合は、YaSTオンラインマイグレーションやzypper migrationではアップグレードできません。代わりに、「Client Migration」手順を使用してください。『 SUSE Manager Upgrade Guide』で説明されています。

5.2 サービスパックのマイグレーションのワークフロー

サービスパックのマイグレーションは、YaST、zypper、またはAutoYaSTにより実行できます。

サービスパックのマイグレーションを開始する前に、SUSEカスタマーセンターまたはローカルRMTサーバでシステムを登録する必要があります。SUSE Managerも使用できます。

どの方法を使用する場合も、サービスパックのマイグレーションは次の手順で構成されます。

  1. 登録システムで、マイグレーションターゲットの候補を見つけます。

  2. マイグレーションターゲットを1つ選択します。

  3. 新しいリポジトリを要求して有効にします。

  4. マイグレーションを実行します。

マイグレーションターゲットのリストは、インストールおよび登録されている製品に応じて異なります。新しいSPがまだ利用可能になっていない拡張機能がインストールされている場合、マイグレーションターゲットが提供されない可能性があります。

ホストで使用可能なマイグレーションターゲットのリストは、常にSUSEカスタマーセンターから取得され、インストールされている製品または拡張機能に応じて異なります。

5.3 サービスパックのマイグレーションのキャンセル

サービスパックのマイグレーションは、マイグレーションプロセスの特定の段階でのみキャンセルできます。

  1. パッケージのアップグレードが開始されるまで、サービスやリポジトリの変更などのシステムの最小限の変更しか加えられません。以前の状態に戻すには、/etc/zypp/repos.d/*を復元します。

  2. パッケージのアップグレードが開始された後は、Snapperスナップショットを使用して以前の状態に戻すことができます(第10章 「Snapperを使用したシステムの回復とスナップショット管理を参照してください)。

  3. マイグレーションターゲットが選択された後、SUSEカスタマーセンターによってリポジトリデータが変更されます。この状態を手動で元に戻すには、SUSEConnect --rollbackを使用します。

5.4 オンラインマイグレーションツール(YaST)を使用したアップグレード

YaSTを使用してサービスパックのマイグレーションを実行するには、Online Migration (オンラインマイグレーション)ツールを使用します。デフォルトでは、YaSTはサードパーティリポジトリからパッケージをインストールしません。パッケージがサードパーティリポジトリからインストールされている場合、YaSTは、SUSEから提供されている同じパッケージによってパッケージが置き換えられるのを防ぎます。

注記
注記: インストールサイズの削減

サービスパックのマイグレーションの実行時に、YaSTは推奨パッケージをすべてインストールします。特にカスタム最小インストールの場合、これによってシステムのインストールサイズが大幅に増加することがあります。

このデフォルトの動作を変更し、必要なパッケージのみを許可するには、/etc/zypp/zypp.confsolver.onlyRequiresオプションを調整します。

solver.onlyRequires = true

また、ファイル/etc/zypp/zypper.confを編集して、installRecommendsオプションを変更します。

installRecommends=false

これにより、パッチや新しいパッケージのインストールなど、すべてのパッケージ操作の動作が変更されます。1回の呼び出しでZypperの動作を変更するには、パラメータ--no-recommendsを使用します。

サービスパックのマイグレーションを開始するには、次の手順を実行します。

  1. 登録サーバ上の未使用の拡張機能をすべて無効にして、将来、依存関係の競合が発生が発生するのを防ぎます。拡張機能を覚えていなくても、後でYaSTによって未使用の拡張機能リポジトリが検出され、無効にされます。

  2. 更新するマシンで実行されているGNOMEセッションにログインしている場合は、テキストコンソールに切り替えます。GNOMEセッション内からアップデートを実行することはお勧めしません。これは、リモートマシンからログインしている場合には該当しません(ただし、GNOMEでVNCセッションを実行している場合を除きます)。

  3. YaSTオンラインアップデートを実行して、システム用の最新のパッケージのアップデートを取得します。

  4. yast2-migrationパッケージおよびその依存関係をインストールします(YaSTのソフトウェア › ソフトウェア管理)。

  5. YaSTを再起動します。再起動しないと、新しくインストールしたモジュールがコントロールセンターに表示されません。

  6. YaSTで、Online Migration (オンラインマイグレーション)を選択します(アップグレードするSUSE Linux Enterprise Serverのバージョンによって、このモジュールはシステムまたはソフトウェアの下にあります)。可能性のあるマイグレーションターゲットと概要がYaSTによって表示されます。システムで使用可能なマイグレーションターゲットが複数ある場合は、リストから1つを選択します。

  7. リストからマイグレーションターゲットを1つ選択し、次へで続行します。

  8. マイグレーションツールによってアップデートリポジトリが提供される場合は、はいで続行することをお勧めします。

  9. オンラインマイグレーションツールにより、DVDまたはローカルサーバから古いリポジトリが検出される場合は、それらを無効にすることを強くお勧めします。古いリポジトリは以前のサービスパック用です。SUSEカスタマーセンターまたはRMTからの古いリポジトリは、自動的に削除されます。

    登録サーバがモジュールまたは拡張機能のマイグレーションを提供しない場合、そのリポジトリ設定は変更されないままになります。これは通常、製品のバージョンまたはサービスパックに固有ではないNVIDIA Compute Moduleなどのサードパーティリポジトリで発生します。必要に応じて、マイグレーション後にリポジトリ設定を手動で確認できます。

  10. 概要を確認し、次へをクリックしてマイグレーションを続行します。更新開始を選択して確認します。

  11. マイグレーションが正常に完了したら、システムを再起動します。

5.5 Zypperによるアップグレード

を使用してサービスパックのマイグレーションを実行するには、コマンドラインツールzypper migrationzypperをパッケージ zypper-migration-plugin.

注記
注記: インストールサイズの削減

サービスパックのマイグレーションの実行時に、YaSTは推奨パッケージをすべてインストールします。特にカスタム最小インストールの場合、これによってシステムのインストールサイズが大幅に増加することがあります。

このデフォルトの動作を変更し、必要なパッケージのみを許可するには、/etc/zypp/zypp.confsolver.onlyRequiresオプションを調整します。

solver.onlyRequires = true

また、ファイル/etc/zypp/zypper.confを編集して、installRecommendsオプションを変更します。

installRecommends=false

これにより、パッチや新しいパッケージのインストールなど、すべてのパッケージ操作の動作が変更されます。1回の呼び出しでZypperの動作を変更するには、パラメータ--no-recommendsを使用します。

サービスパックのマイグレーションを開始するには、次の手順を実行します。

  1. 更新するマシンで実行されているGNOMEセッションにログインしている場合は、テキストコンソールに切り替えます。GNOMEセッション内からアップデートを実行することはお勧めしません。これは、リモートマシンからログインしている場合には該当しません(ただし、GNOMEでVNCセッションを実行している場合を除きます)。

  2. SUSE Linux Enterpriseマシンをまだ登録していない場合は登録します。

    > sudo SUSEConnect --regcode YOUR_REGISTRATION_CODE
  3. マイグレーションを開始します。

    > sudo zypper migration

    マイグレーションプロセスに関する注記

    • システムで使用可能なマイグレーションターゲットが複数ある場合は、Zypperでリストから1つを選択できます。これはSPを1つまたは複数スキップするのと同じことです。基本製品(SLES、SLED)のオンラインマイグレーションを使用できるのは、メジャーバージョンのSP間のみであることに注意してください。

    • デフォルトでは、Zypperは、zypper dupに渡されるオプション--no-allow-vendor-changeを使用します。パッケージがサードパーティリポジトリからインストールされている場合、このオプションにより、SUSEから提供されている同じパッケージによって該当するパッケージが置き換えられるのを防ぎます。

    • Zypperにより、DVDまたはローカルサーバから提供されている古いリポジトリが検出される場合は、それらを無効にすることを強くお勧めします。SUSEカスタマーセンターまたはRMTからの古いリポジトリは自動的に削除されます。

  4. すべての変更内容を確認します。特に、削除されるパッケージに注意してください。「y」と入力して続行します(アップグレードするパッケージの正確な数はシステムによって異なる可能性があります)。

    266 packages to upgrade, 54 to downgrade, 17 new, 8 to reinstall, 5 to remove, 1 to change arch.
    Overall download size: 285.1 MiB. Already cached: 0 B  After the operation, additional 139.8 MiB will be used.
    Continue? [y/n/? shows all options] (y):

    シェルをスクロールするには、ShiftPage ↑ またはShiftPage ↓ キーを使用します。

  5. マイグレーションが正常に完了したら、システムを再起動します。

5.6 プレーンZypperによるアップグレード

インターネットや登録サーバにアクセスできないため、システムが登録されていない場合、YaSTマイグレーションまたはzypper migrationを使用して新しいサービスパックに移行することはできません。この場合でも、プレーンZypperやいくつかの手動での対話操作により新しいサービスパックに移行することができます。

重要
重要: 未登録システムの場合のみ

新しいサービスパックへのこのマイグレーションパスは、インターネットや登録サーバにアクセスできない未登録システムにのみサポートされています。たとえば、特別に保護されたネットワーク内のマシンの場合などです。システムが登録済みである場合は、YaSTまたはZypperマイグレーションを使用してください。

重要
重要: インストールソース

このマイグレーションパスでは、マイグレートするシステムがインストールソースにアクセスできる必要があります。たとえば、これはRMTサーバまたはSLPサーバを設定することで実行できます。

システムがインストール済みの製品バージョンの最新のアップデートリポジトリにアクセスできる必要もあります。

  1. 移行するマシンで実行されているグラフィカルセッションにログインしている場合は、そのセッションをログアウトして、テキストコンソールに切り替えます。グラフィカルセッション内からアップデートを実行することはお勧めしません。これは、リモートマシンからログインしている場合には該当しません(ただし、XでVNCセッションを実行している場合を除きます)。

  2. SUSE Linux Enterpriseの古いリポジトリを使用してパッケージ管理ツールを更新します。

    > sudo zypper patch --updatestack-only
  3. 現在リポジトリが割り当てられていないパッケージ(孤立したパッケージ)のリストを取得します。これらのパッケージは移行されず、マイグレーション後に動作する保証はありません(依存する他のパッケージは互換性がなくなったため変更されている可能性があるため)。リストを取得するには、次のコマンドを実行します:

    > sudo zypper packages --orphaned

    リストを注意深く確認して、必要なくなったすべての孤立パッケージを削除します。残りのすべての孤立パッケージをメモしてください。後で比較用に必要となります。

  4. 次のコマンドを実行して、システムが現在サブスクライブしているすべてのリポジトリのリストを取得します。

    > sudo zypper repos -u

    製品バージョン番号が15-SP6となるように、各リポジトリのURLをアップデートします。たとえば、リポジトリのURLが、

    http://rmt.example.com/repo/SUSE/Products/SLE-15-SP2-Product-SLES/x86_64/product/

    の場合は、次のように変更します。

    http://rmt.example.com/repo/SUSE/Products/SLE-15-SP3-Product-SLES/x86_64/product/

    これは、有効になっているすべてのリポジトリで実行される必要があります。また、後でアクティブ化するときにシステム内に間違ったインストールソースが存在しないように、現在無効になっているリポジトリに対してもこの操作を行うことを検討してください。

    リポジトリURLを変更するには、次のオプションがあります。

    1. YaST › ソフトウェア › ソフトウェアリポジトリの使用。リポジトリを選択して、編集をクリックして必要な変更を行います。すべてのリポジトリに対してこれを繰り返します。

    2. Zypperの使用。次のコマンドを実行して、古いリポジトリを削除します。

      > sudo zypper removerepo OLD_REPO_ID

      削除後、対応する新しいリポジトリを次のコマンドを実行して追加します。

       > sudo zypper addrepo -f URL NAME-15-SP6
    3. /etc/zypp/repos.dでリポジトリ設定ファイルを編集する。各リポジトリは1つの設定ファイルで表されます。各ファイルで、baseurlパラメータの値を変更する必要があります。

  5. zypper repos -uを実行して変更を確認し、次のコマンドを実行してリポジトリをアップデートします。

    > sudo zypper refresh -f -s

    リポジトリのアップデートに失敗した場合は、間違ったURLを入力していないか再確認します。問題が修正できない場合は、失敗したリポジトリを無効にすることをお勧めします。

    すべてのリポジトリが正常に設定された場合は、次のコマンドを再度実行して、

    > sudo zypper refresh -f -s

    すべて」のリポジトリが最新であることを確認します。

  6. マイグレーションを開始する前に、まずテストランを実行することをお勧めします。

    > sudo zypper dup -D --no-allow-vendor-change --no-recommends

    パラメータ-Dは、実際にシステムを変更せずにマイグレーションをシミュレートする、ドライランを実行します。問題が発生する場合は、修正してから続行してください。テストランが成功した場合は、次のコマンドを実行して実際のマイグレーションを実行します:

    > sudo zypper dup --no-allow-vendor-change --no-recommends

    -no-allow-vendor-changeは、サードパーティRPMが基本システムからRPMを上書きしないようにします。--no-recommendsオプションは、初期インストール時に選択解除したパッケージが再び追加されないようにします。

  7. マイグレーションが終了して、システムが新しいサービスパックバージョンで起動したら、孤立パッケージのチェックを再度実行します。

    > sudo zypper packages --orphaned

    新しいリストとマイグレーションを開始する前に生成されたリストを比較します。リストに新しいパッケージが表示された場合は、新しいサービスパックの別のモジュールに移動されたことが原因である可能性があります。以前のインストールにそのモジュールがなかった場合、このパッケージはアップデートされていません。

    https://scc.suse.com/packagesでパッケージが属するモジュールを確認できます。zypper addrepoまたはYaSTソフトウェアリポジトリモジュールを使用して、不足しているモジュールを追加し、次のコマンドを実行して後で孤立パッケージをアップデートします。

    > sudo zypper install --no-recommends LIST OF PACKAGES
  8. 新しいサービスパックに正常に移行しました。

5.7 サービスパックのロールバック

サービスパックの有効性が認められない場合は、SUSE Linux Enterpriseシステムをサービスパックのマイグレーションが開始される前の状態に戻すことができます。このためには、スナップショットが有効なBtrfsルートパーティションであることが前提条件です(これはSLES 12以降のデフォルトです)。詳細については第10章 「Snapperを使用したシステムの回復とスナップショット管理を参照してください。

  1. すべてのSnapperスナップショットのリストを取得します。

    > sudo snapper list

    出力を確認して、サービスパックのマイグレーションの開始直前に作成されたスナップショットを見つけます。列Descriptionには対応するステートメントが含まれており、スナップショットには列importantUserdataというマークが付いています。列#のスナップショット番号と、列Dateの日付を覚えます。

  2. システムを再起動します。ブートメニューからStart boot loader from a read-only snapshot (読み込み専用スナップショットからブートローダを起動)を選択して、前の手順で覚えた日付と番号が付いたスナップショットを選択します。2番目のブートメニュー(スナップショットのブートメニュー)がロードされます。SLES 15 SP6で始まるエントリを選択して起動します。

  3. システムが以前の状態で起動し、システムパーティションは読み込み専用でマウントされます。rootとしてログインし、正しいスナップショットを選択しているかどうかを確認します。また、すべてが正常に機能することも確認します。ルートファイルシステムは読み込み専用でマウントされるため、機能の制限が適用される場合があることに注意してください。

    問題がある場合、または間違ったスナップショットをブートした場合は、再起動して、ブート元として別のスナップショットを選択します。この時点では、恒久的な変更は加えられていません。スナップショットが正しく、正常に機能する場合、次のコマンドを実行して変更を確定します。

    > sudo snapper rollback

    マシンを再起動します。ブート画面で、デフォルトのブートエントリを選択して、復元されたシステムで再起動します。

  4. リポジトリの設定が適切にリセットされているかどうかを確認します。さらに、すべての製品が適切に登録されているかどうかも確認します。いずれかが間違っていると、後でシステムを更新しようとしてもできなかったり、間違ったパッケージリポジトリを使用してシステムが更新されたりすることがあります。

    次の手順を開始する前に、システムがインターネットにアクセスできることを確認してください。

    1. 次のコマンドを実行して、サービスとリポジトリを更新します。

      > sudo zypper ref -fs
    2. 次のコマンドを実行して、アクティブなリポジトリのリストを取得します。

      > sudo zypper lr

      このコマンドの出力を入念に確認します。更新対象として追加したサービスとリポジトリが一覧にされていてはなりません。たとえば、SLES 15 SP6からSLES15 GAへのマイグレーションをロールバックする場合、SLES15-GAのリポジトリではなく、SLES15-SP6のリポジトリがリストに含まれている必要があります。

      間違ったリポジトリが一覧にされている場合は削除し、必要に応じて、製品またはサービスパックのバージョンに一致するバージョンに置き換えます。サポートされるマイグレーションパスのリポジトリのリストについては、1.3項 「モジュールの依存関係とライフサイクル」を参照してください。(リポジトリは自動的に更新されるため、手動での操作は必要ありませんが、確認して必要な修正を行うことがベストプラクティスです。)

    3. 最後に、次のコマンドを実行して、インストールされているすべての製品の登録状態を確認します。

      > sudo SUSEConnect --status

      すべての製品がRegisteredとレポートされる必要があります。そうなっていない場合は、次のコマンドを実行して登録を修復します。

      > sudo SUSEConnect --rollback

以上で、システムは正常にサービスパックのマイグレーション開始直前にキャプチャされた状態に戻りました。

5.8 SUSE Managerを使用したアップグレード

SUSE Managerは、SUSE Linux Enterpriseクライアントに対するアップデート、パッチ、およびセキュリティ修正を提供するためのサーバソリューションです。これには、一連のツールと、管理タスク用のWebベースのユーザインタフェースが付属しています。SUSE Managerの詳細については、https://www.suse.com/products/suse-manager/を参照してください。

マイグレーションにより、1つのメジャーバージョン内で特定のサービスパック(SP)を別のSPにマイグレートできます(たとえば、SLES 15 GAからSLES 15 SP6)。

マシンがSUSE Managerによって管理されている場合は、SUSE Managerドキュメントの説明に従ってアップデートしてください。「Client Migration」の手順については、https://documentation.suse.com/suma/で入手可能なSUSE Manager Upgrade Guideを参照してください。

5.9 openSUSE LeapからSUSE Linux Enterprise Serverへのアップグレード

openSUSE LeapインストールをSUSE Linux Enterprise Serverにアップグレードすることができます。どのバージョンの Leapがマイグレーションに対応しているかを確認するには、2.2項 「サポートされているSLES 15 SP6へのアップグレードパスおよびマイグレーションパス」を参照してください。

警告
警告: 一部のopenSUSEパッケージをマイグレートできない

openSUSEはSUSE Linux Enterprise Serverよりも多くのパッケージを提供します。追加パッケージのほとんどはSUSE Package Hubから入手可能であり、マイグレートされます。SUSE Package Hubから入手できない追加パッケージは、マイグレーション後にアップデートを受けられなくなるため、後で削除する必要があります。

システムを動作させるために必要なすべてのパッケージが、SUSE Linux Enterprise ServerとSUSE Package Hubのリポジトリから入手できることを確認してください。SUSE Package Hubの詳細については、https://packagehub.suse.com/を参照してください。

5.9.1 yast2 migrationによるアップグレード

次の手順は5.4項 「オンラインマイグレーションツール(YaST)を使用したアップグレード」で説明したものと同様ですが、いくつかの追加手順が必要となります。運用システムでこの手順を実行する前に、運用環境のセットアップを複製するテストシステムでまず実行することをお勧めします。

手順 5.1: yast2 migrationによるopenSUSE LeapからSUSE Linux Enterprise Serverへのアップグレード

openSUSE LeapからSUSE Linux Enterprise Serverにマイグレートするには、以下の手順を実行します。

  1. 未使用アプリケーションをすべて閉じてTTYに切り替えます。たとえば、CtrlAltF1を押します。rootとしてログインします。

  2. yast2-migrationrollback-helperパッケージをインストールします。

    # zypper in yast2-migration rollback-helper
  3. rollback-helperサービスを有効化します。

    # systemctl enable rollback
  4. SUSEカスタマーセンターにシステムを登録します。

    # yast2 registration
  5. マイグレーションを実行します。

    # yast2 migration

    パッケージが競合する場合は、YaSTが対処法のリストを表示するので、そこから選択します。

  6. システムを再起動します。

    # reboot

これで、SUSE Linux Enterprise Serverにシステムを正常にマイグレートできました。第6章 「アップグレードの終了の手順を続け、孤立したパッケージを削除して完全にサポートされているSUSE Linux Enterpriseインストールを実行していることを確認します。

マイグレーション後に問題が生じた場合は、サービスパックのアップグレードと同様にマイグレーションを元に戻すことができます。処理手順の詳細については、 5.7項 「サービスパックのロールバック」を参照してください。

5.9.2 yast2 migration_sleによるアップグレード

openSUSE LeapからSUSE Linux Enterprise Serverへの簡略化されたマイグレーションは、Leap 15.4の時点では技術プレビューとして使用できます。

手順 5.2: yast2 migration_sleによるopenSUSE LeapからSUSE Linux Enterprise Serverへのアップグレード

openSUSE LeapからSUSE Linux Enterprise Serverにマイグレートするには、以下の手順を実行します。

  1. 未使用アプリケーションをすべて閉じます(推奨)。

  2. yast2-migration-slerollback-helperパッケージをインストールします。

    > sudo zypper in yast2-migration-sle rollback-helper
  3. rollback-helperサービスを有効化します。

    > sudo systemctl enable rollback
  4. YaSTを開き、ソフトウェア › オンラインマイグレーションを選択するか、または次のコマンドを実行します。

    > sudo yast2 migration_sle

    ウィザードによってマイグレーションプロセスを順を追って実行できます。保留中の更新がある場合、システムを登録する前にインストールできます。登録するには、登録コードおよび電子メールアドレスを入力します。ローカルRMTサーバで登録するには、登録コードの代わりにサーバのURLを入力し、電子メールアドレスを空のままにします。

    システムが登録された後、SUSE Linux Enterprise Serverリポジトリが追加され、SLEパッケージがインストールされてopenSUSEパッケージを置き換えます。

  5. システムを再起動します。

    > sudo reboot

これで、SUSE Linux Enterprise Serverにシステムを正常にマイグレートできました。第6章 「アップグレードの終了の手順を続け、孤立したパッケージを削除して完全にサポートされているSUSE Linux Enterpriseインストールを実行していることを確認します。

マイグレーション後に問題が生じた場合は、サービスパックのアップグレードと同様にマイグレーションを元に戻すことができます。処理手順の詳細については、 5.7項 「サービスパックのロールバック」を参照してください。