Mizeria is a simple program for making backups. It is written in Rust and it supports Windows, Linux and macOS. The goal of this project is to provide straightforward and easy to understand structure of a backup.
Create a snapshot of your files:
mizeria backup <BACKUP> <INPUT>...
USAGE:
mizeria backup [FLAGS] <BACKUP> <INPUT>...
FLAGS:
--full Force creating full snapshot
-h, --help Prints help information
-v Sets the level of verbosity
ARGS:
<BACKUP> A folder where snapshot will be stored
<INPUT>... Files or folders to be backed up
General help about the program:
mizeria --help
backup sumcommand help:
mizeria help backup
more detailed help about backup subcommand:
mizeria backup --help
cargo install --git https://github.com/KyrietS/mizeria.git
- Single executable file.
- Extremely fast.
- Backed up files and folders are stored as files and folders.
- Incremental backups. 🚀
- Merging and removing snapshots. 🚧
- Backup restoration procedures.
- Compressing snapshots into zips.
- Repairing corrupted snapshots.
- And more...
- Backup – folder with snapshots.
- Snapshot - folder with backed up files and index for them. Snapshot's name consists of date and time when it was created.
- Index – text file stored in every snapshot under the name
index.txt
. It is a list of absolute paths to every file that was present at a time when snapshot was made. - Files – folder with files that were copied from their origins. The absolute folder structure is preserved.
Consider the following example
.
└── my_backup/
├── 2021-07-26_13.45/
│ ├── index.txt
│ └── files/
│ └── C/
│ └── my_folder/
│ └── my_file.txt
├── 2021-07-27_13.45/
│ ├── index.txt
│ └── files/
│ └── C/
│ └── my_folder/
│ └── my_modified_file.txt
└── 2021-07-28_13.45/
├── index.txt
└── files/
Backup presented above has 3 snapshots. Each snapshot except the last one consists of one file. Note how the absolute directory structures of a backed up files are preserved.
Let's look at the contents of a particular index.txt files from the backup above.
2021-07-26_13.45/index.txt
2021-07-26_13.45 C:\\my_folder\my_file.txt
2021-07-27_13.45/index.txt
2021-07-27_13.45 C:\\my_folder\my_modified_file.txt
2021-07-28_13.45/index.txt
2021-07-27_13.45 C:\\my_folder\my_modified_file.txt
The last snapshot does not have any files because my_modified_file.txt
hasn't changed since the last snapshot, so an incremental backup has been performed. The unmodified file is listed in the index but it's pointing into the previous snapshot (see date before the file path).
Every module has its own unit tests. This project has also integration/e2e tests to verify given user-cases and scenarios.
Copyright © 2021-2024 KyrietS
Use of this software is granted under the terms of the MIT License.
See the LICENSE for the full license text.