ref: 1211bc2a32c1ffe5614b5a7d6daae3ca3f5faa65
dir: /sys/doc/backup.ms/
.FP lucidasans .HTML "Venti Backups to Blu-Ray Discs" .EQ delim $$ .EN . .TL Venti Backups to Blu-Ray Discs .AU Geoff Collyer .AI .MH .SH Overview .PP As a precaution against multiple disks in our Plan 9 .I venti server's RAID array failing at about the same time, or other catastrophic failure, we record .I venti arenas, after they are sealed, onto dual-layer Blu-Ray discs (BDs). One could use other large optical discs instead. .PP The advertised capacity of a dual-layer BD is 50GB, but those aren't even disk-manufacturer's (decimal) gigabytes, which would give a capacity of $50 times 10 sup 9$ bytes, which is roughly equivalent to 46.6 gigabytes, as the term is used by everyone but disk manufacturers. In the case of BDs, even that is an exaggeration, with the actual capacity being closer to $48.44 times 10 sup 9$ bytes, so the claimed capacity should be read as `50 VAX-gigabytes', where a .I VAX-gigabyte is 968,800,338 bytes. The default .I venti arena size is 512MB, but for some reason our server is configured with 1GB arenas, so we could fit 46 of them on a BD. To leave a little extra room for lead-in, lead-out, inter-track gaps, lossless-linking and the like, we record 45 arenas per BD. .PP The scripts used and records kept are in .CW /sys/lib/backup and pertain to the file server on which they are stored. You will probably want to edit .CW funcs to set default file server and Blu-ray device, at minimum. .SH Creating and Updating Backups .PP We start .I cdfs after inserting a disc (virgin or partially-written), then use .I venti/rdarena to copy the next sealed but not backed-up arena to the start of the unwritten portion of the BD by writing to .CW /mnt/cd/wd/x . We don't fixate data BDs, as that seems to tickle a bug, perhaps in our Sony Blu-Ray burners, that only records the first track in the disc index upon fixation. .PP One can find out which arenas are sealed and which are open by viewing .CW http://\fIventi-server\fP/index . We also periodically print the most recent .I fossil dump scores and save the paper with the discs. .PP All of this is packaged up as scripts in .CW /sys/lib/backup , notably .CW backup . A typical invocation would be just .DS .ft CW cd /sys/lib/backup backup .ft .DE which will guide its invoker as to which discs to insert into a Blu-ray burner and when. This works for a first full backup and for subsequent incremental backups of just the newly-sealed arenas. There is provision for burning multiple backup sets, the default being .CW set1 . To burn a second set, we would .DS .ft CW mkdir /sys/lib/backup/set2 backup -s set2 .ft .DE .CW backup and related scripts keep track of which BD is current and how many tracks are recorded, and which arenas have been dumped to BD. .PP We have recorded two sets of BD backups, one of which will go to Antwerp to seed their .I venti server and also serve as off-site backup for Murray Hill. .SH Restoring from Backups .PP After a disaster, or when setting up a new .I venti server from BD backups, the first step is to get Plan 9 running on the new .I venti server. This could be done by installing into a smallish (2GB) .I fossil partition from a Plan 9 installation CD, if necessary. One would then initialise the new disk partitions per .I venti-fmt (8) and read all the arenas on all the BDs into the new .I venti by running .I venti/wrarena once per BD track (arena). .br .ne 3 .PP To add the contents of a backup BD to a (possibly fresh) .I venti store, shut down the .I venti server, format the arenas partition, then run .DS .ft CW restore \fIfirst-arena-number\fP .ft .DE after inserting a BD into the Blu-ray drive. Repeat this for each BD in the backup set. When all the arenas have been restored, it will be necessary to build a new .I venti index, the usual steps being to run .I checkarenas , .I fmtisect , .I fmtbloom , .I fmtindex , and .I "buildindex -b" , all from .I venti-fmt (8). Then the .I venti server may be restarted. .PP Once the .I venti storage has been restored, a new .I fossil partition (perhaps the existing one or another one) can be initialised from the last .I fossil dump score corresponding to the last arena on BD (see .I fossil/flfmt in .I fossil (4)): .DS .ft CW fossil/flfmt -v c388...32b5 /dev/sdC0/fossil .ft .DE