Location via proxy:   [ UP ]  
[Report a bug]   [Manage cookies]                
Skip to content

My opinionated data backup and retrieval system

License

Notifications You must be signed in to change notification settings

myTerminal/ursa

Repository files navigation

ursa-major

License
ko-fi

My opinionated data backup and retrieval system

Purpose

Since the late 1990s, I have accumulated a significant amount of personal digital data, starting from my first digital diary. Over the years, my data has migrated across various computing devices, undergone format changes, and experienced occasional data loss. My journey to find the most secure and reliable method for data storage has led me through various solutions, including external drives, cloud storage, and a network of Syncthing nodes offering more than sufficient redundancy.

While these methods have served me well, ensuring continued access to my data for an inheritor presents a challenge. Storage drives can fail, cloud services come with trust issues, and even replicating data across multiple computers is constrained by password requirements.

ursa is designed to address these concerns by:

  1. Centralizing Data: Keeping all data in a single, cohesive location.
  2. Enhanced Security: Protecting data behind encrypted volumes, accessible only through independent passwords.
  3. Redundant Copies: Maintaining more than two redundant copies of all data to ensure reliability.
  4. Regular Synchronization: Continuously syncing data from its various sources to keep it up-to-date.
  5. Error Checking and Refreshing: Periodically refreshing and checking data for errors to ensure ongoing integrity.

With ursa, I could have peace of mind knowing that my data is securely managed and more accessible in case I need it available after I'm gone.

Requirements

Hardware

The system has been designed with an external storage drive in mind with the following data volumes:

  1. /dev/sdb1 - Backup volume 1
  2. /dev/sdb2 - Backup volume 2
  3. /dev/sdb3 - Backup volume 3
  4. /dev/sdb4 - Live volume hosting ursa

The above specification assumes that the external drive has been identified as /dev/sdb block device.

Software

ursa is a simple set of shell scripts with the least number of external dependencies that it sets up to be able to perform its operations, which includes regular backups, updates, and eventual data retrieval by a trusted family member or inheritor.

Suggested Volume Setup

Set up partitions

cfdisk /dev/sdb

Partitions:

  1. /dev/sdb1 - backup partition 1
  2. /dev/sdb2 - backup partition 2
  3. /dev/sdb3 - backup partition 3
  4. /dev/sdb4 - auxiliary partition

Format backup partitions with LUKS

cryptsetup -y -v luksFormat --type luks1 /dev/sdb1
cryptsetup -y -v luksFormat --type luks1 /dev/sdb2
cryptsetup -y -v luksFormat --type luks1 /dev/sdb3

Format auxiliary partition with EXT4

mkfs.ext4 /dev/sdb4

Open backup partitions to create an EXT4 underneath

cryptsetup open /dev/sdb1 vault-a
cryptsetup open /dev/sdb2 vault-b
cryptsetup open /dev/sdb3 vault-c
mkdir /mnt/vault-a /mnt/vault-b /mnt/vault-c
mount /dev/mapper/vault-a /mnt/vault-a
mount /dev/mapper/vault-b /mnt/vault-b
mount /dev/mapper/vault-c /mnt/vault-c
chmod 777 -R /mnt/vault-a /mnt/vault-b /mnt/vault-c
mkfs.ext4 /dev/mapper/vault-a
mkfs.ext4 /dev/mapper/vault-b
mkfs.ext4 /dev/mapper/vault-c
cryptsetup close vault-a
cryptsetup close vault-b
cryptsetup close vault-c

Unmount the auxiliary partition

udisksctl unmount -b /dev/sdb4
udisksctl power-off -b /dev/sdb4

Install a graphical Linux distribution on the fourth volume, and deploy ursa on it. Follow the next section on deploying ursa. Preferably enable running sudo commands without a password.

Setup

In order to set up ursa on an external storage drive, clone it to a local directory, and run the following command:

make setup

This will prepare the environment with external dependencies, and internally run ./ursa-deploy, which will prompt for a location to the fourth live volume on the target drive. Once a location is provided, and if everything goes as expected, you should be able to see the commands deployed to the specified device.

Usage

ursa has been designed to maintain user data in a set of three identical data volumes. You may maintain your data backup in only one of the three, though keeping all three of them in sync is recommended.

Retrieving Data

If you simply need to retrieve data from the three data volumes, run:

./ursa-retrieve

You should be presented with a file explorer window with the most recent data recorded by ursa.

Regular Backups

In order to backup data, you may run:

./ursa-retrieve

...which will find the most recently updated (and hence most up-to-date data volume) and unlock it for syncing files for a backup. Although, it is recommended to occasionally also sync data between all the three data-volumes and keep them in sync. This can be done using:

./ursa-sync

This will open meld on all the three data volumes for manual sync.

Integrity Refresh (Suggested Once or Twice a Year)

It is recommended to run an integrity refresh occasionally to avoid data loss. The reason for having thee data volumes is that if during a replication cycle, a volume has been identified with issues, another one can be used for the current cycle, and the problematic volume could still be repaired from one of the two working volumes.

To start an integrity refresh cycle, simply run:

./ursa-refresh

The scripts automatically unlocks the vaults, identify the newest and the oldest replicated volume, and the user is suggested to use the former to replicate the latter. This way, the oldest replicated volume becomes the newest for the next cycle, and effectively, all the three volumes get checked for data integrity every third replication cycle. ursa maintains the timestamp using an empty file named .ursa-tag at the root of each data volumes.

Removing the Backup Drive

Removing the backup drive can be performed using a simple command:

./ursa-remove

Updating ursa

In order to update ursa on the backup drive, simply run:

./ursa-update

External Dependencies

TODO

  • Implement progress update during long-running processes
  • Implement ".desktop" files for normies

About

My opinionated data backup and retrieval system

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published