12.4. コマンドラインインターフェイスを使用した仮想マシンの移行
仮想マシンの現在のホストが不安定な場合や使用できない場合や、ホストワークロードを再分散する場合は、仮想マシンを別の KVM ホストに移行できます。ライブマイグレーション または オフラインマイグレーション を実行できます。2 つのシナリオの違いについては、仮想マシンの移行の仕組み を参照してください。
前提条件
- ハイパーバイザー: ソースホストと宛先ホストの両方が KVM ハイパーバイザーを使用します。
-
ネットワーク接続: ソースホストと宛先ホストはネットワーク経由で相互にアクセスできます。
ping
ユーティリティーを使用してこれを確認します。 開いているポート: 宛先ホストで次のポートが開いていることを確認します。
- ポート 22 は、SSH を使用して宛先ホストに接続するために必要です。
- ポート 16509 は、TLS を使用して宛先ホストに接続するために必要です。
- ポート 16514 は、TCP を使用して宛先ホストに接続するために必要です。
- ポート 49152 - 49215 は、QEMU がメモリーおよびディスク移行データを転送するために必要です。
- ホスト: Red Hat が移行に対応できるようにするには、ソースホストと宛先ホストが特定のオペレーティングシステムとマシンタイプを使用している必要があります。これを確認するには、Supported hosts for virtual machine migration を参照してください。
- CPU: 仮想マシンは、宛先ホストの CPU 機能と互換性がある必要があります。これを確認するには、仮想マシン移行のホスト CPU の互換性の確認 を参照してください。
ストレージ: 移行される仮想マシンのディスクイメージは、ソースホストと宛先ホストの両方からアクセスできます。オフラインマイグレーションの場合は任意ですが、実行中の仮想マシンの移行に必要になります。両方のホストのストレージアクセスを確保するには、次のいずれかに該当している必要があります。
- ストレージエリアネットワーク (SAN) 論理ユニット (LUN) を使用している。
- Ceph Storage クラスター を使用している。
-
ソース仮想マシンディスクと同じ形式とサイズの ディスクイメージを作成済み で、仮想マシンを移行するときに
--copy-storage-all
パラメーターを使用する。 - ディスクイメージが別のネットワーク上の場所にある。このような仮想マシンの共有ストレージを設定する手順は、Sharing virtual machine disk images with other hosts を参照してください。
ネットワーク帯域幅: 実行中の仮想マシンを移行する場合、ネットワーク帯域幅は仮想マシンがダーティーメモリーページを生成する速度を超える必要があります。
ライブマイグレーションを開始する前に仮想マシンのダーティーページ速度を取得するには、次の手順を実行します。
短期間、仮想マシンのダーティーページ生成速度を監視します。
# virsh domdirtyrate-calc <example_VM> 30
監視が終了したら、結果を取得します。
# virsh domstats <example_VM> --dirtyrate Domain: 'example-VM' dirtyrate.calc_status=2 dirtyrate.calc_start_time=200942 dirtyrate.calc_period=30 dirtyrate.megabytes_per_second=2
この例では、仮想マシンが 1 秒あたり 2MB のダーティーメモリーページを生成しています。帯域幅が 2MB/s 以下のネットワーク上でこのような仮想マシンをライブマイグレーションしようとすると、仮想マシンを一時停止したり、ワークロードを低くしたりしないと、ライブマイグレーションが進行しません。
ライブマイグレーションが正常に終了するように、Red Hat では、ネットワークの帯域幅が仮想マシンのダーティーページの生成速度を大幅に上回ることを推奨しています。
注記calc_period
オプションの値は、ワークロードとダーティーページ速度により異なる場合があります。いくつかのcalc_period
値を試して、環境のダーティーページ速度に合わせた最適な期間を決定できます。
- ブリッジタップネットワークの詳細: パブリックブリッジタップネットワーク内の既存の仮想マシンを移行する場合、ソースホストと宛先ホストは同じネットワーク上に配置されている必要があります。そうでない場合は、移行後に仮想マシンのネットワークが機能しなくなります。
接続プロトコル: 仮想マシンの移行を実行する場合、ソースホスト上の
virsh
クライアントは、いくつかのプロトコルのいずれかを使用して、宛先ホスト上の libvirt デーモンに接続できます。次の手順の例では SSH 接続を使用していますが、別の接続を選択することもできます。libvirt で SSH 接続を使用する場合は、
virtqemud
ソケットが有効になっていて、宛先ホストで実行されていることを確認してください。# systemctl enable --now virtqemud.socket
libvirt で TLS 接続を使用する場合は、
virtproxyd-tls
ソケットが有効になっていて、宛先ホストで実行していることを確認してください。# systemctl enable --now virtproxyd-tls.socket
libvirt で TCP 接続を使用する場合は、
virtproxyd-tcp
ソケットが有効になっていて、宛先ホストで実行していることを確認してください。# systemctl enable --now virtproxyd-tcp.socket
手順
仮想マシンをあるホストから別のホストに移行するには、virsh migrate
コマンドを使用します。
オフラインマイグレーション
次のコマンドは、SSH トンネルを使用して、シャットオフされた
example-VM
仮想マシンをローカルホストからexample-destination
ホストのシステム接続に移行します。# virsh migrate --offline --persistent <example_VM> qemu+ssh://example-destination/system
ライブマイグレーション
次のコマンドは、SSH トンネルを使用して、
example-VM
仮想マシンをローカルホストからexample-destination
ホストのシステム接続に移行します。仮想マシンは移行中も稼働し続けます。# virsh migrate --live --persistent <example_VM> qemu+ssh://example-destination/system
移行が完了するまで待ちます。ネットワーク帯域幅、システム負荷、仮想マシンのサイズによっては、このプロセスに時間がかかる場合があります。
virsh migrate
で--verbose
オプションが使用されていないと、CLI はエラー以外の進捗インジケーターを表示しません。移行中は、
virsh domjobinfo
ユーティリティーを使用して移行の統計を表示できます。
マルチ FD ライブマイグレーション
ライブマイグレーション中に、宛先ホストへの複数の並列接続を使用できます。これは、複数のファイル記述子 (マルチ FD) マイグレーションとも呼ばれます。マルチ FD 移行では、移行プロセスに利用可能なネットワーク帯域幅をすべて利用することで、移行を高速化できます。
# virsh migrate --live --persistent --parallel --parallel-connections 4 <example_VM> qemu+ssh://<example-destination>/system
この例では、4 つのマルチ FD チャネルを使用して <example_VM> 仮想マシンを移行します。利用可能なネットワーク帯域幅 10 Gbps ごとに 1 つのチャネルを使用することを推奨します。デフォルト値は 2 チャネルです。
ダウンタイム制限を延長したライブマイグレーション
ライブマイグレーション中に仮想マシンを一時停止できる最大時間 (ミリ秒単位) を指定する
maxdowntime
パラメーターを設定することで、ライブマイグレーションの信頼性を向上できます。ダウンタイムを長く設定すると、マイグレーションが正常に完了するようになります。# virsh migrate-setmaxdowntime <example_VM> <time_interval_in_milliseconds>
Post-copy migration
仮想マシンのメモリーフットプリントが大きい場合は、コピー後 のマイグレーションを実行できます。これにより、まずソース仮想マシンの CPU 状態が転送され、移行された仮想マシンが宛先ホスト上ですぐに起動されます。移行された仮想マシンが宛先ホスト上ですでに実行された後に、ソース仮想マシンのメモリーページが転送されます。このため、コピー後 のマイグレーションでは、移行された仮想マシンのダウンタイムが短くなる可能性があります。
ただし、宛先ホスト上で実行中の仮想マシンが、まだ転送されていないメモリーページにアクセスしようとする可能性があり、これにより、ページフォールト が発生します。移行中の ページフォールト の発生が多すぎると、移行された仮想マシンのパフォーマンスが大幅に低下する可能性があります。
コピー後 のマイグレーションが複雑になる可能性があることを考慮すると、標準のライブマイグレーションを開始し、指定された時間内にライブライブマイグレーションを完了できない場合は コピー後 のライブマイグレーションに切り替える次のコマンドを使用することを推奨します。
# virsh migrate --live --persistent --postcopy --timeout <time_interval_in_seconds> --timeout-postcopy <example_VM> qemu+ssh://<example-destination>/system
自動コンバージドライブマイグレーション
仮想マシンのメモリーワークロードが高い場合は、
--auto-converge
オプションを使用できます。このオプションは、仮想マシンの CPU の実行速度を自動的に低下させます。その結果、この CPU スロットリングはメモリー書き込み速度を低下させるのに役立ちます。これにより、メモリーワークロードの高い仮想マシンでもライブマイグレーションが成功する可能性があります。ただし、CPU スロットリングは、メモリー書き込みが CPU 実行速度に直接関係しないワークロードの解決には役立たず、ライブマイグレーション中に仮想マシンのパフォーマンスに悪影響を与える可能性があります。
# virsh migrate --live --persistent --auto-converge <example_VM> qemu+ssh://<example-destination>/system
検証
オフライン マイグレーションの場合:
宛先ホストで、利用可能な仮想マシンをリスト表示して、仮想マシンが正常に移行されたことを確認します。
# virsh list --all Id Name State ---------------------------------- 10 example-VM-1 shut off
ライブ マイグレーションの場合:
宛先ホストで、利用可能な仮想マシンをリスト表示して、宛先仮想マシンの状態を確認します。
# virsh list --all Id Name State ---------------------------------- 10 example-VM-1 running
仮想マシンの状態が
running
と表示されている場合、移行が完了したことを意味します。ただし、ライブマイグレーションがまだ進行中の場合、宛先仮想マシンの状態はpaused
と表示されます。
コピー後 のマイグレーションの場合:
ソースホストで、利用可能な仮想マシンをリスト表示して、ソース仮想マシンの状態を確認します。
# virsh list --all Id Name State ---------------------------------- 10 example-VM-1 shut off
宛先ホストで、利用可能な仮想マシンをリスト表示して、宛先仮想マシンの状態を確認します。
# virsh list --all Id Name State ---------------------------------- 10 example-VM-1 running
ソース仮想マシンの状態が
shut off
と表示され、宛先仮想マシンの状態がrunning
と表示されている場合、移行は完了していることを意味します。
関連情報
-
virsh migrate --help
コマンド -
システム上の
virsh (1)
man ページ