Automatic backups of inode tables and partition info for easier data recovery

Good morning all, in today’s episode of “What I learned during work hours”…

I was playing around with wxHexEditor and realised that if something catastrophic happened, I would really struggle with any data recovery if I lost the inode tables for any drive.

A quick duckle pointed me to e2image, which says in the man:

It is a very good idea to create image files for all file systems on a system and save the partition layout (which can be generated using the fdisk -l command) at regular intervals — at boot time, and/or every week or so.

I couldn’t find any prebuilt solutions for this online, so I wrote a systemd service and timer to do this for me. I save the fdisk to a text file, run e2image on a couple drives, and compress it all together in a dated 7z that can get uploaded via rsync or Mega or Dropbox etc.

The metadata image from a 500gb drive is 8gb, but compresses down to 40mb. Backup takes a couple minutes.

Unfortunately this does not work with my raid drives, but they are RAID1 so already resilient.

Apparently I was being a derp somehow. …Anyways,

My RAID drives are 16TB, e2image of this is 125gb, and 7z’d it comes down to just 63mb.

I’ll post the service, timer, and backup script in a comment, let me know if you can spot anywhere for improvements!

lemmyvore,

May I point out that all a RAID1 does is sync the blocks between two drives. It won’t protect against writing something dumb that would mess up the filesystem, it will just dutifully sync it.

You should be able to back up ext data from a filesystem on a RAID array, unless I’m confused about what e2image actually does. Are you trying to use it on the underlying drive devices by any chance? You have to point it at the RAID device on top of them, something like /dev/md1 rather than /dev/sda1.

This sounds like a good extra backup to have but don’t let it lull you into a false sense of security. It may help recover from a very specific kind of mistake but the recovery may be very specific as well. It’s not file backup.

luthis,

Oh you’re right it does work… well fuck knows what I was doing wrong before.

Yeah this is a backup in case I like, mv file to /dev/sda1 or something.

Not a backup of the files, but a backup of the structure.

NeoNachtwaechter,

e2image

There’s a good reason for the 2 in the name.

Today we have ext4, and ZFS of course.

uis,
@uis@lemmy.world avatar

e2image - Save critical ext2/ext3/ext4 file system metadata to a file

Quazatron,
@Quazatron@lemmy.world avatar

I’m really curious as to why go to all this trouble instead of using a proper file level backup and restore solution.

luthis,

For fun and learning. It’s just another tool to go with file level backup.

And the backup for this is 40mb and really fast, but backing up files even when compressed would be hundreds of GB, maybe terabytes, and then you’re paying for that amount of storage online somewhere, uploading for hours…

Quazatron,
@Quazatron@lemmy.world avatar

Picture this: you open and edit one of your documents and save it.

The filesystem promptly allocates some blocks and updates the inodes. Maybe the inode table changed, maybe not. Repeat for some other files. Now your “inode backup” has a completely different picture of what is going on on your disk. If you try to recover the disk using it, all you will achieve is further corruption of the filesystem.

NeoNachtwaechter,

instead of using a proper file level backup

Backups do not solve everything.

For example once I had a bad cable, and it did a kinda sneaking silent damage. Let’s say 5 or 50 broken files every day. And only after some weeks I noticed some of them, and there was hardly a chance to identify them each day. And sometimes there was damage to the file system, too. It took a while find the root cause.

Today I use ZFS with redundancy and it does the recovery all by itself and my sleep is so much better :-)

luthis,

Ok time to investigate ZFS

Quazatron,
@Quazatron@lemmy.world avatar

“Proper backups” imply that you have multiple backups and a backup strategy. That could mean, for instance, that you would do a full backup, then an incremental/differential backup each week and keep one backup for each month. A bad cable would cause you trouble, no doubt, but the impact would be lessened by having multiple backups points spread over months.

Redundancy is not backup. Read that again.

Redundancy is important for system resilience, but backup is crucial for continuity. Every filesystem is subject to bugs and ZFS is not special. Here’s an article from a couple of days ago. If you’re comfortable with no backups just because you have redundancy, more power to you. I wouldn’t be.

NeoNachtwaechter,

I wasn’t saying backups are useless or something.

I was saying there are situations that backups can’t solve.

Quazatron,
@Quazatron@lemmy.world avatar

Sure, all the work you do between the moment of the filesystem failure and the last backup is gone. There’s nothing that can be done to mitigate that fact, other that more frequent backups and/or a synchronized (mirror) system.

Backups are just a simple way to keep you from having to explain to your partner that you lost all the pictures and videos you took along the years.

skullgiver, (edited )
@skullgiver@popplesburger.hilciferous.nl avatar

deleted_by_author

  • Loading...
  • Violet_McQuasional,
    @Violet_McQuasional@feddit.uk avatar

    This is why I love having luks covering my entire system disk. If I want to upgrade the system with a new drive or move the drive to a different pc or sell it or dispose of it I just dd the first couple of gigs to obliterate the luks header.

    It’s obviously essential to have a backup strategy, of course, but full disk encryption is the only way to go for me.

    luthis,

    Great tips, thanks!

    I’m using ext4 across everything I think.

    Can you enable superblocks after you’ve already formatted the drive?

    Fdisk saves the offsets so keeping a record of that at least sounds like a good idea.

    MigratingtoLemmy,

    Fantastic. I’m following!

    luthis, (edited )

    The script takes the drives as arguments:

    
    <span style="color:#323232;">$ pwd
    </span><span style="color:#323232;">/usr/lib/systemd/system
    </span><span style="color:#323232;">$ cat drive_backup.service 
    </span><span style="color:#323232;">[Unit]
    </span><span style="color:#323232;">Description=backup fdisk + e2image
    </span><span style="color:#323232;">Wants=drive_backup.timer
    </span><span style="color:#323232;">
    </span><span style="color:#323232;">[Service]
    </span><span style="color:#323232;">Type=oneshot
    </span><span style="color:#323232;">ExecStart=/usr/bin/backup_meta_data.sh /dev/sdc1 /dev/sdb1
    </span><span style="color:#323232;">
    </span><span style="color:#323232;">[Install]
    </span><span style="color:#323232;">WantedBy=multi-user.target
    </span>
    

    Set to run at 3:40am every day, but probably could be once weekly really.

    
    <span style="color:#323232;">$ cat drive_backup.timer 
    </span><span style="color:#323232;">[Unit]
    </span><span style="color:#323232;">Description=timer to run drive backup
    </span><span style="color:#323232;">Requires=drive_backup.service
    </span><span style="color:#323232;">
    </span><span style="color:#323232;">[Timer]
    </span><span style="color:#323232;">Unit=drive_backup.service
    </span><span style="color:#323232;">OnCalendar=*-*-* 03:40:00
    </span><span style="color:#323232;">
    </span><span style="color:#323232;">[Install]
    </span><span style="color:#323232;">WantedBy=timers.target
    </span>
    

    Should be fairly self-explanatory.

    
    <span style="color:#323232;">$ cat /usr/bin/backup_meta_data.sh
    </span><span style="color:#323232;">#!/bin/bash
    </span><span style="color:#323232;">
    </span><span style="color:#323232;">working_dir=/home/st/drive_recovery/working
    </span><span style="color:#323232;">backup_dir=/home/st/drive_recovery
    </span><span style="color:#323232;">backup_date=$(date +%Y%m%d-%H%M)
    </span><span style="color:#323232;">
    </span><span style="color:#323232;">mkdir -p $working_dir
    </span><span style="color:#323232;">
    </span><span style="color:#323232;">sudo fdisk -x > $working_dir/$backup_date.fdisk
    </span><span style="color:#323232;">
    </span><span style="color:#323232;">for var in "$@"
    </span><span style="color:#323232;">do
    </span><span style="color:#323232;">	clean=$(echo $var | sed 's;/;-;g')
    </span><span style="color:#323232;">	sudo e2image $var $working_dir/$backup_date.$clean
    </span><span style="color:#323232;">done
    </span><span style="color:#323232;">
    </span><span style="color:#323232;">sudo 7z a $backup_dir/$backup_date.archive $working_dir/"$backup_date"*
    </span><span style="color:#323232;">sudo rm $working_dir/"$backup_date"*
    </span>
    
  • All
  • Subscribed
  • Moderated
  • Favorites
  • linux@lemmy.ml
  • localhost
  • All magazines
  • Loading…
    Loading the web debug toolbar…
    Attempt #