Root-over-NFS

Allikas: Kuutõrvaja
(Ümber suunatud leheküljelt NFS-Root arvuti tekitamine)

Eesmärk

Soovitavaks tulemuseks on tekitada nn diskless (ingl. k. ilma kõvakettata) arvuti, st millel endal puudub kõvaketas ja kuhu on ühendatud külge NFS serverilt juurfailisüsteem. Muus osas on tegu tavalisel moel töötava arvutiga.

Tutvustus

Üldiselt läbitakse arvuti käivitamisel järgmised etapid

  1. Katsetades järgemööda BIOSis näidatud boot-seadmeid käivitatakse esimene leitud bootloader (eesti k. alglaadija)
  2. Bootloaderi abil laaditakse operatsioonisüsteemi tuum
  3. Vastavalt tuuma käivitamisel kasutatud parameetritele, ühendatakse külge juurfailisüsteem ning käivitatakse operatsioonisüsteem

Tavaliselt leitakse bootloader arvuti ainsalt kõvakettalt, sealt samast laaditakse tuum, ühendatakse külge juurfailisüsteem ning lõpuks käivitatakse operatsioonisüsteem. Võimalik on aga korraldada nii, et osa tegevusi sooritatakse kohalikus arvutis ning osa jaoks pöördutakse võrku:

  1. PXE (preboot execution environment) on standardne viis, mil moel võrgukaart pöördub DHCP serveri poole, omandab võrguseadistuse ning kopeerib edasi TFTP serveri poole pöördudes võrgust bootloaderi
  2. bootloader kopeerib võrgust tuuma
  3. tuuma laadimisel omandatakse uuesti võrguparameetrid ning ühendatakse võrgust külge juurfailisüsteem

Kõige praktilisemat huvi pakuvad kaks juhtu

  1. lokaalselt meedialt käivitatud bootloader - klientarvutil ei ole PXE võimelist võrgukaarti, kuid CD plaadilt või pehmekettalt käivitatakse bootloader, mis kopeerib võrgust tuuma
  2. võrgust käivitatud bootloader - klientarvutil on PXE võimeline võrgukaart ning süsteem käivitatakse ilma lokaalset meediat tarvitamata

NFS serveri ettevalmistamine

Sõltumata sellest, kas bootloader ja tuum laaditakse võrgust või klientarvuti lokaalselt meedialt, NFS serveril peab asuma juurfailisüsteem. NFS serveri ettevalmistamine koosneb kahest tegevusest

  1. klientarvuti juurfailisüsteemi ettevalmistamine - selleks sobib nt kasutada Debian GNU/Linuxi programmi debootstrap ning moodustada nö chroot keskkond, nt kataloogi /data/nfsroot
  2. juurfailisüsteemi võrku jagamine - jagada sobivate ligipääsupiirangutega NFS servr abil võrku välja klientarvuti juurfailisüsteem

Kliendi tuuma ettevalmistamine

Sõltumata sellest, kas laaditav tuum kopeeritakse võrgust või kohalikult meedialt peab tuum olema selliste omadustega

  1. võrgukaardi tugi
  2. Root-over-NFS tugi
Networking -> Networking options -> IP: kernel level autoconfiguration -> IP: DHCP support
File Systems -> Network File Systems -> Root FS on NFS

Ilmselt aga on kõige praktilisem kasutada distributsiooni standardset tuuma, mis töötab samuti.

TFTP serveri ettevalmistamine

TFTP serveri pidamiseks sobib kasutada nt atftpd tarkvara. Sõltuvalt sellest, kas kasutatakse lokaalselt meedialt või võrgust käivitatud bootloaderit, tuleb võrgust kopeerida vastavalt

  • lokaalne bootloader - tuum ja ramdisk
  • võrgust käivitatud bootloader - bootloader, bootloaderi seadistusfail, tuum ja ramdisk

Seadke näiteks tftpd serveri juurfailisüsteemiks kataloog /var/tftpdboot ja kopeerige sinna vajalikud failid. Konkreetsed näited on esitatud allpool.

Lokaalselt meedialt käivitatud bootloader

Grub bootloaderi tarkvarast on võimalik moodustada bootiv CD plaat, mille kasutamise tulemusena arvuti bootitakse üles sellelt plaadilt ning seejärel bootloader kopeerib tftp serverist tuuma ja ramdiski. CD valmistamiseks

  1. Debian GNU/Linuxi operatsioonisüsteemiga jagatav grub ei ole võrguvõimeline ja sellepärast tuleb pakett kompileerida ringi.
  2. moodustada kataloog /usr/src/iso/grub/boot
  3. kopeerida sinna fail /lib/grub/i386-pc/stage2_eltorito
  4. moodustada fail /usr/src/iso/grub/boot/menu.lst sisuga
title           nfs_1.200
ifconfig        --address=192.168.1.200 --mask=255.255.255.0 --server=192.168.1.254
root            (nd)
kernel          (nd)/tuum root=/dev/nfs \
  nfsroot=192.168.1.254:/data/nfsroot \
  ip=192.168.1.200:192.168.1.254:192.168.1.254:255.255.255.0:evangelist:eth0:off
module                   (nd)/ramdisk
  • --server näitab tftp serveri aadressi kust kopeeritakse tuum ja ramdisk

ning anda .iso moodustamiseks kataloogis /usr/src käsk

bash$ mkisofs -R -b boot/grub/stage2_eltorito -no-emul-boot -boot-load-size 4 -boot-info-table -o grub.iso iso 

Seejärel kirjutada CD plaat ning sellelt plaadilt klientarvutit bootides jõutakse grub menüüvalikusse, sealt saab vajadusel teha veel parandusi ning lasta grubil kopeerida tftpd serverilt tuum ning see laadida seadistatud parameetritega. Edasi ühendatakse külge NFS serverilt juurfailisüsteem ning käivitatakse operatsioonisüsteem.

Võrgust käivitatud bootloader pxegrub

Bootloaderi võrgust leidmiseks peab võrgus töötama sobivalt ettevalmistatud dhcp server, sobib kasutada ICS dhcp server, kolm viimast rida on võrgust bootimise spetsiifilised

host evangelist.auul {
  hardware ethernet 00:17:31:b2:77:df;
  fixed-address 192.168.10.20;
  option broadcast-address 192.168.10.255;
  option routers 192.168.10.254;
  option domain-name-servers 192.168.1.254;
  option host-name "evangelist";
  option domain-name "auul";
 
  next-server 192.168.10.254;
  option option-150 "(nd)/menu.lst";
  filename "pxegrub";
}

kus next-server näitab tftpd serveri aadressi.

Antud juhul saab klient dhcp serverilt teada, et bootloader ning bootloaderi menüüfail tuleb kopeerida tftpd serverist aadressil 192.168.10.254. Fail pxegrub tuleb kopeerida võrguvõimelise grubi paketist ning menu.lst sobivalt ettevalmistada. Edasine tegevus jätkub sarnaselt eelmisele punktile, bootloader laadib tuuma ning seejärel ühendatakse külge juurfailisüsteem ning käivitatakse operatsioonisüsteem.

Võrgust käivitatud bootloader pxelinux

pxelinuxi kasutamise eelduseks on, et on kasutada PXE toega võrgukaart. DHCP serveris töötab selline root-over-nfs kliendile vastav sektsioon

 host xen-nfsroot.auul {
   hardware ethernet 00:0e:0c:ba:4b:28;
   fixed-address 192.168.10.101;
   option broadcast-address 192.168.10.255;
   option routers 192.168.10.254;
 
   filename "pxelinux.0";
   next-server 192.168.10.251;
   option domain-name-servers 192.168.10.254;
 }

kus next-server näitab tftpd serveri aadressi. tftpd serveris peab olema neli faili

  • pxelinuxi bootloader /var/tftpboot/pxelinux.0
  • pxelinuxi seadistusfail /var/tftpboot/pxelinux.cfg/default
  • nfs kliendi tuum
  • nfs kliendi ramdisk

kusjuures /var/tftpboot/pxelinux.cfg/default sisaldab

 default nfsroot
 
 label nfsroot
 kernel vmlinuz-2.6.22-3-686
 append initrd=initrd.img-2.6.22-3-686-tootav root=/dev/nfs \
   nfsroot=192.168.10.251:/data/nfsroot \
   ip=192.168.10.101:192.168.10.254:192.168.10.254:255.255.255.0:emmija:eth0:off

Kusjuures PXE bootloader pxelinux.0 ise ei toeta otseselt konkreetset võrgukaarti, nt Inteli või 3Com seadmeid, oluline on, et seade vastaks PXE standardile.

Tavaliselt ei ole selle järele vajadust, aga nt lisades append reale root=/dev/nfs ette 'insmod=e1000' laaditakse kerneli moodul e1000.

pxelinux.0 faili saab näiteks syslinux-common paketist, mille paigaldamiseks tuleb öelda

# apt-get install syslinux-common

Märkused

Käesolevas palas käsitleti bootloaderit grub ja pxelinux, populaarne asjandus on veel etherboot.

Debian GNU/Linux grub paketi kasutamisel tuleb arvestada, milliste võrgukaartide toetus on olemas (nb! see ei ole pxegrub juhtum)

  1. bash$ apt-get source grub
  2. redigeerida debian/rules failis nn ./configure suvandeid, näiteks Realteki, Inteli ja 3Com populaarsete võrgukaartide toetuse lisamiseks tekitada juurde sellised read, et kokku on vastav sektsioon
# Add here commands to configure the package.
aclocal-1.8 && automake-1.8 && autoconf
CC=$(CC) LDFLAGS=$(LDFLAGS) ./configure \
   --host=$(DEB_HOST_GNU_TYPE) \
   --build=$(DEB_BUILD_GNU_TYPE) \
   --prefix=/ \
   --mandir=/usr/share/man \
   --infodir=/usr/share/info \
   --disable-auto-linux-mem-opt \
   --enable-diskless \
   --enable-eepro100 \
   --enable-rtl8139 \
   --enable-3c90x
  1. bash$ dpkg-buildpackage -rfakeroot
  2. mõnel juhul võiks bootloaderi vahele jätta ja lasta otse DCHP serveril PXE'le tuum kätta anda, aga vähemalt minu ühel seesugusel katsel teatas arvuti seepeale, et mälust ei piisanud

Linuxi Root-over-NFS arvutile on sobilik ühendada külge swap üle iSCSI.

TODO: palad teemadel: dhcp, tftp, nfs, debiani pakettide tekitamine, tuuma kompileerimine, debiani paketihaldus, grub, debootstrap

Kasulikud lisamaterjalid