Operatsioonisüsteemi uuendamine
Sisukord
Eesmärk
OpenBSD operatsioonisüsteemi saab uuendada mitmel viisil, käesolevat varianti iseloomustavad sellised asjaolud
- kuna uue süsteemi kasutuselevõtmiseks ei ole vaja kasutada installerit ja piisab file set'ide lahtipakkimisest ning oluliste failide redigeerimisest on see suhteliselt mugav ja peaks võimaldama protseduuri läbi viia võimalikult väikese katkestusega süsteemi töös
- kuna uue süsteemi kasutuselevõtmiseks ei ole kasutata installerit, siis ei saa kasutada installeri abi süsteemi ettevalmistamisel (partitsioneerimine jms)
Kirjeldatud uuendamise käigus võib muuta ka arhitektuuri, nt i386 -> amd64. Sisuliselt tekitatakse kahe OpenBSD eksemplariga dual-boot arvuti, mida saab hõlpsasti vajadusel bootida töötanud olekusse tagasi kui uuendatud süsteem vajab veel kohendamist. Arvuti konsoolile (serial konsoolile) on vajalik ligi pääseda.
Protseduur koosneb järgmistest sammudest
- Arvuti töötab ja on kasutada üks failisüsteem, mis on piisavalt suur ja mis pole parasjagu kasutusega koormatud (nt /tmp) ning mis tuleb ühendada lahti ning külge /mnt kataloogi ilma mount option'iteta
- Pakkida /mnt kataloogi lahti olulised failide komplektid (etc46.tgz, base46.tgz jt) ning tuum (bsd)
- Moodustada uuele süsteemile seadmefailid öeldes /mnt/dev all './MAKEDEV all'
- vaadata diff -r /etc /mnt/etc abil üle erinevused (tõenäoliselt mõniteist nö tundud konfifaili, fstab, motd, hosts, hostname.if jne)
- rebootida süsteem ning kosoolil boot> prompt'ist bootida uue tuumaga uus süsteem
Kui OpenBSD töötab tulemüürina, siis lisaks kaasneb eelis, et arvutis jääb füüsiliste võrguseadmete, MAC ja ip aadresside vastavas samaks erinevate keskkondade vahel liikumisel, erinevalt kahe erineva füüsilise arvuti kasutamisest.
Ettevalmistused
Lähtepunktiks on töötav OpenBSD arvuti, näiteks selliste partitsioonidega
# df -h Filesystem Size Used Avail Capacity Mounted on /dev/sd0a 367M 43.7M 305M 13% / /dev/sd0d 982M 2.0K 933M 0% /tmp /dev/sd0e 490M 149M 317M 32% /home /dev/sd0f 12.2G 2.5G 9.1G 22% /usr /dev/sd0g 51.8G 504M 48.7G 1% /var
Kopeeriga kataloogi /home/install-47 vajalikud failide komplektid (ingl. k. file sets, binary distribution sets) ja tuum, näiteks failid
base47.tgz bsd comp47.tgz etc47.tgz game47.tgz man47.tgz misc47.tgz
Uue keskkonna moodustamine
Ühendage /tmp failisüsteem lahti, ühendage /mnt alla külge ning pakkida kataloogi /mnt arhiivid lahti sellises järjekorras (sama järjekorda kasutatakse ka süsteemi traditsioonilisel viisil paigaldades)
# cp bsd /mnt # cp bsd.rd /mnt # tar -C /mnt -xzphf base47.tgz # tar -C /mnt -xzphf etc47.tgz # tar -C /mnt -xzphf misc47.tgz # tar -C /mnt -xzphf comp47.tgz # tar -C /mnt -xzphf man47.tgz # tar -C /mnt -xzphf game47.tgz
/etc/fstab failist tuleks seejärel /tmp välja kommenteerida, samas peab veenduma, et allesjäänud /tmp kataloogi loabitid on endised, vajadusel kohendada
# chmod 1777 /tmp
ning et juurfailisüsteemis on mõistlikul hulgal vaba ruumi.
Seejärel tekitada seadmefailid
# cd /mnt/dev # ./MAKEDEV all
Kohendada /mnt/etc kataloogis olulisi faile, tõenäoliselt tuleb tähelepanu pöörata järgmistele failidele
/etc/hosts /etc/hostname.* /etc/mygate /etc/myname /etc/resolv.conf /etc/group /etc/ipsec.conf /etc/master.passwd /etc/rc.conf.local /etc/rc.local /etc/pf.* /etc/ntpd.conf /etc/ssh/* /etc/sudoers /etc/sysctl.conf /etc/fstab /etc/joe/joerc /etc/pwd.db /etc/spwd.db /etc/rndc.key /etc/localtime /etc/isakmpd/* /etc/ttys
kusjuures nt pwd.db ja master.passwd faili erinevate versioonide vahel liikudes ei pruugi saada otse kasutusele võtta.
Abiks on võrrelda keskkondi selliselt
# diff -r /etc /mnt/etc | less
Kui on soov lisada pakettidest või portsudest tarkvara, siis võiks seda teha liikudes chroot abil uude keskkonda
# chroot /mnt
ning toimetada edasi tavapärasel viisil, nt öeldes
# pkg_add pftop
Seejuures peab aga uus keskkond olema sama arhitektuuriga.
Uue keskkonna bootimine
Uue keskkonna bootimiseks peab olema ligipääs konsoolile, vanas keskkonnas öelda reboot ning konsoolil boot promptis öelda
boot> boot hd0d:/bsd -a
Seejärel küsitakse peale tuuma laadimist juurfailisüsteemi ning swap'i asukohta, vaikimisi pakutakse sobivaid väärtusi.
Vana keskkonna asendamine uuega
Kui uus keskkond rahuldab, siis võiks vana keskkonna failisüsteemid puhtaks teha ning kopeerida sinna uue keskkonna failid laiali ning bootida tagasi.
Uuele keskkonnale on tõenäoliselt tarkvara paiku lihtsam rakendada kui keskkond on booditud ja selle seest edasi toimetada.
Probleemid
Kui chroot'i tehes saab teate
# chroot /mnt/ /bin/ksh: No controlling tty (open /dev/tty: Device not configured) /bin/ksh: warning: won't have full job control
siis see tähendab tõenäoliselt seda, et /mnt on ühendatud külge ebasobivas rezhiimis (nodev), vaatake mount käsuga järele. Kõige parem oleks kui uues keskkond on ettevalmistamise ajal ühendatud külge ilma mount optioneid kasutamata.
Kui liikuda teisele arhitektuurile, siis tuleb bootida uue arhitektuuri cd43.iso pealt ja tema boot promptist edasi liikuda.
Kui bash või wget paigaldamisel saab teate
# pkg_add bash Can't install gettext-0.14.6p0: lib not found expat.8.0 Dependencies for gettext-0.14.6p0 resolve to: libiconv-1.9.2p3 Full dependency tree is libiconv-1.9.2p3 Can't install bash-3.2.17: can't resolve gettext-0.14.6p0
siis tuleb paigalda xbase42.tgz fail set esmalt, OpenBSD 4.3 puhul sellist vajadust enam pole.
Kui peale crashi püüda failisüsteemi ühendada, siis võib arvuti öelda
# mount /dev/sd0a /mnt/sd0a mount_ffs: /dev/sd0a on /mnt/sd0a: filesystem must be mounted read-only; you may need to run fsck
Ja nii nagu ta teatab tuleks siis kasutada fsck utiliiti
# fsck /dev/sd0a ** /dev/rsd0a ** Last Mounted on / ** Phase 1 - Check Blocks and Sizes ** Phase 2 - Check Pathnames ** Phase 3 - Check Connectivity ** Phase 4 - Check Reference Counts ** Phase 5 - Check Cyl groups 5532 files, 72329 used, 116590 free (30 frags, 14570 blocks, 0.0% fragmentation) MARK FILE SYSTEM CLEAN? [Fyn?] y ***** FILE SYSTEM WAS MODIFIED ***** #
Bootloaderi paigaldamiseks tuleb öelda
# /usr/mdec/installboot -v /mnt/sd0a/usr/mdec/boot /usr/mdec/biosboot sd0 boot: /mnt/sd0a/usr/mdec/boot proto: /usr/mdec/biosboot device: /dev/rsd0c /usr/mdec/biosboot: entry point 0 proto bootblock size 512 /mnt/sd0a/usr/mdec/boot is 3 blocks x 16384 bytes fs block shift 2; part offset 5888032; inode block 1451320, offset 808 using MBR partition 3: type 166 (0xa6) offset 32 (0x20)
kus
- /mnt/sd0a/usr/mdec/boot - fail, mille füüsiline asukoht plokkseadmel kirjutatakse MBRi
- /usr/mdec/biosboot - fail, mis võetakse aluseks MBR muudatuse tekitamisel
- sd0 - plokkseade, mille MBRi muudetakse