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 社による戦いになるのでしょうか、それとも勝者総取りになるのでしょうか。

推薦する

優れたコピーライターになるための3つのステップ

人生は旅のようなものです。コピーライティングを職業として選んだということは、旅の目的を選んだというこ...

クラウドネイティブの可観測性がインダストリー4.0の成功をいかに推進するか

クラウド ネイティブの可観測性が、リアルタイムの分析情報、俊敏な意思決定、最適なクラウド使用を可能に...

新しいサイトの初期最適化における誤解についてお話ししましょう

多くのウェブマスターの友人、特に初心者の友人は、ウェブサイトの最適化の初期段階で必然的にさまざまなこ...

六易クラウド:メーデー特別価格、クラウドサーバー20%割引、ロサンゼルス聯通VIP回線、ロサンゼルス200G高防御、香港安昌BGP、香港大埔CN2、香港沙田CN2

六益クラウドインターコネクトは、メーデー連休期間中、米国ロサンゼルスのCeraデータセンターのChi...

マイクロサービスはシンプルな分散ログ追跡を実装します

最近、プロジェクトに簡単な分散リクエスト追跡機能を追加したいと考えています。フロントエンドからゲート...

[AWS コミュニティディスカッション活動概要 3] クラウドデータベースの長所と短所

[51CTO.com オリジナル記事] 今日の話題 (262) データベースをクラウド上に保存するし...

3つの主要なシナリオ、20以上の厳選された製品、Huawei Cloudは電子商取引業界に深く関わっています

私の国のインターネットの発展と成長のおかげで、電子商取引業界はわずか10年余りで急速な成長を遂げまし...

15のマルチクラウド管理プラットフォームの評価

IT 業界で長く働いていると、名前は変わるものの、同じことが何度も繰り返されていることに気がつくでし...

企業のクラウド移行ガイドについて知っておくべきこと

今日の企業は、かつてないほど多くのデータにアクセスできます。これらのデータは、量と変動性の両面で驚く...

エンタープライズレベルのサービストップ20に選ばれたLiudu Renhe(EC)は、SaaSの成長可能性を検証しました。

9月21日、スタートアップダークホースとB2Bサークルが主催する「企業サービスTOP50ダークホース...

10の視点からウェブサイトのトラフィックを伸ばす

ウェブサイトが収益を上げたい場合、トラフィックなしでは成り立ちません。その結果、多くのウェブマスター...

メガレイヤーはどうですか?フィリピンのプレミアムラインのレビュー、Netflix/chatgptのブロック解除

メガレイヤーはどうですか?メガレイヤーフィリピンはどうですか?以前、HostCat のウェブサイトで...

Apple、2014年のiTunesベスト・オブ・ザ・イヤーリストを発表

年末も近づき、そろそろ一年を総括する時期になりました。少し前に、Apple は 2014 年に iT...

モバイルインターネット市場でアプリから収益を上げることの難しさについての簡単な分析

2013年5月16日、AppleはApp Storeのダウンロード数が500億回を超え、開発者が70...