Skip to content

Latest commit

 

History

History
1450 lines (1000 loc) · 65.6 KB

README.ja.md

File metadata and controls

1450 lines (1000 loc) · 65.6 KB

Create ReleaseTranslate READMEDeploy GitHub PagesGenerate HTML and PDFPSScriptAnalyzerSlack Notification


MIT LicenseForksStargazersContributorsIssuesLinkedIn


LPIC-3 305-300 の学習

LPIC3-305-300

Explore the docs »
Web Site - Code Page - Report Bug - Request Feature


まとめ

TABLE OF CONTENT
  1. About The Project
  2. Getting Started
  3. Usage
  4. Roadmap
  5. Four Essential Freedoms
  6. Topic 351: Full Virtualization
  7. Topic 352: Container Virtualization
  8. Topic 353: VM Deployment and Provisioning
  9. License
  10. Contact
  11. Acknowledgments


プロジェクトについて

このプロジェクトは、学生や専門家が GNULinux の主要な概念を学習できるようにすることを目的としています。 およびフリー ソフトウェア\ Debian や RPM などの一部の GNULinux ディストリビューションがカバーされます\ 一部のパッケージのインストールと構成についても説明します\ こうすることで、コミュニティ全体が変更から恩恵を受ける機会を得ることができます。\ ソース コードへのアクセスがその前提条件です。\ 稼働中のマシンに vagrant を使用し、ラボを実行して、この記事の内容を実践してください。\ 必要なものを含む Vagrantfile をフォルダー Vagrant に公開しました\ 学習環境をアップロードするため


(back to top)

はじめる

学習を開始するには、上記のドキュメントを参照してください。

前提条件

インストール

リポジトリのクローンを作成する

git clone https://github.com/marcossilvestrini/learning-lpic-3-305-300.git
cd learning-lpic-3-305-300

テンプレートをカスタマイズする_Vagrantfile-トピック-XXX_。このファイルには、ラボ用の VMS 構成が含まれています。例:

  • ファイルVagrantfile-topic-351
    • vm.clone_directory = "<ドライバーの文字>:\\<マシンへ>\#{VM_NAME}-インスタンス-1" 例: vm.clone_directory = "E:\サーバー\ヴイエムウェア\#{VM_NAME}-インスタンス-1"
    • vm.vmx[「メムサイズ」"]= ""
    • vm.vmx[「numvcpus」"]= ""
    • vm.vmx[「cpuid"coresPerSocket」.]= ""

ファイル内のネットワーク構成をカスタマイズする構成/ネットワーク.


使用法

LPIC-3 305-300 試験について学習するには、このリポジトリを使用してください

上下用

スイッチa_Vagrantfile-トピック-xxx_名前付きの新しいファイルのテンプレートとコピー_ベイグラントファイル_

cd vagrant && vagrant up
cd vagrant && vagrant destroy -f

VMSを再起動する場合

cd vagrant && vagrant reload

重要:vagrant を使用せずに vms を再起動すると、起動後に共有フォルダーがマウントされません。

上下にはPowerShellを使用します

Windows プラットフォームを使用している場合は、VM を起動および停止するための PowerShell スクリプトを作成します。

vagrant/up.ps1
vagrant/destroy.ps1

(back to top)


ロードマップ

  • リポジトリの作成
  • ラボをプロビジョニングするためのスクリプトを作成する
  • トピック 351 に関する例を作成する
  • トピック 352 に関する例を作成する
  • トピック 353 に関する例を作成する
  • シミュレートされた itexam をアップロードする

4 つの必須の自由

0.目的を問わず、プログラムを自由に実行できる (自由 0)。\ 1.プログラムがどのように動作するかを研究し、そのように変更する自由\ あなたのコンピューティングを思いのままに (自由 1)。\ ソース コードへのアクセスがその前提条件です。\ 2.他の人を助けるためにコピーを再配布する自由 (自由 2)。\ 3. 修正したバージョンのコピーを他の人に配布する自由 (自由 3)。


コマンドを検査する

type COMMAND
apropos COMMAND
whatis COMMAND --long
whereis COMMAND
COMMAND --help, --h
man COMMAND

(back to top)


トピック 351: 完全仮想化

LPIC3-305-300


351.1 仮想化の概念と理論

**重さ:**6

**説明:**受験者は、仮想化の一般的な概念、理論、用語を理解し、理解している必要があります。これには、Xen、QEMU、libvirt の用語が含まれます。

主要な知識領域:

  • 仮想化用語を理解する
  • 仮想化の長所と短所を理解する
  • ハイパーバイザーと仮想マシン モニターのさまざまなバリエーションを理解する
  • 物理マシンから仮想マシンへの移行の主な側面を理解する
  • ホスト システム間での仮想マシンの移行の主な側面を理解する
  • スナップショット、一時停止、クローン作成、リソース制限など、仮想マシンの仮想化の機能と影響を理解する
  • oVirt、Proxmox、systemd-machined、VirtualBox の認識
  • Open vSwitch の認識

351.1 引用オブジェクト

Hypervisor
Hardware Virtual Machine (HVM)
Paravirtualization (PV)
Emulation and Simulation
CPU flags
/proc/cpuinfo
Migration (P2V, V2V)

ハイパーバイザー

タイプ 1 ハイパーバイザー (ベアメタル ハイパーバイザー)
タイプ 1 の定義

ホストの物理ハードウェア上で直接実行され、ホスト オペレーティング システムを必要とせずに VM を管理するための基本レイヤーを提供します。

タイプ 1 の特性
  • 高いパフォーマンスと効率。
  • レイテンシとオーバーヘッドが低減されます。
  • エンタープライズ環境やデータセンターでよく使用されます。
タイプ 1 の例
  • VMware ESXi: 企業環境で広く使用されている堅牢なハイパーバイザー。
  • Microsoft Hyper-V: Windows Server と統合され、強力なパフォーマンスと管理機能を提供します。
  • Xen: 多くのクラウド サービス プロバイダーによって使用されているオープンソースのハイパーバイザー。
  • KVM (カーネルベースの仮想マシン): Linux カーネルに統合され、Linux ベースのシステムに高いパフォーマンスを提供します。
タイプ 2 ハイパーバイザー (ホスト型ハイパーバイザー)
タイプ 2 の定義

従来のオペレーティング システム上で実行され、リソース管理とデバイス サポートをホスト OS に依存します。

タイプ 2 の特性
  • 特にパーソナルコンピュータでのセットアップと使用が簡単になります。
  • 開発、テスト、小規模な導入に対してより柔軟に対応します。
  • 通常、ホスト OS からのオーバーヘッドが追加されるため、タイプ 1 ハイパーバイザーよりも効率が低くなります。
タイプ 2 の例
  • VMware Workstation: 単一のデスクトップ上で複数のオペレーティング システムを実行するための強力なハイパーバイザー。
  • Oracle VirtualBox: 柔軟性と使いやすさで知られるオープンソースのハイパーバイザー。
  • Parallels Desktop: Mac ユーザーが Windows やその他のオペレーティング システムを macOS と一緒に実行できるように設計されています。
  • QEMU (Quick EMUlator): オープンソースのエミュレーターおよびバーチャライザーであり、KVM と組み合わせてよく使用されます。
タイプ 1 ハイパーバイザーとタイプ 2 ハイパーバイザーの主な違い
  • 導入環境:
    • タイプ 1 ハイパーバイザーは、ハードウェアとの直接対話と高いパフォーマンスのため、一般にデータセンターやエンタープライズ環境に導入されます。
    • タイプ 2 ハイパーバイザーは、個人使用、開発、テスト、および小規模な仮想化タスクにより適しています。
  • パフォーマンス:
    • タイプ 1 ハイパーバイザーは、ホスト OS に依存しないため、一般にパフォーマンスが向上し、遅延が低くなります。
    • タイプ 2 ハイパーバイザーは、ホスト OS 上で実行するオーバーヘッドにより、パフォーマンスが低下する可能性があります。
  • 管理と使いやすさ:
    • タイプ 1 ハイパーバイザーは、より複雑なセットアップと管理を必要としますが、大規模な展開向けの高度な機能と拡張性を提供します。
    • タイプ 2 ハイパーバイザーはインストールと使用が簡単で、個人ユーザーや小規模プロジェクトに最適です。
移行の種類

仮想マシンの作成と管理に使用されるテクノロジーであるハイパーバイザーのコンテキストでは、仮想化環境では P2V 移行と V2V 移行という用語が一般的です。
これらは、異なるタイプのプラットフォーム間でシステムを移行するプロセスを指します。

P2V - 物理から仮想への移行

P2V 移行とは、物理サーバーを仮想マシンに移行するプロセスを指します。
言い換えれば、専用の物理ハードウェア上で実行されているオペレーティング システムとそのアプリケーションは「変換」され、ハイパーバイザー (VMware、Hyper-V、KVM など) 上で実行される仮想マシンに移動されます。

  • 例: Windows または Linux システムを実行している物理サーバーがあり、それをクラウド インフラストラクチャや内部仮想化サーバーなどの仮想環境に移動したいと考えています。
    このプロセスには、オペレーティング システム、ドライバー、データを含むシステム状態全体をコピーして、物理ハードウェア上で動作するかのように実行できる同等の仮想マシンを作成することが含まれます。
V2V - 仮想から仮想への移行

V2V 移行とは、仮想マシンをあるハイパーバイザーから別のハイパーバイザーに移行するプロセスを指します。
この場合、仮想化環境 (VMware など) で仮想マシンがすでに実行されており、それを別の仮想化環境 (たとえば、Hyper-V または新しい VMware サーバー) に移動したいと考えています。

  • 例: VMware 仮想化サーバー上で実行されている仮想マシンがありますが、それを Hyper-V プラットフォームに移行することにしました。この場合、V2V 移行により、仮想マシンがある形式またはハイパーバイザーから別の形式またはハイパーバイザーに変換され、正しく実行を継続できるようになります。

HVM と準仮想化

ハードウェア支援仮想化 (HVM)
HVMの定義

HVM は、最新の CPU によって提供されるハードウェア拡張機能を利用してハードウェアを仮想化し、最小限のパフォーマンス オーバーヘッドで VM の作成と管理を可能にします。

HVM の主な特徴
  • ハードウェアサポート: Intel VT-x や AMD-V などの仮想化拡張機能に対する CPU サポートが必要です。
  • **完全仮想化:**ハイパーバイザーはハードウェア環境の完全なエミュレーションを提供するため、VM は変更されていないゲスト オペレーティング システムを実行できます。
  • **パフォーマンス:**通常、CPU 上でゲスト コードが直接実行されるため、ネイティブに近いパフォーマンスが提供されます。
  • **分離:**各 VM は独自の専用ハードウェアがあるかのように動作するため、VM 間に強力な分離が提供されます。
HVM の例

VMware ESXi、Microsoft Hyper-V、KVM (カーネルベースの仮想マシン)。

HVM の利点
  • **互換性:**変更を加えることなく、あらゆるオペレーティング システムを実行できます。
  • **パフォーマンス:**ハードウェアサポートによる高いパフォーマンス。
  • **安全:**ハードウェアによって提供される強化された分離機能とセキュリティ機能。
HVM の欠点
  • **ハードウェアの依存関係:**特定のハードウェア機能が必要なため、古いシステムとの互換性が制限されます。
  • **複雑:**より複雑な構成と管理が必要になる場合があります。
準仮想化
準仮想化の定義

準仮想化では、仮想環境を認識するようにゲスト オペレーティング システムを変更し、ハイパーバイザーとより効率的に対話できるようにします。

準仮想化の主な特徴
  • **ゲストの変更:**ハイパーコールを使用してハイパーバイザーと直接通信するには、ゲスト オペレーティング システムを変更する必要があります。
  • **パフォーマンス:**ハードウェアのエミュレーションに関連するオーバーヘッドが削減されるため、従来の完全仮想化よりも効率的になります。
  • **互換性:**準仮想化用に変更されたオペレーティング システムに限定されます。
準仮想化の例

準仮想化ゲストを備えた Xen、特定の構成の VMware ツール、および一部の KVM 構成。

準仮想化の利点
  • **効率:**ハードウェアの仮想化のオーバーヘッドを削減し、特定のワークロードのパフォーマンスを向上させる可能性があります。
  • **リソース使用率:**ゲスト OS とハイパーバイザー間の直接通信により、システム リソースがより効率的に使用されます。
準仮想化の欠点
  • **ゲスト OS の変更:**ゲスト OS を変更する必要があるため、サポートされているオペレーティング システムとの互換性が制限されます。
  • **複雑:**ハイパーコールの実装には、ゲスト OS の複雑さがさらに必要になります。
主な違い
ゲスト OS の要件
  • **HVM:**変更されていないゲスト オペレーティング システムを実行できます。
  • **準仮想化:**ハイパーバイザーと連携するには、ゲスト オペレーティング システムを変更する必要があります。
パフォーマンス
  • **HVM:**通常、ハードウェア支援による実行により、ネイティブに近いパフォーマンスが提供されます。
  • **準仮想化:**ハードウェア エミュレーションのオーバーヘッドを削減することで効率的なパフォーマンスを提供できますが、変更されたゲスト OS に依存します。
ハードウェアの依存関係
  • **HVM:**特定の CPU 機能 (Intel VT-x、AMD-V) が必要です。
  • **準仮想化:**特定の CPU 機能は必要ありませんが、ゲスト OS の変更が必要です。
分離
  • **HVM:**ハードウェア機能を使用して強力な絶縁を提供します。
  • **準仮想化:**ソフトウェアベースの分離に依存しますが、ハードウェアベースの分離ほど堅牢ではない可能性があります。
複雑
  • **HVM:**変更されていない OS をサポートしているため、一般に導入がより簡単です。
  • **準仮想化:**ゲスト OS への追加のセットアップと変更が必要となり、複雑さが増します。

NUMA (不均一メモリアクセス)

NUMA (Non-Uniform Memory Access) は、プロセッサによるメモリ アクセスを最適化するためにマルチプロセッサ システムで使用されるメモリ アーキテクチャです。
NUMA システムでは、メモリはプロセッサ間で不均等に分散されます。つまり、各プロセッサは、物理的に遠く離れたメモリ (「リモート メモリ」と呼ばれる) よりもメモリの一部 (「ローカル メモリ」) に高速にアクセスでき、関連付けられています。他のプロセッサと。

NUMA アーキテクチャの主な特徴
  1. ローカルおよびリモートメモリ: 各プロセッサには独自のローカル メモリがあり、より高速にアクセスできます。ただし、時間はかかりますが、他のプロセッサのメモリにアクセスすることもできます。
  2. 差別化されたレイテンシ: メモリ アクセスのレイテンシは、プロセッサがローカル メモリにアクセスしているか、別のノードのメモリにアクセスしているかによって異なります。ローカル メモリへのアクセスは高速ですが、別のノード (リモート) のメモリへのアクセスは低速です。
  3. スケーラビリティ: NUMA アーキテクチャは、多数のプロセッサを備えたシステムのスケーラビリティを向上させるように設計されています。プロセッサーを追加すると、メモリーも分散され、Uniform Memory Access (UMA) アーキテクチャーで発生するボトルネックが回避されます。
NUMAの利点
  • 大規模システムにおけるパフォーマンスの向上: 各プロセッサにはローカル メモリがあるため、メモリ アクセスに関して他のプロセッサとそれほど競合することなく、より効率的に動作できます。
  • スケーラビリティ: NUMA を使用すると、UMA アーキテクチャと比較して、多くのプロセッサと大量のメモリを備えたシステムをより効果的に拡張できます。
短所
  • プログラミングの複雑さ: プログラマは、メモリのどの領域がローカルかリモートかを認識し、パフォーマンスを向上させるためにローカル メモリの使用を最適化する必要があります。
  • 潜在的なパフォーマンスの低下: プロセッサがリモート メモリに頻繁にアクセスすると、待ち時間が長くなるため、パフォーマンスが低下する可能性があります。 このアーキテクチャは、スケーラビリティとメモリの最適化が重要であるサーバーやスーパーコンピュータなどの高性能マルチプロセッサ システムで一般的です。

オープンソース ソリューション

仮想化の種類

ハードウェア仮想化(サーバー仮想化)
HV の定義

物理ハードウェアを抽象化して、個別のオペレーティング システムとアプリケーションを実行する仮想マシン (VM) を作成します。

HV の使用例

データセンター、クラウドコンピューティング、サーバー統合。

HV の例

VMware ESXi、Microsoft Hyper-V、KVM。

オペレーティング システムの仮想化 (コンテナ化)
コンテナ化の定義

複数の分離されたユーザー空間インスタンス (コンテナー) を単一の OS カーネル上で実行できるようにします。

コンテナ化のユースケース

マイクロサービス アーキテクチャ、開発およびテスト環境。

コンテナ化の例

Docker、Kubernetes、LXC。

ネットワーク仮想化
ネットワーク仮想化の定義

ハードウェアとソフトウェアのネットワーク リソースを単一のソフトウェア ベースの管理エンティティに結合します。

ネットワーク仮想化の使用例

ソフトウェア定義ネットワーキング (SDN)、ネットワーク機能仮想化 (NFV)。

ネットワーク仮想化の例

VMware NSX、Cisco ACI、OpenStack Neutron。

ストレージ仮想化
ストレージ仮想化の定義

複数のデバイスの物理ストレージを単一の仮想ストレージ ユニットにプールし、一元管理できます。

ストレージ仮想化の定義の使用例

データ管理、ストレージの最適化、災害復旧。

ストレージ仮想化の定義例

IBM SAN ボリューム コントローラー、VMware vSAN、NetApp ONTAP。

デスクトップ仮想化
デスクトップ仮想化の定義

サーバー上でホストされている仮想マシン上でデスクトップ オペレーティング システムを実行できるようにします。

デスクトップ仮想化の定義の使用例

仮想デスクトップ インフラストラクチャ (VDI)、リモート ワーク ソリューション。

デスクトップ仮想化の定義例

Citrix Virtual Apps and Desktops、VMware Horizo​​n、Microsoft リモート デスクトップ サービス。

アプリケーションの仮想化
アプリケーション仮想化の定義

アプリケーションを基盤となるハードウェアやオペレーティング システムから分離し、隔離された環境で実行できるようにします。

アプリケーション仮想化の定義の使用例

アプリケーションの導入、互換性テストの簡素化。

アプリケーション仮想化の定義例

VMware ThinApp、Microsoft App-V、Citrix XenApp。

データ仮想化
データ仮想化の定義

さまざまなソースからのデータを物理的に統合することなく統合し、分析とレポートのための統一されたビューを提供します。

データ仮想化の定義の使用例

ビジネス インテリジェンス、リアルタイム データ統合。

データ仮想化の定義例

Denodo、Red Hat JBoss Data Virtualization、IBM InfoSphere。

仮想化のメリット
  • リソース効率: 物理リソースの利用効率が向上します。
  • コスト削減: ハードウェアおよび運用コストが削減されます。
  • スケーラビリティ: 需要に応じて簡単にスケールアップまたはスケールダウンできます。
  • 柔軟性: さまざまなワークロードとアプリケーションをサポートします。
  • ディザスタリカバリ: バックアップとリカバリのプロセスを簡素化します。
  • 分離: 環境の分離によりセキュリティが向上します。

(back to sub Topic 351.1)

(back to Topic 351)

(back to top)


351.2ゼン

xen-architecture

xen-architecture

**重さ:**3

**説明:**受験者は、Xen インストールのインストール、構成、保守、移行、およびトラブルシューティングができる必要があります。 Xen バージョン 4.x に焦点を当てています。

主要な知識領域:

  • ネットワークやストレージを含む Xen のアーキテクチャを理解する
  • Xen ノードとドメインの基本構成
  • Xen ノードとドメインの基本的な管理
  • Xen インストールの基本的なトラブルシューティング
  • 錠剤の強さ
  • XenStoreの認知度
  • Xen ブートパラメータの認識
  • xm ユーティリティの認識

ゼン

panda

Xen は、オープンソースのタイプ 1 (ベアメタル) ハイパーバイザーであり、複数のオペレーティング システムを同じ物理ハードウェア上で同時に実行できます。
Xen は、物理ハードウェアと仮想マシン (VM) の間にレイヤーを提供し、効率的なリソースの共有と分離を可能にします。

  • **建築:**Xen は 2 層システムで動作します。ドメイン 0 (Dom0) はハードウェアに直接アクセスできる特権ドメインであり、ハイパーバイザーを管理します。ドメイン U (DomU) と呼ばれる他の仮想マシンはゲスト オペレーティング システムを実行し、Dom0 によって管理されます。
  • **仮想化の種類:**Xen は、変更されたゲスト OS を必要とする準仮想化 (PV) と、ハードウェア拡張機能 (Intel VT-x や AMD-V など) を使用して未変更のゲスト OS を実行するハードウェア支援仮想化 (HVM) の両方をサポートします。 Xen は、クラウド環境、特にアマゾン ウェブ サービス (AWS) やその他の大規模クラウド プロバイダーで広く使用されています。

Xenソース

XenSource は、Xen を商用化するためにケンブリッジ大学の Xen ハイパーバイザーの最初の開発者によって設立された会社です。
同社は、Xen に基づいたエンタープライズ ソリューションを提供し、企業での使用向けに Xen の機能を強化するための追加のツールとサポートを提供しました。

  • シトリックスによる買収:2007 年、XenSource は Citrix Systems, Inc. に買収されました。Citrix は、Xen テクノロジーを Citrix XenServer 製品の基盤として使用し、Xen ベースのエンタープライズ グレードの仮想化プラットフォームとして人気を博しました。
  • 遷移:買収後、Xen プロジェクトはオープンソース プロジェクトとして継続されましたが、Citrix は XenSource テクノロジーを活用して XenServer などの商用製品に注力しました。

Xenプロジェクト

Xen プロジェクトとは、Xen ハイパーバイザーの商用化後の開発と保守を担当するオープンソース コミュニティおよびイニシアチブを指します。
Xen プロジェクトは Linux Foundation の下で運営されており、コミュニティ主導の共同作業として Xen の構築、改善、サポートに重点を置いています。

  • **目標:**Xen プロジェクトは、クラウド コンピューティング、セキュリティ重視の仮想化 (Qubes OS など)、組み込みシステムなど、幅広いユースケース向けにパフォーマンス、セキュリティ、機能セットを改善することでハイパーバイザーを進化させることを目指しています。
  • **寄稿者:**このプロジェクトには、大手クラウド プロバイダー、ハードウェア ベンダー、独立系開発者など、さまざまな組織からの貢献者が参加しています。
  • **錠剤とハンツール:**Xen プロジェクトには、Xen ハイパーバイザーのインストールの管理に使用される XAPI (XenAPI) などのツールや、システム管理と最適化のためのその他のさまざまなユーティリティも含まれています。

XenStore

Xen Store は、Xen Hypervisor の重要なコンポーネントです。
基本的に、Xen Store は、Xen ハイパーバイザーとそれが管理する仮想マシン (ドメインとも呼ばれます) の間の通信と情報共有に使用される分散キー/値データベースです。

Xen Store の重要な側面をいくつか紹介します。

  • **ドメイン間通信:**Xen Store を使用すると、Dom0 (ハードウェア リソースを制御する特権ドメイン) と DomU (VM であるユーザー ドメイン) などのドメイン間の通信が可能になります。これは、各ドメインが情報を読み書きできるキーと値のエントリを通じて行われます。

  • **構成管理:**これは、仮想デバイス、ネットワーク、ブート パラメーターなどの構成情報を保存し、アクセスするために使用されます。これにより、VM の動的な管理と構成が容易になります。

  • **イベントと通知:**Xen Store はイベント通知もサポートしています。 Xen ストア内の特定のキーまたは値が変更されると、関係するドメインにこれ​​らの変更に対応するように通知できます。これは、リソースの監視と管理に役立ちます。

  • シンプルな API: Xen Store は、データの読み取りと書き込みのためのシンプルな API を提供するため、開発者はアプリケーションを Xen 仮想化システムと簡単に統合できます。

ピル

XAPI (XenAPI) は、Xen Hypervisor とその仮想マシン (VM) を管理するために使用されるアプリケーション プログラミング インターフェイス (API) です。
XAPI は XenServer (現在は Citrix Hypervisor として知られています) の主要コンポーネントであり、Xen ハイパーバイザーと対話して VM の作成、構成、監視、制御などの操作を実行するための標準化された方法を提供します。

XAPI の重要な側面をいくつか示します。

  • **VM管理:**XAPI を使用すると、管理者はプログラムで仮想マシンを作成、削除、起動、停止できます。

  • **オートメーション:**XAPI を使用すると、大規模なクラウド環境にとって重要な、ネットワーク、ストレージ、コンピューティングなどの仮想リソースの管理を自動化できます。

  • **統合:**XAPI は他のツールやスクリプトと統合して、Xen 環境のより効率的なカスタマイズされた管理を提供できます。

  • **アクセス制御:**XAPI は、許可されたユーザーのみが仮想環境で特定の操作を実行できるようにするアクセス制御メカニズムも提供します。

XAPI は、Xen Hypervisor の制御と自動化を可能にし、仮想化環境の管理を容易にするインターフェイスです。

Xenの概要

  • **ゼン:**仮想マシンを物理ハードウェア上で実行できるようにするコア ハイパーバイザー テクノロジ。
  • **Xenソース:**Xen を商用化した企業で、後に Citrix に買収され、Citrix XenServer の開発につながりました。
  • **Xen プロジェクト:**Linux Foundation の下で Xen ハイパーバイザーの開発と保守を継続するオープンソース イニシアチブおよびコミュニティ。
  • **Xenストア:**Xen Store は、Xen ハイパーバイザーと VM の間の通信と構成の仲介者として機能し、仮想化環境の運用と管理を合理化します。
  • ピルは、Xen Hypervisor の制御と自動化を可能にし、仮想化環境の管理を容易にするインターフェイスです。

ドメイン0 (Dom0)

Domain0 (Dom0) は、Xen アーキテクチャの制御ドメインです。他のドメイン (DomU) を管理し、ハードウェアに直接アクセスします。
Dom0 はデバイス ドライバーを実行し、ハードウェアに直接アクセスできない DomU がデバイスと通信できるようにします。通常、これは Linux などのオペレーティング システムの完全なインスタンスであり、Xen ハイパーバイザーの動作に不可欠です。

ドメインU (DomU)

DomU は、仮想マシンを実行する非特権ドメインです。
これらは Dom0 によって管理され、ハードウェアに直接アクセスすることはできません。 DomU は、さまざまなオペレーティング システムを実行するように構成でき、アプリケーション サーバーや開発環境などのさまざまな目的に使用されます。ハードウェアの対話には Dom0 に依存します。

PV-DOMU (超正規化ドメイン)

PV-DomU は準仮想化と呼ばれる技術を使用します。このモデルでは、DomU オペレーティング システムが仮想化環境で実行されることを認識するように変更され、ハイパーバイザーと直接通信してパフォーマンスを最適化できるようになります。
これにより、完全な仮想化と比較してオーバーヘッドが低減され、効率が向上します。

HVM-DomU (ハードウェア仮想マシン ドメイン U)

HVM-DomU は完全仮想化を利用した仮想マシンであり、変更されていないオペレーティング システムを実行できます。 Xen ハイパーバイザーは、これらの DomU にハードウェア エミュレーションを提供し、基礎となるハードウェア アーキテクチャをサポートする任意のオペレーティング システムを DomU で実行できるようにします。
これにより柔軟性が向上しますが、PV-DomU と比較してオーバーヘッドが高くなる可能性があります。

Xenネットワーク

準仮想化ネットワークデバイスpv-networking

ブリッジングpv-networking

351.2 引用オブジェクト

Domain0 (Dom0), DomainU (DomU)
PV-DomU, HVM-DomU
/etc/xen/
xl
xl.cfg 
xl.conf # Xen global configurations
xentop
oxenstored # Xenstore configurations

351.2 注記

# Xen Settings
/etc/xen/
/etc/xen/xl.conf - Main general configuration file for Xen
/etc/xen/oxenstored.conf - Xenstore configurations

# VM Configurations
/etc/xen/xlexample.pvlinux
/etc/xen/xlexample.hvm

# Service Configurations
/etc/default/xen
/etc/default/xendomains

# xen-tools configurations
/etc/xen-tools/
/usr/share/xen-tools/

351.2 重要なコマンド

xen-create-image
# create a pv image
xen-create-image \
  --hostname=lpic3-pv-guest \
  --memory=1gb \
  --vcpus=2 \
  --lvm=vg_xen \
  --dhcp \
  --pygrub \
  --dist=bookworm
xen-削除-イメージ
# delete a pv image
xen-delete-image lpic3-pv-guest --lvm=vg_xen
brctl
# list xen interfaces
brctl show
XL
# view xen information
xl infos

# list Domains
xl list

# view dmesg information
xl dmesg

# monitoring domain
xl top
xentop
xen top

# Limit mem Dom0
xl mem-set 0 2048

# Limite cpu (not permanent after boot)
xl vcpu-set 0 2

# manual conf
man xl.conf

# manual cfg - about guest configuration
man xl.cfg

# create DomainU - virtual machines
xl create /etc/xen/lpic3-pv-guest.cfg

# create DomainU virtual machine and connect to guest
xl create -c /etc/xen/lpic3-pv-guest.cfg

# connect in domain guest
xl console <id>|<name> (press enter)
xl console 1
xl console lpic3-pv-guest

#How do I exit domU "xl console" session
#Press ctrl+] or if you're using Putty press ctrl+5.

# Poweroff domain
xl shutdown lpic3-pv-guest

# destroy domain
xl destroy lpic3-pv-guest

# reboot domain
xl reboot lpic3-pv-guest

(back to sub Topic 351.2)

(back to Topic 351)

(back to top)


351.3QEMU

**重さ:**4

**説明:**受験者は、QEMU インストールのインストール、構成、保守、移行、およびトラブルシューティングを行うことができる必要があります。

主要な知識領域:

  • KVM、ネットワーキング、ストレージなどの QEMU のアーキテクチャを理解する
  • コマンドラインからQEMUインスタンスを起動する
  • QEMU モニターを使用してスナップショットを管理する
  • QEMU ゲスト エージェントと VirtIO デバイス ドライバーをインストールする
  • ネットワークやストレージを含む QEMU インストールのトラブルシューティング
  • 重要な QEMU 構成パラメータの認識

351.3 引用オブジェクト

Kernel modules: kvm, kvm-intel and kvm-amd
/dev/kvm
QEMU monitor
qemu
qemu-system-x86_64
ip
brctl
tunctl

351.3 重要なコマンド

ip
# list links
ip link show

(back to sub Topic 351.3)

(back to Topic 351)

(back to top)


351.4 Libvirt仮想マシン管理

**重さ:**9

**説明:**受験者は、libvirt および関連ツールを使用して仮想化ホストと仮想マシン (「libvirt ドメイン」) を管理できる必要があります。

主要な知識領域:

  • libvirt のアーキテクチャを理解する
  • libvirt 接続とノードを管理する
  • QEMU および Xen ドメイン (スナップショットを含む) を作成および管理する
  • ドメインのリソース消費を管理および分析する
  • ストレージプールとボリュームの作成と管理
  • 仮想ネットワークの作成と管理
  • ノード間でドメインを移行する
  • libvirt が Xen および QEMU とどのように対話するかを理解する
  • libvirt が dnsmasq や radvd などのネットワーク サービスとどのように対話するかを理解する
  • libvirt XML 構成ファイルを理解する
  • virtlogd と virtlockd の認識

351.4 引用オブジェクト

libvirtd
/etc/libvirt/
virsh (including relevant subcommands)

351.4 重要なコマンド

ふー
foo

(back to sub Topic 351.4)

(back to Topic 351)

(back to top)


351.5 仮想マシンのディスクイメージの管理

**重さ:**3

**説明:**受験者は、仮想マシンのディスク イメージを管理できる必要があります。これには、さまざまな形式とハイパーバイザー間でのディスク イメージの変換や、イメージ内に保存されているデータへのアクセスが含まれます。

主要な知識領域:

  • Raw イメージ、qcow2、VMDK などのさまざまな仮想ディスク イメージ形式の機能を理解する
  • qemu-img を使用して仮想マシンのディスク イメージを管理する
  • libguestfish を使用してパーティションをマウントし、仮想マシンのディスク イメージに含まれるファイルにアクセスする
  • 物理ディスクの内容を仮想マシンのディスクイメージにコピーする
  • さまざまな仮想マシンのディスク イメージ形式間でディスク コンテンツを移行する
  • オープン仮想化フォーマット (OVF) の認識

351.5 引用オブジェクト

qemu-img
guestfish (including relevant subcommands)
guestmount
guestumount
virt-cat
virt-copy-in
virt-copy-out
virt-diff
virt-inspector
virt-filesystems
virt-rescue
virt-df
virt-resize
virt-sparsify
virt-p2v
virt-p2v-make-disk
virt-v2v
virt-sysprep

351.5 重要なコマンド

ふー
foo

(back to sub Topic 351.5)

(back to Topic 351)

(back to top)


トピック 352: コンテナの仮想化


352.1 コンテナ仮想化の概念

**重さ:**7

**説明:**受験者はコンテナ仮想化の概念を理解している必要があります。これには、コンテナ仮想化の実装に使用される Linux コンポーネントの理解と、これらのコンポーネントのトラブルシューティングのための標準 Linux ツールの使用が含まれます。

主要な知識領域:

  • システムとアプリケーションコンテナの概念を理解する
  • カーネル名前空間を理解して分析する
  • コントロールグループの理解と分析
  • 能力の理解と分析
  • コンテナ仮想化における seccomp、SELinux、AppArmor の役割を理解する
  • LXC と Docker が名前空間、cgroup、機能、seccomp、MAC をどのように活用するかを理解する
  • runcの原理を理解する
  • CRI-Oとcontainerdの原理を理解する
  • OCI ランタイムとイメージ仕様の認識
  • Kubernetes Container Runtime Interface (CRI) の認識
  • ポッドマン、ビルダ、スコープの認識
  • Linux およびその他の無料オペレーティング システム (rkt、OpenVZ、systemd-nspawn、BSD Jails など) における他のコンテナ仮想化アプローチの認識
timeline
    title Time Line Containers Evolution
    1979 : chroot
    2000 : FreeBSD Jails
    2004 : Solaris Containers
    2006 : cgroups
    2008 : LXC
    2013 : Docker
    2014 : Kubernetes
Loading

352.1 引用オブジェクト

nsenter
unshare
ip (including relevant subcommands)
capsh
/sys/fs/cgroups
/proc/[0-9]+/ns
/proc/[0-9]+/status

352.1 重要なコマンド

ふー
foo

(back to sub topic 352.1)

(back to topic 352)

(back to top)


352.2LXC

**重さ:**6

**説明:**受験者は、LXC および LXD を使用してシステム コンテナを使用できる必要があります。対象となる LXC のバージョンは 3.0 以降です。

主要な知識領域:

  • LXC と LXD のアーキテクチャを理解する
  • LXD を使用して既存のイメージに基づいて LXC コンテナー (ネットワーキングやストレージを含む) を管理する
  • LXCコンテナのプロパティを構成する
  • LXC コンテナーのリソース使用量を制限する
  • LXDプロファイルを使用する
  • LXC イメージを理解する
  • 従来の LXC ツールの認識

352.2 引用オブジェクト

lxd
lxc (including relevant subcommands)

352.2 重要なコマンド

ふー
foo

(back to sub topic 352.2)

(back to topic 352)

(back to top)


352.3 ドッカー

**重さ:**9

**説明:**受験者は、Docker ノードと Docker コンテナを管理できる必要があります。これには、Docker のアーキテクチャを理解するだけでなく、Docker がノードの Linux システムとどのように対話するかを理解することが含まれます。

主要な知識領域:

  • Docker のアーキテクチャとコンポーネントを理解する
  • Docker レジストリのイメージを使用して Docker コンテナを管理する
  • Dockerコンテナのイメージとボリュームを理解して管理する
  • Dockerコンテナのログを理解して管理する
  • Docker のネットワークを理解して管理する
  • Dockerfile を使用してコンテナー イメージを作成する
  • レジストリ Docker イメージを使用して Docker レジストリを実行する

352.3 引用オブジェクト

dockerd
/etc/docker/daemon.json
/var/lib/docker/
docker
Dockerfile

352.3 重要なコマンド

港湾労働者
# Examples of docker

(back to sub topic 352.3)

(back to topic 352)

(back to top)


352.4 コンテナ オーケストレーション プラットフォーム

**重さ:**3

**説明:**受験者は、コンテナ オーケストレーションの重要性と、コンテナ オーケストレーションを実装するために Docker Swarm と Kubernetes が提供する重要な概念を理解する必要があります。

主要な知識領域:

  • コンテナオーケストレーションの関連性を理解する
  • Docker Compose と Docker Swarm の主要な概念を理解する
  • Kubernetes と Helm の主要な概念を理解する
  • OpenShift、Rancher、Mesosphere DC/OS の認識

(back to sub topic 352.4)

(back to topic 352)

(back to top)


トピック 353: VM の展開とプロビジョニング


353.1 クラウド管理ツール

**重さ:**2

**説明:**受験者は、パブリック クラウドの一般的なサービスを理解し、一般的に利用可能なクラウド管理ツールの基本的な機能知識を持っている必要があります。

主要な知識領域:

  • パブリック クラウドの一般的なサービスを理解する
  • OpenStack の基本的な機能の知識
  • Terraform の基本的な機能の知識
  • CloudStack、Eucalyptus、OpenNebula の認識

353.1 引用オブジェクト

IaaS, PaaS, SaaS
OpenStack
Terraform

353.1 重要なコマンド

ふー
# examples

(back to sub topic 353.1)

(back to topic 353)

(back to top)


353.2 パッカー

**重さ:**2

**説明:**受験者は、Packer を使用してシステム イメージを作成できる必要があります。これには、さまざまなパブリックおよびプライベート クラウド環境での Packer の実行や、LXC/LXD 用のコンテナ イメージの構築が含まれます。

主要な知識領域:

  • Packer の機能と特徴を理解する
  • テンプレート ファイルの作成と保守
  • さまざまなビルダーを使用してテンプレート ファイルからイメージを構築する

353.2 引用オブジェクト

packer

353.2 重要なコマンド

パッカー
# examples

(back to sub topic 353.2)

(back to topic 353)

(back to top)


353.3 クラウド初期化

**重さ:**3

**説明:**受験者は、cloud-init を使用して、標準化されたイメージから作成された仮想マシンを構成できる必要があります。これには、利用可能なハードウェア リソース、特にディスク領域とボリュームに合わせて仮想マシンを調整することが含まれます。
さらに、受験者は安全な SSH ログインを許可し、特定のソフトウェア パッケージのセットをインストールできるようにインスタンスを構成できる必要があります。
さらに、受験者は、cloud-init サポートを備えた新しいシステム イメージを作成できる必要があります。

主要な知識領域:

  • ユーザーデータ、cloud-init の初期化と構成など、cloud-init の機能と概念を理解する
  • Cloud-init を使用して、ファイル システムの作成、サイズ変更、マウントを行い、SSH キーなどのログイン認証情報を含むユーザー アカウントを構成し、ディストリビューションのリポジトリからソフトウェア パッケージをインストールします。
  • Cloud-init をシステム イメージに統合する
  • テストには構成ドライブ データソースを使用する

353.3 引用オブジェクト

cloud-init
user-data
/var/lib/cloud/

353.3 重要なコマンド

ふー
# examples

(back to sub topic 353.3)

(back to topic 353)

(back to top)


353.4 浮浪者

**重さ:**3

**説明:**受験者は、仮想マシンのプロビジョニングなど、Vagrant を使用して仮想マシンを管理できる必要があります。

主要な知識領域:

  • ストレージやネットワークなど、Vagrant のアーキテクチャと概念を理解する
  • アトラスからボックスを取得して使用する
  • Vagrantfile を作成して実行する
  • Vagrant 仮想マシンにアクセスする
  • Vagrant 仮想マシンとホスト システム間でフォルダーを共有および同期する
  • Vagrant プロビジョニング、つまりファイル プロビジョナーとシェル プロビジョナーを理解する
  • マルチマシンのセットアップを理解する

353.4 引用オブジェクト

vagrant
Vagrantfile

353.4 重要なコマンド

浮浪者
# examples

(back to sub topic 353.4)

(back to topic 353)

(back to top)


貢献する

オープンソース コミュニティを素晴らしい場所にするのは、コントリビューションのおかげです。 学び、インスピレーションを与え、創造します。あなたが行う貢献はすべて、とても感謝しています.

これを改善する提案がある場合は、リポジトリをフォークしてください。 プルリクエストを作成します。 「拡張」タグを付けて問題を開くこともできます。 プロジェクトにスターを付けることを忘れないでください。再度、感謝します!

  1. プロジェクトをフォークする
  2. 機能ブランチを作成します (git checkout -b feature/AmazingFeature)
  3. 変更をコミットします (git commit -m 'Add some AmazingFeature')
  4. ブランチにプッシュ (git push origin feature/AmazingFeature)
  5. プルリクエストを開く

ライセンス

  • このプロジェクトは MIT ライセンスに基づいてライセンスされています * 詳細については LICENSE.md ファイルを参照してください

接触

マルコス・シルヴェストリーニ -[email protected]\Twitter

プロジェクトリンク:https://github.com/marcossilvestrini/learning-lpic-3-305-300

(back to top)


謝辞

(back to top)