KVM は内部的にどのように動作しますか?

KVM は内部的にどのように動作しますか?

[[314764]]

1. KVMアーキテクチャ

kvm の基本構造は 2 つの部分で構成されます。

kvm ドライバーは Linux カーネルのモジュールになりました。主に仮想マシンの作成、仮想メモリの割り当て、VCPU レジスタの読み取りと書き込み、VCPU の操作を担当します。

もう 1 つのコンポーネントは Qemu です。これは、仮想マシンのユーザー スペース コンポーネントをシミュレートし、I/O デバイス モデルを提供し、周辺機器にアクセスするために使用されます。

図1 KVMの基本構造

kvm の基本構造を上の図に示します。 kvm はすでにカーネル モジュールであり、標準の Linux 文字セット デバイス (/dev/kvm) として認識されます。 Qemu は libkvm アプリケーション インターフェイスを使用して、ioctl 経由で fd を使用するデバイス ドライバーに仮想マシンの作成および実行コマンドを送信します。デバイス ドライバー kvm は、以下に示すように、コマンドを解析します (kvm_dev_ioctl 関数は kvm_main.c ファイル内にあります)。

図2 kvm_dev_ioctl関数

kvm モジュールは、Linux ホストを仮想マシン モニター (VMM) にし、元の 2 つの Linux 実行モードに基づいて新しいクライアント モードを追加します。クライアント モードには、独自のカーネル モードとユーザー モードがあります。仮想マシンの実行中、3 つのモードは次のように動作します。

クライアント モード: 非 I/O クライアント コードを実行します。仮想マシンはこのモードで実行されます。

ユーザー モード: ユーザーに代わって I/O 命令を実行します。 Qemu はこのモードで実行されます。

カーネル モード: クライアント モードの切り替えを実装し、I/O またはその他の命令によって発生するクライアント モードの終了 (VM_EXIT) を処理します。 kvm モジュールはこのモードで動作します。

kvm モデルでは、各 Gust OS は標準の Linux プロセスとして扱われ、Linux プロセス管理コマンドを使用して管理できます。

ここで、qemu が ioctl を通じて KVM_CREATE_VM 命令を発行する場合、VM を作成した後、qemu は KVM_CREATE_VCPU などのいくつかのコマンドを VM に送信する必要があります。もちろん、これらのコマンドも ioctl を通じて送信されます。ユーザプログラム内で ioctl を使って KVM_CREATE_VM を送信した場合の戻り値は、新しく作成された VM に対応する fd (kvm_vm) になります。 fd は、特定の仮想マシンインスタンスを指すために作成されたファイル記述子です。この fd は、アクセス制御のために VM にコマンドを送信するために使用されます。 kvm がこれらのコマンドを解析するために使用する関数は kvm_vm_ioctl です。

2. KVMの動作原理

kvm の基本的な動作原理の概要:

ユーザー モードの qemu は、ioctl を介してカーネル モードに入るために libkvm を使用します。 kvm モジュールは仮想マシンの仮想メモリを作成し、仮想 CPU の後に VMLAUCH 命令を実行してクライアント モードに入ります。ゲスト OS をロードして実行します。ゲスト OS が外部割り込みまたはシャドウ ページ テーブル ページ フォールトに遭遇すると、ゲスト OS の実行が中断され、例外を処理するためにゲスト モードが終了し、その後ゲスト モードが再び開始されてゲスト コードが実行されます。 I/O イベントが発生するか、シグナル キューにシグナルが到着すると、ユーザー モード処理が開始されます。 (下図参照)

図3 KVMの動作原理フローチャート

<<:  分散 KVM とは何かを理解するための分散 KVM システム アーキテクチャ図

>>:  2020 年、クラウド コンピューティングは上位 4 社による戦いになるのでしょうか、それとも勝者総取りになるのでしょうか。

推薦する

24khost-1.5G メモリの格安 VPS-ラスベガス

24khost は以前にもストレージ VPS を紹介してきました。今回はラスベガスの FiberHu...

短期間で成功し、すぐに利益を得ることを狙う企業ウェブサイトによくあるSEOの誤解について簡単に説明します。

インターネットは、ビジネスオーナーからますます注目を集めています。現在、ますます多くの企業がインター...

中国のパブリッククラウドサービス市場レポートが発表、テンセントクラウドは引き続き2位

10月26日、IDCの最新の「中国パブリッククラウドサービス市場(2022年上半期)追跡」レポートに...

vpscheap-$15 年/512MB メモリ/20GB SSD/1000MB 無制限/シカゴ/coresite

vpscheap.net は、低価格 VPS 業界では比較的古い企業です。2010 年に設立され、非...

ウェブサイトのSEO: 検索エンジンに適したドメイン名を作成する

検索エンジンの運営目的は、より正確で有用な情報をユーザーに提供することです。この目的は、検索エンジン...

シンプルで習得しやすいソフトコピーマーケティングスキルとは?この5つのステップを見てください

ショートビデオ、セルフメディア、インフルエンサーのためのワンストップサービス私は企業のプロダクトマー...

外国貿易ウェブサイトのSEOに影響を与える要因の分析

ウェブサイトの構築を準備する際に、あなたのビジネスや会社にとって最も重要な要素は何でしょうか? それ...

クラウド コンピューティング サービスは将来どのような脅威に直面するでしょうか?

クラウド コンピューティングはここ数年 IT 業界の流行語となっていますが、脅威は増大しています。最...

PR価値のアップデート: PR価値の価値の簡単な分析

以前は、ウェブマスターはPR値に夢中でしたが、Googleが中国市場から撤退したため、PR値はますま...

スーパープロモーションでビジネスが世界中に広がる

Taobao チームはますます大きくなっており、それは競争がますます激しくなっていることを意味します...

TektonとArgo CDを組み合わせてGitOpsを実装する

以前は、アプリケーションの CI/CD プロセスを完了するために Tekton を使用していましたが...

人気のオリンピックイベントからトラフィックを引き寄せる最速の方法

毎年開催されるオリンピックは誰もが注目するイベントです。昔は誰もがテレビで試合を観戦していましたが、...