Erinevus lehekülje "Xen kasutamine Debian Etchiga" redaktsioonide vahel
(→Full virtualization) |
|||
216. rida: | 216. rida: | ||
/etc/udev/rules.d/z25_persistent-net.rules | /etc/udev/rules.d/z25_persistent-net.rules | ||
− | + | Katse näitab, samuti asjakohaste arhiivide lugemine, et 64bit dom0 all saab edukalt kasutada 32bit domU keskkondi, kusjuures domU tuumaks on 64bit dom0 tuuma. Ilmselt rakenduvad seejuures samasugused asjaolud nagu ilma Xenita 64bit tuuma ja 32 bit userspace'i kasutamisel. | |
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
===Debian Etch paketihalduse xen-tuuma kasutamine=== | ===Debian Etch paketihalduse xen-tuuma kasutamine=== | ||
268. rida: | 260. rida: | ||
[[Pilt:Xen-hvm-console.gif]] | [[Pilt:Xen-hvm-console.gif]] | ||
+ | |||
+ | ===Lingid=== | ||
+ | |||
+ | Xen http://www.xensource.com/ | ||
+ | |||
+ | NetBSD xen http://www.s-mackie.demon.co.uk/unix-notes/NetBSD-Xen-Setup.html | ||
+ | |||
+ | Xen knoppix http://unit.aist.go.jp/itri/knoppix/xen/index-en.html | ||
+ | |||
+ | Gentoo Xen http://gentoo-wiki.com/HOWTO_Xen_and_Gentoo |
Redaktsioon: 14. juuni 2007, kell 23:16
Sisukord
- 1 Sissejuhatus
- 2 Xen tarkvara paigaldamine
- 3 Privilegeeritud domeeni dom0 tuum
- 4 Grubi seadistamine
- 5 Guest domeeni seadistamine
- 6 Guest domeeni domU tuum
- 7 Xen domU moodustamine
- 8 domU käivitamine
- 9 Võrgu kasutamine domU seest
- 10 Probleemid
- 11 Debian Etch paketihalduse xen-tuuma kasutamine
- 12 Full virtualization
- 13 Lingid
Sissejuhatus
Xen võimaldab ühel füüsilisel arvutil kasutada mitmeid samaaegselt töötavaid operatsioonisüsteeme. Reeglina töötab selliselt käivitatud arvutil üks põhiline operatsioonisüsteem (Host), mis kontrollib teiste (Guest) operatsioonisüsteemide tegevust. Üldiselt eristatakse nelja tüüpi virtualiseerimise tehnikaid:
Riistvara emuleerimine - QEMU Full virtualization - vmware (saab kasutada modifitseerimata Guest operatsioonisüsteeme) Paravirtualization - Xen (saab kasutada vaid modifitseeritud Guest operatsioonisüsteeme) Operating System level virtualization - UML (Guest operatsioonisüsteem töötab protsessina)
Modifitseerimine tähendab Xeni puhul seda, et Guest operatsioonisüsteem kasutab vastavalt paigatud tuuma.
Xeni puhul kasutatakse kõnealuselt käivitatud arvutis kahte tuuma
Host operatsioonisüsteem ehk privilegeeritud domeen ehk dom0 Guest operatsioonisüsteem ehk privilegeerimata domeen ehk domU
Xen tarkvara paigaldamine
Debian Etch puhul tuleb paigaldada paketid
libc6-xen xen-docs-3.0 xen-hypervisor-3.0.3-1-i386 xen-tools xen-utils-3.0.3-1 xen-utils-common
Lisaks on tuumade kompileerimiseks vajalik kopeerida www.xensource.com veebikohast Xen lähtetekstid ning paigaldada
iproute bridge-utils python-twisted gcc-3.3 binutils make zlib1g-dev python-dev transfig bzip2 screen debootstrap libcurl3-dev libncurses5-dev x-dev
Privilegeeritud domeeni dom0 tuum
Lahtipakitud Xeni lähtetekstid kataloogis tuleb öelda
bash# make linux-2.6-xen0-config CONFIGMODE=menuconfig KERNELS="linux-2.6-xen0" .. võib lisaks valida meelepäraseid seadeid bash# make linux-2.6-xen0-build bash# make linux-2.6-xen0-install
Tulemusena on paigaldatud arvutisse uus tuum, peale bootloaderi seadistuste ülevaatamist tuleb arvuti xen0 domeeni tuumaga rebootida. Seejärel näeb Xen teateid käsuga
xm dmesg
Grubi seadistamine
Esmalt laaditakse Xeni hüperviisor ja seejärel privilegeeritud domeeni (dom0) Linuxi tuum
default 0 timeout 15 color cyan/blue white/blue title xen root (hd0,1) kernel /boot/xen-3.0.3-1-i386.gz dom0_mem=384000 module /boot/vmlinuz-2.6.16.29-xen0 root=/dev/hda2 ro max_loop=255 savedefault boot
Tuleb tähele panna, et privilegeerimata domeeni tuum paikneb väljaspoole privilegeerimata domeeni failisüsteemi ning see asjaolu on iseloomulik paravirtualiseerimisele.
Guest domeeni seadistamine
Guest domeene võib olla üks või mitu, iga domeeniga on seotud
- guest domeeni tuum (mitu guest domeeni võivad kasutada ühte ja sama domU tuuma)
- guest failisüsteemi immidz
- Xeni guest domeeni seadistusfail
Kusjuures oluline on tähele panna, et Guest operatsioonisüsteemi tuum paikneb tema immidzast väljaspool.
Guest domeeni domU tuum
Lahtipakitud Xeni lähtetekstid kataloogis tuleb öelda
bash# make linux-2.6-xenU-config CONFIGMODE=menuconfig KERNELS="linux-2.6-xenU" .. võib lisaks valida meelepäraseid seadeid bash# make linux-2.6-xenU-build bash# make linux-2.6-xenU-install
Tulemusena on paigaldatud arvutisse xenU domeeni tuuma, mida kasutatakse guest domeenide bootimiseks.
Xen domU moodustamine
Debian Etch sisaldab paketti xen-tools, mis hõlbustab Guest domeenide immidza tekitamist. Koostage nt selline seadistusfail /etc/xen-tools/xen-tools.conf
dir = /mnt/xen debootstrap = 1 size = 4Gb # Disk image size. memory = 512Mb # Memory size swap = 1024Mb # Swap size fs = ext3 # use the EXT3 filesystem for the disk image. dist = sarge # Default distribution to install. image = sparse # Specify sparse vs. full disk images. passwd = 1 kernel = /boot/vmlinuz-2.6.16.29-xenU mirror = http://ftp.aso.ee/debian/
ning öelge
bash# xen-create-image --hostname=xen-sarge.auul --ip=172.16.92.2 \ --gateway=172.16.92.128 --netmask=255.255.255.0
Tulemusena moodustatakse domU seadistusfail
/etc/xen/xen-sarge.auul.cfg
immidzad /mnt/xen/domains/xen-sarge.auul immidzad
disk.img swap.img
domU käivitamine
Privilegeerimata domU seadistusfaili sisu võiks olla näiteks selline
name = 'xen-sarge.auul' kernel = '/boot/vmlinuz-2.6.16.29-xenU' memory = '256' root = '/dev/sda1 ro' disk = [ 'file:/data/xen/domains/xen-sarge.auul/disk.img,sda1,w', \ 'file:/data/xen/domains/xen-sarge.auul/swap.img,sda2,w' ] vif = ['bridge=xenbr0']
Kusjuures, siin kasutatud sda1 ja sda2 seadmed peavad olema kooskõlas domU /etc/fstab faili sisuga. domU failisüsteemile pääseb juurde hõlpsasti, tuleb vastav image ühendada
bash# mount -o loop /data/xen/domains/xen-sarge.auul/disk.img /mnt
domU käivitamine koos konsooli teadete esitamisega toimub selliselt
bash# xm create -c /etc/xen/xen-sarge.auul.cfg
-c võti tähendab, et terminalile esitatakse domU konsool. Peale domU käivitamist võib sisse logida kas konsooli kaudu või üle võrgu. Konsoolilt pääseb välja Ctrl + ] kombinatsiooni abil.
domU seiskamiseks on käsk
bash# xm shutdown xen-sarge.auul
Töötavate domeenide nimekirja näeb käsuga
bash# xm list
Töötavate domeenide ressursikasutust näeb käsuga
bash# xm top
Võrgu kasutamine domU seest
Eelnevates punktides on libisetud üle võrku puudutavatest küsimustest ja keskendutud domU enda käivitamisele kuigi just sobivate võrguomaduste seadistamisega on tavaliselt kõige rohkem probleeme. Võrgus saab domU paikneda kahel moel
- bridge rezhiimis - domU kasutab sama alamvõrgu aadresse mida dom0
- nat rezhiimis - domU kasutab privaatse võrgu aadresse ning on dom0 taha natitud
Käesolevas palas kasutatakse esimest võimalust.
Pikemalt teoorisse süvenemata olgu öeldud, et privilegeeritud ja privilegeerimata domeenide võrgukaardid on ühendatud virtuaalsete sildade abil kokku ning seda kaudu toimub andmevahetus. Ühe võrgukaardi puhul ei tohiks võrgu seadistamine vajada eriliste muudatuste tegemist Xen tarkvara seadistusfailidesse, domU virtuaalne võrguseade ühendatakse virtuaalse sillaga tänu reale
vif = ['bridge=xenbr0']
Kui on vajadus kasutada domU selliselt, et sealt saab pöörduda mitmesse, nt kahe dom0 arvuti füüsilise võrgukaardiga seotud võrgu poole, siis tuleb selleks tekitada üks skript, nt nimega /etc/xen/scripts/kaks-silda.sh ja sisuga
#!/bin/sh dir=$(dirname "$0") "$dir/network-bridge" "$@" vifnum=0 netdev=eth0 bridge=xenbr0 "$dir/network-bridge" "$@" vifnum=1 netdev=eth1 bridge=xenbr1
Lisaks tuleb seadistusfailis /etc/xen/xend-config.sxp kasutada rida
(network-script kaks-silda.sh)
Õigel juhul kasutab nüüd Xen kahte virtuaalselt silda (ingl. k. bridge)
bash # brctl show bridge name bridge id STP enabled interfaces xenbr0 8000.feffffffffff no vif0.0 peth0 vif5.0 xenbr1 8000.feffffffffff no vif0.1 peth1 vif5.1
Tulemusena peab domU sisse tekkima kaks võrguseadet, eth0 ja eth1 ning sobivate aadresside kasutamisel saab nende abil pöörduda vastavatesse võrkudesse.
Probleemid
Kui ei tarkvara kasutamine ei anna soovitud tulemust, siis esmalt maksab tutvuda logifailide sisuga, nt Debian puhul asuvad nad kataloogis /var/log/xen.
Mõnel juhul võib ilmuda peale domU konsoolile bootimist st võtmega -c rohkelt teateid
Couldnt get a file descriptor referring to the console
Selle vastu aitab liigutada ära domU sees fail
bash# mv /etc/console/boottime.kmap.gz /etc/console/boottime.kmap.gz-muidu-segab-xenni
Couldnt get a file descriptor referring to the console
Tundub, et 2007 aasta keskel on AMD64 platvormil Debian Etch Xenilisel paketituumal probleeme stabiilsusega mitme protsessori puhul. Selle vastu aitab kasutada /etc/xen/xend-config.sxp failis rida
# In SMP system, dom0 will use dom0-cpus # of CPUS # If dom0-cpus = 0, dom0 will take all cpus available (dom0-cpus 1)
Lisaks on täheldatud probleeme kui domU juurfailisüsteemina kasutatakse reiser failisüsteemi.
Kui domU on Debian Sarge, siis ei ole seal standardse paketihaldusega võimalik paigaldada nn xenisõbralikku libc teeki libc6-xen ning selle tulemusena võivad ilmneda sellised teated
4gb seg fixup, process S43portmap (pid 1046), cs:ip 73:b7e763f8
Selle vastu aitab kataloogi /lib/tls liigutamine
bash# mv /lib/tls /lib/tls.disabled
dom0 sees ethtool vms utiliitidega võrguseadmeid uurides tuleb pöörduda pethx kujul seadme poole, nt selliselt
bash# ethtool peth0
Kui domU sees töötab Debian Etch operatsioonisüsteem ning kasutatakse paketihaldusega jagatavat udev'i, siis vaikimisi igal domU reboodil suureneb ethernetiseadme järjekorranumber, st eth0, eth1 jne. Selle vastu aitab domU seadistusfailis fikseerida võrguseadme mac aadress, võiks kasutada Xeni poolt kord omistatud aadress, mille leiab domU failist
/etc/udev/rules.d/z25_persistent-net.rules
Katse näitab, samuti asjakohaste arhiivide lugemine, et 64bit dom0 all saab edukalt kasutada 32bit domU keskkondi, kusjuures domU tuumaks on 64bit dom0 tuuma. Ilmselt rakenduvad seejuures samasugused asjaolud nagu ilma Xenita 64bit tuuma ja 32 bit userspace'i kasutamisel.
Debian Etch paketihalduse xen-tuuma kasutamine
Turvalisuse ja kasutusmugavuse seisukohast on Debian GNU/Linux Etch versiooni puhul otstarbekas kasutada pakendatud tuuma kasutades nt 32bit x86 platvormil paketti ja sealt lähtuvaid sõltuvusi, näiteks sellised võiksid olla asjakohased paketid ühe ajahetkel
bash# dpkg -l '*xen*' | grep ii ii bridge-utils 1.2-1 Utilities for configuring the Linux ethernet bridge ii libc6-xen 2.3.6.ds1-13 GNU C Library: Shared libraries [Xen version] ii linux-image-2.6.18-4-xen-686 2.6.18.dfsg.1-12etch2 Linux 2.6.18 image on i686 ii linux-modules-2.6.18-4-xen-686 2.6.18.dfsg.1-12etch2 Linux 2.6.18 modules on i686 ii xen-hypervisor-3.0.3-1-i386-pae 3.0.3-0-2 The Xen Hypervisor on i386 with pae ii xen-linux-system-2.6.18-4-xen-686 2.6.18.dfsg.1-12etch2 XEN system with Linux 2.6.18 image on i686 ii xen-tools 2.8-2 Tools to manage debian XEN virtual servers ii xen-utils-3.0.3-1 3.0.3-0-2 XEN administrative tools ii xen-utils-common 3.0.3-0-2 XEN administrative tools - common files
Ning nii jääb ära vajadus ise tuuma kompileerida.
Full virtualization
Kui kasutada olev riistavara on AMD-V või Intel VT toega, siis on võimalik kasutada Xeni ka 'full virtualization' rezhiimis. Näiteks kaasneb sellega võimalus kasutada domU sees modifitseerimata operatsioonisüsteemi. Kasutamiseks tuleb paigaldada pakett
xen-ioemu-3.0.3-1
Üldiselt on asjatoimetused sarnased kui paravirtualiseerimise puhul, domU seadistusfailiks sobib nt sellise sisuga fail, antud juhul toimub Debian GNU/Linux operatsioonisüsteemi paigaldusmeedialt bootimine, millele võiks järgneda install varem dd käsuga moodustatud disk image'le
kernel = "/usr/lib/xen-3.0.3-1/boot/hvmloader" builder = 'hvm' device_model = '/usr/lib/xen-3.0.3-1/bin/qemu-dm' memory = '2048' vcpus = '1' name='full-virt' vif = [ 'mac=00:16:3E:3A:8E:7A, type=ioemu, bridge=xenbr2' ] disk = [ 'file:/data/zones/domains/full-virt/disk.img,ioemu:hda,w', 'file:/data/images/debian-40r0-i386-CD-1.iso,hdc:cdrom,r' ] boot='d' vnc=1
Peale sellise seadistusfailiga domU bootimist saab ühenduda vnc kliendiga (nt vncviewer) porti 5900 ning suhelda domU konsooliga. Seda võiks praktiliselt teha ssh abil porte sobivalt suunates. Peale operatsioonisüsteemi paigaldamist tuleks asendada boot parameetri väärtuseks 'c' ning bootida vastselt paigaldatud süsteem.
Konsool võiks X keskkonnas välja näha selline
Lingid
NetBSD xen http://www.s-mackie.demon.co.uk/unix-notes/NetBSD-Xen-Setup.html
Xen knoppix http://unit.aist.go.jp/itri/knoppix/xen/index-en.html
Gentoo Xen http://gentoo-wiki.com/HOWTO_Xen_and_Gentoo