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 社による戦いになるのでしょうか、それとも勝者総取りになるのでしょうか。
人生は旅のようなものです。コピーライティングを職業として選んだということは、旅の目的を選んだというこ...
クラウド ネイティブの可観測性が、リアルタイムの分析情報、俊敏な意思決定、最適なクラウド使用を可能に...
多くのウェブマスターの友人、特に初心者の友人は、ウェブサイトの最適化の初期段階で必然的にさまざまなこ...
六益クラウドインターコネクトは、メーデー連休期間中、米国ロサンゼルスのCeraデータセンターのChi...
最近、プロジェクトに簡単な分散リクエスト追跡機能を追加したいと考えています。フロントエンドからゲート...
Amazon Web Services は、2022 re:Invent Global Confer...
[51CTO.com オリジナル記事] 今日の話題 (262) データベースをクラウド上に保存するし...
私の国のインターネットの発展と成長のおかげで、電子商取引業界はわずか10年余りで急速な成長を遂げまし...
IT 業界で長く働いていると、名前は変わるものの、同じことが何度も繰り返されていることに気がつくでし...
今日の企業は、かつてないほど多くのデータにアクセスできます。これらのデータは、量と変動性の両面で驚く...
9月21日、スタートアップダークホースとB2Bサークルが主催する「企業サービスTOP50ダークホース...
ウェブサイトが収益を上げたい場合、トラフィックなしでは成り立ちません。その結果、多くのウェブマスター...
メガレイヤーはどうですか?メガレイヤーフィリピンはどうですか?以前、HostCat のウェブサイトで...
年末も近づき、そろそろ一年を総括する時期になりました。少し前に、Apple は 2014 年に iT...
2013年5月16日、AppleはApp Storeのダウンロード数が500億回を超え、開発者が70...