Betriebssysteme > Solaris
Sicherung 4.2 (UFS) Dateisystem von CD-ROM in Dump-Datei
(1/1)
escimo:
Hallo zusammen,
welche Verfahren kennt ihr zum Sichern des Inhaltes einer CD-ROM mit 4.2-Dateisytem (UFS) in eine Datei/Archiv/Dump unter SunOS 4.x, xBSD oder GNU/Linux? (kein CD-Abbild/Image!)
Hintergrund: der Inhalt der CD-ROM der für SunOS 4.x nötig ist (SPARCompiler 2.0), soll später mit "mkisofs" in einem separatem ISO-Image über TME mit installiertem SunOS 4.1.3 eingehangen (mount) werden.
Ich konnte den Inhalt der CD-ROM bereits erfolgreich in ein RAW-Abbild mit dem Programm Brasero unter Ubuntu 10.04 (GNU/Linux) sichern und auch wieder erfolgreich auf das beschreibbare Medium (CD-R/W) bannen und im Dateisystem unterhalb SunOS 4.x auf der SS2 einhängen (mount). Das RAW-Abbild lässt sich leider nicht in TME mounten. Eine "einfache" Sicherung (ISO-Abbild) der CD-ROM mit dem selben Programm führt zu einem defekten CD-Abbild, welches später nicht unter SunOS 4.x weder auf der SS2 noch unter TME eingehängt werden konnte.
Die folgenden Varianten erwiesen sich unter SunOS 4.x ebenso als Fehlschlag:
--- Code: ---# mount -trv 4.2 /dev/sr0 /cdrom ; cp -pR /cdrom /home/me/ ; umount /cdrom
# #Keine symbolischen Links vorhanden nach Kopiervorgang!
# cat /dev/sr0 > /home/me/cd.img
# ls -l /home/me/cd.img
-rw-r--r-- 1 root 577382400 Mar 4 03:18 /home/me/cd.img
# dd if=/dev/sr0 bs=512 of=/home/me/cd.img
-rw-r--r-- 1 root 577382400 Mar 4 03:18 /home/me/cd.img
# #Beide Images konnten nach dem Brennen nicht auf dem Zielsystem eingehangen (mount) werden
--- Ende Code ---
Bisweilen konnte ich mir unter SunOS 4.1.4 auf zwei Arten helfen:
[1] Ungünstige Variante mit Program cpio
--- Code: ---$ su -
# mount -trv 4.2 /dev/sr0 /cdrom
# cd /cdrom
# ls
Solaris_1.0 Solaris_2.0
# find Solaris_1.0 -print | cpio -ocvdumB > /home/me/SC201-S1.cpio
# compress SC201-S1.cpio
--- Ende Code ---
"Ungünstig" desshalb, weil mit dieser Methode (alternativ tar) alle symbolischen Links dereferenziert werden. Das bedeutet, im 4.2-Dateisystem vorhandene, symbolischen Links werden aufgelöst indem eine Kopie der referenzierten Datei mit der Bezeichnung des symbolischen Links im relativen Pfad angelegt/erstellt wird. Das führt wiederum dazu, dass die Sicherung (cpio-Datei) mehr Speicherplatz benötigt als tatsächlich nötig wäre und eigentliche Referenzierung geht verloren.
[2] Vollständige Variante mit Programmen dump/restore (ab SunOS 5.x: ufsdump/ufsrestore)
--- Code: ---$ su -
# umount /cdrom
# Sicherung dump(8) SunOS 4.x
toosy# dump 0f - /dev/sr0 > dmp
DUMP: Date of this level 0 dump: Sun Mar 4 00:10:13 2012
DUMP: Date of last level 0 dump: the epoch
DUMP: Dumping /dev/sr0 to standard output
DUMP: mapping (Pass I) [regular files]
DUMP: mapping (Pass II) [directories]
DUMP: estimated 601128 blocks (293.52MB) on 8.27 tape(s).
DUMP: dumping (Pass III) [directories]
DUMP: dumping (Pass IV) [regular files]
DUMP: 599562 blocks (292.75MB) on 1 volume
DUMP: DUMP IS DONE
toosy# ls -l dmp
-rw-r--r-- 1 root 306974720 Mar 4 00:14 dmp
# Wiederherstelung restore(8) SunOS 4.x
toosy# restore xfvy - Solaris_1.0 </home/me/dmp
Verify volume and initialize maps
Dump date: Sun Mar 4 00:10:13 2012
Dumped from: the epoch
Level 0 dump of an unlisted file system on toosy:/dev/sr0
Label: none
Extract directories from tape
Initialize symbol table.
Warning: ./Solaris_1.0: File exists
Make node ./Solaris_1.0/bin
Make node ./Solaris_1.0/SC2.0.1_SunC++
Make node ./Solaris_1.0/SC2.0.1_SunC++/SC2.0.1
Make node ./Solaris_1.0/SC2.0.1_SunC++/SC2.0.1/README
[...]
Make node ./Solaris_1.0/SC2.0.1_SunC/_text
Extract requested files
extract file ./Solaris_1.0/bin/Session.icon
extract file ./Solaris_1.0/bin/cdruninstall
extract file ./Solaris_1.0/bin/extract_unbundled
extract file ./Solaris_1.0/SC2.0.1_SunC++/SC2.0.1/include/cc_411/arpa/nameser.h
extract file ./Solaris_1.0/SC2.0.1_SunC++/SC2.0.1/include/cc_411/rfs/ns_xdr.h
extract file ./Solaris_1.0/SC2.0.1_SunC++/SC2.0.1/include/cc_411/rfs/rfs_xdr.h
extract file ./Solaris_1.0/SC2.0.1_SunC++/SC2.0.1/include/cc_411/sparc/asm_linkage.h
extract file ./Solaris_1.0/SC2.0.1_SunC++/SC2.0.1/include/cc_411/sun4c/debug/asm_linkage.h
extract file ./Solaris_1.0/SC2.0.1_SunC++/SC2.0.1/include/cc_412/hsfs/hsfs_spec.h
Create symbolic link ./Solaris_1.0/SC2.0.1_SunC++/SC2.0.1/include/cc_412/hsfs/hsnode.h->../../cc_411/hsfs/hsnode.h
[...]
Add links
Set directory mode, owner, and times.
set owner/mode for '.'? [yn] y
toosy# ls -l
total 1
drwxr-xr-x 18 root 512 Mar 4 01:25 Solaris_1.0
toosy# du -s Solaris_1.0
131636 Solaris_1.0
--- Ende Code ---
Wie geht ihr beziehungsweise würdet ihr vorgehen?
Viele Grüße,
escimo
Ten Little Indyans:
Wenn das Endergebnis ein ISO-Image sein soll, was spricht denn dagegen einfach mkisofs über die gemountete CD-ROM laufen zu lassen?
Ich habe es jetzt nicht praktisch erprobt, sehe aber auf Anhieb keinen Grund warum es so nicht funktionieren sollte:
--- Code: ---mount -trv 4.2 /dev/sr0 /cdrom
mkisofs -o SC201-S1.iso -R /cdrom
--- Ende Code ---
escimo:
Mir fehlt das passende Binary von mkisofs für SunOS 4.x. Ein xBSD habe ich auch nicht zur Hand bzw. installiert. Eine Übersetzung über den bei SunOS 4.x mitgelieferten cc (C-Compiler) sollte dennoch machbar sein:
--- Zitat ---It seems that at there is a structure alignment problem
with the structure scsi_cmd at least with gcc.
If you get a message: 'XXX
If you want to run cdrecord on SunOS 4.x on a sparc system
please make sure that you are using the old Sun cc
by typing:
make CCOM=cc
--- Ende Zitat ---
Quelle: http://cdrecord.berlios.de/private/man/README/README.sunos
Ich probiere es aus. Danke.
Navigation
[0] Themen-Index
Zur normalen Ansicht wechseln