Galileo Computing < openbook > Galileo Computing - Professionelle Bücher. Auch für Einsteiger.
Professionelle Bücher. Auch für Einsteiger.

Inhaltsverzeichnis
Vorwort
1 Einleitung
2 Die Installation
3 Erste Schritte
4 Linux als Workstation für Einsteiger
5 Der Kernel
6 Die Grundlagen aus Anwendersicht
7 Die Shell
8 Reguläre Ausdrücke
9 Konsolentools
10 Die Editoren
11 Shellskriptprogrammierung mit der bash
12 Die C-Shell
13 Benutzerverwaltung
14 Grundlegende Verwaltungsaufgaben
15 Netzwerkgrundlagen
16 Anwendersoftware für das Netzwerk
17 Netzwerkdienste
18 Mailserver unter Linux
19 LAMP
20 DNS-Server
21 Secure Shell
22 Die grafische Oberfläche
23 Window-Manager und Desktops
24 X11-Programme
25 Multimedia und Spiele
26 Prozesse und IPC
27 Bootstrap und Shutdown
28 Dateisysteme
29 Virtualisierung und Emulatoren
30 Softwareentwicklung
31 Crashkurs in C und Perl
32 Einführung in die Sicherheit
33 Netzwerksicherheit überwachen
A Lösungen zu den einzelnen Aufgaben
B Kommandoreferenz
C X11-InputDevices
D MBR
E Die Buch-DVDs
F Glossar
G Literatur
Stichwort

Download:
- ZIP, ca. 15,7 MB
Buch bestellen
Ihre Meinung?

Spacer
 <<   zurück
Linux von Johannes Pl&ouml;tner, Steffen Wendzel
Das umfassende Handbuch
Buch: Linux

Linux
geb., mit 2 DVDs
1302 S., 39,90 Euro
Galileo Computing
ISBN 978-3-8362-1704-0
Pfeil 29 Virtualisierung und Emulatoren
  Pfeil 29.1 Einführung
    Pfeil 29.1.1 Betriebssystem-Virtualisierung
    Pfeil 29.1.2 Emulation
  Pfeil 29.2 Wine, Cedega und Crossover
    Pfeil 29.2.1 Cedega
    Pfeil 29.2.2 Crossover
    Pfeil 29.2.3 Wine
  Pfeil 29.3 ScummVM
    Pfeil 29.3.1 Klassiker und Open-Source-Spiele
    Pfeil 29.3.2 Spiele installieren
  Pfeil 29.4 Oldie-Emulatoren und Nostalgie
    Pfeil 29.4.1 DOSBox
    Pfeil 29.4.2 UAE
    Pfeil 29.4.3 Weitere Emulatoren
  Pfeil 29.5 Hardware-Virtualisierung mit Xen
    Pfeil 29.5.1 Die Xen-Architektur
    Pfeil 29.5.2 Die Administration via xm
  Pfeil 29.6 Hardware-Virtualisierung mit KVM
    Pfeil 29.6.1 Die KVM-Architektur
    Pfeil 29.6.2 Die Administration via Qemu
    Pfeil 29.6.3 KVM vs. Xen
    Pfeil 29.6.4 Weitere Lösungen
  Pfeil 29.7 Zusammenfassung
  Pfeil 29.8 Aufgaben


Galileo Computing - Zum Seitenanfang

29.6 Hardware-Virtualisierung mit KVM  Zur nächsten ÜberschriftZur vorigen Überschrift

Die Kernel Virtual Machine – kurz: KVM (linux-kvm.org) – ist als Virtualisierungstechnologie eine ernsthafte Konkurrenz zu Xen. KVM ist eine Erweiterung des Linux-Kernels, sodass dieser eine Hardware-beschleunigte Virtualisierung von Gastbetriebssystemen ermöglicht.


Galileo Computing - Zum Seitenanfang

29.6.1 Die KVM-Architektur  Zur nächsten ÜberschriftZur vorigen Überschrift

Im Gegensatz zu Xen, das einen eigenständigen Hypervisor nutzt, agiert bei KVM der Linux-Kernel nach dem Laden bestimmter Kernelmodule selbst als Hypervisor. Zwingende Voraussetzung dafür ist eine entsprechend aktuelle CPU mit Intel VT (Vanderpool) oder AMD-V (Pacifica) als Erweiterungen des CPU-Befehlssatzes. Diese Befehlssatz-Erweiterungen ermöglichen es erst, dass mehrere Betriebssysteme parallel auf einer CPU ausgeführt und damit Gastbetriebssysteme ohne größeren Geschwindigkeitsverlust virtualisiert werden können.

Um Herauszufinden, ob Ihr Prozessor diese Erweiterung unterstützt, können Sie in der /proc/cpuinfo bei den Prozessflags nach vmx für Intel-VT oder svm für AMD-V suchen:

$ cat /proc/cpuinfo
[...]
flags    : fpu vme de pse tsc msr pae mce cx8 apic mtrr pge mca
cmov pat pse36 clflush dts acpi mmx fxsr sse sse2 ss
ht tm pbe lm constant_tsc arch_perfmon pebs bts
aperfmperf pni dtes64 monitor ds_cpl vmx est tm2
ssse3 cx16 xtpr pdcm lahf_lm tpr_shadow
[...]

Listing 29.9  Intel-CPU mit vmx-Flag

Um KVM zu aktivieren, müssen Sie zwei Kernelmodule laden: kvm.ko und – je nach Prozessortyp – kvm-intel.ko beziehungsweise kvm-amd.ko.

# modprobe kvm
# modprobe kvm-intel

Listing 29.10  KVM aktivieren


Sollte sich kvm-intel beziehungsweise kvm-amd nicht laden lassen, kann es gut sein, dass Sie diese Erweiterung erst im BIOS Ihres Computers aktivieren müssen. Bei älteren Modellen – wie dem Laptop, auf dem dieses Kapitel entstand – kann dazu gegebenenfalls sogar ein BIOS-Update notwendig sein. Konsultieren Sie dazu bitte die Webseite Ihres Herstellers. Weiterhin können Sie weitere Hilfe und gute Tipps in der KVM-FAQ auf www.linux-kvm.org/page/FAQ finden.


Die KVM-Erweiterung stellt selbst nur die HVM-Infrastruktur beziehungsweise die Virtualisierungs-Schnittstellen bereit. Um die Hardware-Virtualisierung im Linux-Kernel auch konkret nutzen zu können, müssen Sie ein modifiziertes Qemu benutzen.


Galileo Computing - Zum Seitenanfang

29.6.2 Die Administration via Qemu  Zur nächsten ÜberschriftZur vorigen Überschrift

Das ursprüngliche Qemu ist ein reiner Emulator, der als Programm im Userspace läuft und es über die Emulierung einer kompletten PC-Hardware inklusive BIOS etc. ermöglicht, komplette Betriebssysteme innerhalb eines normalen Linux-Systems auszuführen. Woher der Name Qemu stammt, weiß man nicht – in den FAQ der Software geben die Entwickler diese Frage als »unanswered« an.

Viele Architekturen

Erwähnenswert ist, dass der Qemu-Emulator sehr viele CPU-Architekturen unterstützt. Sie können damit im Prinzip auf jedem Intel-Rechner auch Solaris für Sparc-Prozessoren installieren. Derzeit werden x86, x86_64, ARM, Sparc, Sparc64, PowerPC und MIPS gut unterstützt. Den aktuellen Entwicklungsstand der Architekturunterstützung können Sie jederzeit auf der Qemu-Webseite (qemu.org) unter Status nachlesen.

In Verbindung mit KVM wird aus Qemu schließlich eine echte Virtualisierungslösung. Dank der durch KVM nutzbaren Befehlssatzerweiterungen der Intel- bzw. AMD-Prozessoren kann dabei im Vergleich zur einfachen Emulation ein spürbarer Geschwindigkeitsvorteil in der Ausführung von Gastbetriebssystemen erreicht werden. KVM unterstützt dabei nahezu alle Linux-Distributionen, Solaris, diverse BSD-Derivate sowie Windows als Gastsystem auf Ihrem Linux-Rechner – jedoch können im Gegensatz zur echten Emulation nur x86-basierte Gastbetriebssysteme virtualisiert werden. [Schließlich wird der virtuellen Maschine kein Prozessor »vorgespielt« oder »emuliert«, sondern es wird auf den tatsächlich physikalisch vorhandenen Prozessor zugegriffen. An diesem Beispiel wird der Unterschied zwischen Emulation und Virtualisierung noch einmal besonders deutlich.]

Qemu benutzen

Die Konfiguration beziehungsweise das Ausführen einer virtuellen Maschine geht erfreulich einfach vonstatten und besteht mehr oder minder nur daraus, dem Qemu entsprechende Aufrufparameter mit auf den Weg zu geben.

Netzwerk- unterstützung

Zudem verfügt Qemu über eine hervorragende Netzwerkunterstützung. Das Betriebssystem in der Qemu Virtual Machine kann, wie jeder andere Rechner im Netzwerk, beispielsweise den DHCP-Server im LAN zur Konfiguration der Netzwerkkarte verwenden.

Virtuelle Platte

Zunächst erstellt man eine virtuelle Festplatte. Eine solche Festplatte wird im echten Dateisystem durch eine einzige Datei dargestellt. Innerhalb der virtuellen Maschine wird diese Datei durch die Software allerdings als »echte« Festplatte dargestellt.

Das Festplatten-Image wird durch das Programm qemu-img erstellt. Wir erstellen eine 1 GByte große Festplatte mit dem Dateinamen hl.img. Die Größe wird dabei in der Form »nM« für n Megabyte bzw. »nG« für n Gigabyte angegeben.

# qemu-img create hl.img 1G
Formating 'hl.img', fmt=raw, size=1048576 kB

Listing 29.11  Festplatte erstellen

Installation starten

Nun werden wir eine Installation der »Hardened Linux«-Distribution innerhalb von Qemu vornehmen (mittlerweile gibt es diese Distribution nicht mehr, doch das ist hier nicht von Belang, da die Vorgehensweise auch für alle anderen Distributionen gleich ist). Zur Installation benutzen wir eine ISO-Datei; Qemu kann diese direkt verwenden und benötigt keine physikalisch vorhandenen CD-ROMs/DVDs.

$ qemu -hda hl.img -cdrom hardenedlinux-1.6.2.iso -boot d -m 80

Listing 29.12  Die Installation von Hardened Linux starten

Mit -hda wird dabei die erste Festplatte, mit -hdb eine eventuelle zweite angegeben. Unser ISO-Image wird als CD-ROM-Laufwerk verwendet. Gebootet werden soll von der CD-ROM (-boot d). Des Weiteren soll der virtuelle Rechner über 80 MByte RAM verfügen (-m 80).

System booten

Gebootet wird das System fast genauso wie bei der Installation. Der Unterschied besteht jedoch darin, dass wir diesmal nicht von der CD-ROM, sondern von der Festplatte booten (Parameter -boot c).

Abbildung 29.10  Qemu mit Hardened Linux und den HL Hardening Scripts

Von nun an kann man mit dem System arbeiten, als ob es ganz allein auf dem jeweiligen Rechner installiert wäre.


Galileo Computing - Zum Seitenanfang

29.6.3 KVM vs. Xen  Zur nächsten ÜberschriftZur vorigen Überschrift

KVM ist – im Gegensatz zu Xen – aktuell bereits regulärer Bestandteil des Linux-Kernels. Für Xen gab und gibt es immer wieder Pläne einer Integration, aber aktuell gibt es offizielle Xen-Patches nur für Kernel 2.6.18 (Xen 3) beziehungsweise Kernel 2.6.31 (Xen 4). In der Vergangenheit haben einige Distributoren die Xen Patches regelmäßig an die aktuellen Kernelversionen angepasst und diese auch als Standardpakete mit ausgeliefert, jedoch hat zum Beispiel Red Hat Enterprise Linux den Schwenk von Xen auf KVM vollzogen und liefert seit REHL 6.0 auch nur noch KVM aus und biete keine Xen-Unterstützung mehr.

Eigentlich wird Xen allgemein als die ausgereiftere und stabilere Lösung mit den besseren Managementfrontends bezeichnet, allerdings sehen manche auch aufgrund dieser Entwicklung die Zukunft von Xen fraglich. Mit der Zeit wird sich zeigen, welcher Hypervisor sich durchsetzen wird.


Galileo Computing - Zum Seitenanfang

29.6.4 Weitere Lösungen  topZur vorigen Überschrift

Neben KVM/Qemu und Xen gibt es noch weitere Virtualisierungssoftware für Linux. Bei VMWare handelt es sich um eine ebenfalls sehr einfach zu bedienende, allerdings bis auf den VMWare Player kommerzielle Software. Mit VirtualBox hingegen gibt es noch eine weitere halbfreie, auf Qemu basierende Software. Die Basisversion von VirtualBox kann als GPL-lizenzierte Version aus dem Internet heruntergeladen werden, die kommerzielle Version bietet allerdings noch einige zusätzliche Features, wie die vollständige Unterstützung des Remote Desktop Protocols (RDP), virtuelle USB-Geräte sowie Shared Folders zwischen Gast- und Hostsystem.



Ihr Kommentar

Wie hat Ihnen das <openbook> gefallen? Wir freuen uns immer über Ihre freundlichen und kritischen Rückmeldungen.






 <<   zurück
  Zum Katalog
Zum Katalog: Linux, Ausgabe 2011






Linux, Ausgabe 2011
Jetzt bestellen


 Ihre Meinung?
Wie hat Ihnen das <openbook> gefallen?
Ihre Meinung

 Buchempfehlungen
Zum Katalog: Linux-Server






 Linux-Server


Zum Katalog: Linux Hochverfügbarkeit






 Linux Hoch-
 verfügbarkeit


Zum Katalog: LPIC-1






 LPIC-1


Zum Katalog: Debian GNU/Linux






 Debian GNU/Linux


Zum Katalog: openSUSE 11.2






 openSUSE 11.2


Zum Katalog: Shell-Programmierung






 Shell-Programmierung


Zum Katalog: Ubuntu GNU/Linux






 Ubuntu GNU/Linux


 Shopping
Versandkostenfrei bestellen in Deutschland und Österreich
InfoInfo




Copyright © Galileo Press 2011
Für Ihren privaten Gebrauch dürfen Sie die Online-Version natürlich ausdrucken. Ansonsten unterliegt das <openbook> denselben Bestimmungen, wie die gebundene Ausgabe: Das Werk einschließlich aller seiner Teile ist urheberrechtlich geschützt. Alle Rechte vorbehalten einschließlich der Vervielfältigung, Übersetzung, Mikroverfilmung sowie Einspeicherung und Verarbeitung in elektronischen Systemen.


[Galileo Computing]

Galileo Press, Rheinwerkallee 4, 53227 Bonn, Tel.: 0228.42150.0, Fax 0228.42150.77, info@galileo-press.de