hashget deduplication and compression tool
Project description
hashget
Deduplication tool for archiving (backup) debian virtual machines
For example, very useful for backup LXC containers before uploading to Amazon Glacier.
Installation
Pip (recommended):
pip3 install hashget
or clone from git:
git clone https://gitlab.com/yaroslaff/hashget.git
QuickStart
Create debian machine (optional). Later with this example we will use 'mydebvm' container in default LXC location.
# lxc-create -n mydebvm -t download -- --dist=debian --release=stretch --arch=amd64
Update local and network hashdb with packages from this VM. (optional, but very recommended to get maximal efficiency)
# hashget --debcrawl /var/lib/lxc/mydebvm/rootfs/
Now, main work, prepare
# hashget -p /var/lib/lxc/mydebvm/rootfs/
Development hashget hashdb repository
https://gitlab.com/yaroslaff/hashget
saved: 5905 files, 133 pkgs, size: 165.3M
Creates .hashget-restore file in rootfs and (by default) creates gethash-exclude
file (for later tar command) in homedir of current user.
Now, compress:
# tar -czf /tmp/mydebvm.tar.gz -X ~/hashget-exclude --exclude='var/lib/apt/lists' -C /var/lib/lxc/mydebvm/rootfs .
Now lets compare results with usual tarring
# du -sh /var/lib/lxc/mydebvm/rootfs/
321M /var/lib/lxc/mydebvm/rootfs/
# tar -czf /tmp/mydebvm-orig.tar.gz --exclude='var/lib/apt/lists' -C /var/lib/lxc/mydebvm/rootfs .
# ls -lh /tmp/mydebvm.tar.gz /tmp/mydebvm-orig.tar.gz
-rw-r--r-- 1 root root 99M Mar 4 22:01 /tmp/mydebvm-orig.tar.gz
-rw-r--r-- 1 root root 29M Mar 4 21:59 /tmp/mydebvm.tar.gz
Optimized backup is 70Mb shorter, just 29 instead of 99, 70% saved!
After this step, you have very small (just 29Mb for 300Mb+ generic debian 9 LXC machine rootfs)
Untarring:
# tar -xzf mydebvm.tar.gz -C rootfs
Just unpack to any directory as usual tar.gz file
# du -sh rootfs/
80M rootfs/
At this stage we have just 80 Mb out of 300+ Mb total.
Restoring
After unpacking, you can restore files to new rootfs
# hashget -u rootfs
recovered rootfs/usr/bin/vim.basic
recovered rootfs/lib/i386-linux-gnu/libdns-export.so.162.1.3
...
recovered rootfs/usr/share/doc/systemd/changelog.Debian.gz
recovered rootfs/usr/share/doc/systemd/copyright
Documentation
For more detailed documentation see Wiki.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
File details
Details for the file hashget-0.126.tar.gz
.
File metadata
- Download URL: hashget-0.126.tar.gz
- Upload date:
- Size: 22.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.18.4 setuptools/40.8.0 requests-toolbelt/0.9.1 tqdm/4.31.1 CPython/3.6.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | ea65e192375376c9c8709eab68810dba597ed0cc3c204253c7df9c5b17cf366c |
|
MD5 | 16a73d6b82dfcd7e460294c76c3140cc |
|
BLAKE2b-256 | 40a3e80dd9d4127b41e62f08f498ca5871d3d10e1009e5cdc2a97427b4ebc042 |