tool which de-duplicates files in a filesystem by checksum.
Project description
farmfs
Tool for creating / distributing / maintaining symlink farms.
Warning
FarmFS is still very early stage software.
Please do not keep anything in it which you are not willing to lose.
Installation
To use Farmfs
pip install git+https://github.com/andrewguy9/farmfs.git@master
To hack on Farmfs
git clone https://github.com/andrewguy9/farmfs.git
cd farmfs
python setup.py install
Usage:
FarmFS
Usage:
farmfs mkfs
farmfs (status|freeze|thaw) [<path>...]
farmfs snap (make|list|read|delete|restore) <snap>
farmfs fsck
farmfs count
farmfs similarity
farmfs gc
farmfs checksum <path>...
farmfs remote add <remote> <root>
farmfs remote remove <remote>
farmfs remote list
farmfs pull <remote> [<snap>]
Options:
What is FarmFS
Farmfs is a git style interface to non text, usually immutable, sometimes large files. It takes your files and puts them into an immutable blob store then builds symlinks from the file names into the store.
Why would you do that?
- You can snapshot your directory structure BIG_O(num_files).
- You can diff two different farmfs stores with BIG_O(num_files) rather than BIG_O(sum(file_sizes))
- You can identify corruption of your files because all entries in the blob store are checksumed.
- If the same file contents appear in multiple places you only have to put it in the blob store once. (deduplication)
Getting Started
Create a Farmfs store
mkdir myfarm
cd myfarm
farmfs mkfs
Make some files
mkdir -p 1/2/3/4/5
mkdir -p a/b/c/d/e
echo "value1" > 1/2/3/4/5/v1
echo "value1" > a/b/c/d/e/v1
Status can show us unmanged files.
farmfs status
/Users/andrewguy9/Downloads/readme/1/2/3/4/5/v1
/Users/andrewguy9/Downloads/readme/a/b/c/d/e/v1
Add the untracked files to the blob store. Notice it only needs to store "value1" once.
farmfs freeze
Processing /Users/andrewguy9/Downloads/readme/1/2/3/4/5/v1 with csum /Users/andrewguy9/Downloads/readme/.farmfs/userdata
Putting link at /Users/andrewguy9/Downloads/readme/.farmfs/userdata/238/851/a91/77b60af767ca431ed521e55
Processing /Users/andrewguy9/Downloads/readme/a/b/c/d/e/v1 with csum /Users/andrewguy9/Downloads/readme/.farmfs/userdata
Found a copy of file already in userdata, skipping copy
Edit a file. First we need to thaw it, then we can change it.
farmfs thaw 1/2/3/4/5/v1
farmfs status
/Users/andrewguy9/Downloads/readme/1/2/3/4/5/v1
echo "value2" > 1/2/3/4/5/v1
farmfs freeze 1/2/3/4/5/v1
Processing /Users/andrewguy9/Downloads/readme/1/2/3/4/5/v1 with csum /Users/andrewguy9/Downloads/readme/.farmfs/userdata
Putting link at /Users/andrewguy9/Downloads/readme/.farmfs/userdata/4ca/8c5/ae5/e759e237bfb80c51940de7a
farmfs status
We don't want to loose our progress, so lets make a snapshot.
farmfs snap make mysnap
Now create more stuff
echo "oops" > mistake.txt
farmfs freeze mistake.txt
Processing /Users/andrewguy9/Downloads/readme/mistake.txt with csum /Users/andrewguy9/Downloads/readme/.farmfs/userdata
Putting link at /Users/andrewguy9/Downloads/readme/.farmfs/userdata/38a/f5c/549/26b620264ab1501150cf189
Well that was a mistake, lets roll back to the old snap.
farmfs snap restore mysnap
Removing /mistake.txt
Now that we have our files built, lets build another depot.
cd ..
mkdir copy
cd copy
farmfs mkfs
We want to add our prior depot as a remote.
farmfs remote add origin ../myfarm
Now lets copy our work from before.
farmfs pull origin
mkdir /1
mkdir /1/2
mkdir /1/2/3
mkdir /1/2/3/4
mkdir /1/2/3/4/5
mklink /1/2/3/4/5/v1 -> /4ca/8c5/ae5/e759e237bfb80c51940de7a
Blob missing from local, copying
*** /Users/andrewguy9/Downloads/copy/.farmfs/userdata/4ca/8c5/ae5/e759e237bfb80c51940de7a /Users/andrewguy9/Downloads/myfarm/.farmfs/userdata/4ca/8c5/ae5/e759e237bfb80c51940de7a
mkdir /a
mkdir /a/b
mkdir /a/b/c
mkdir /a/b/c/d
mkdir /a/b/c/d/e
mklink /a/b/c/d/e/v1 -> /238/851/a91/77b60af767ca431ed521e55
Blob missing from local, copying
*** /Users/andrewguy9/Downloads/copy/.farmfs/userdata/238/851/a91/77b60af767ca431ed521e55 /Users/andrewguy9/Downloads/myfarm/.farmfs/userdata/238/851/a91/77b60af767ca431ed521e55
Lets see whats in our new depot:
find *
1
1/2
1/2/3
1/2/3/4
1/2/3/4/5
1/2/3/4/5/v1
a
a/b
a/b/c
a/b/c/d
a/b/c/d/e
a/b/c/d/e/v1
Development:
Testing:
Regression Testing:
Regression tests can be run with pytest
Tests are kept in the tests
directory, which will be detected by pytest automatically
.
Performance Optimization:
Performance testing cases are stored under the perf
directory. These are useful for making development decions are not generally useful as ongoing tests.
To run a particular trial run:
pytest -s perf/your_test -k case_patter
.
Notice that the -s
is required to get a printout of the results.
Example: pytest -s perf/transducer.py -k transducers
Debugging
farmfs comes with a useful debugging tool farmdbg
.
farmdbg
Usage:
farmdbg reverse <csum>
farmdbg key read <key>
farmdbg key write <key> <value>
farmdbg key delete <key>
farmdbg key list [<key>]
farmdbg walk (keys|userdata|root|snap <snapshot>)
farmdbg checksum <path>...
farmdbg fix link <file> <target>
farmdbg rewrite-links <target>
farmdbg
can be used to dump parts of the keystore or blobstore, as well as walk and repair links.
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
Built Distributions
File details
Details for the file farmfs-0.7.10.tar.gz
.
File metadata
- Download URL: farmfs-0.7.10.tar.gz
- Upload date:
- Size: 21.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.23.0 setuptools/40.8.0 requests-toolbelt/0.9.1 tqdm/4.45.0 CPython/3.7.3
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 9322a891f4fefbbd9ef2d118882df49842b257726b3f3ba047109fcbcfca0570 |
|
MD5 | e91bc387e4321109bb5112e71185ab03 |
|
BLAKE2b-256 | e63599c9e8ea799ef80d4b67c1d3f9b1ca9b70a0a2a00ffadb9a3673a8241166 |
File details
Details for the file farmfs-0.7.10-py3.7.egg
.
File metadata
- Download URL: farmfs-0.7.10-py3.7.egg
- Upload date:
- Size: 50.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.23.0 setuptools/40.8.0 requests-toolbelt/0.9.1 tqdm/4.45.0 CPython/3.7.3
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 6d472290b2b114ab9d2b38b44480299263d4132c291b57095bc414c24315bcc4 |
|
MD5 | 50a9cdbecdb009a877fb6f28f647bfa5 |
|
BLAKE2b-256 | 218818efb4cd79289d08930ea5a528cd169cb898e80e2d27899479d9dcf64bbc |
File details
Details for the file farmfs-0.7.10-py3-none-any.whl
.
File metadata
- Download URL: farmfs-0.7.10-py3-none-any.whl
- Upload date:
- Size: 22.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.23.0 setuptools/40.8.0 requests-toolbelt/0.9.1 tqdm/4.45.0 CPython/3.7.3
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 5997a272b7cca480bd6b469ae565d20c941878e094630488567031de03a567e1 |
|
MD5 | 91ff8ec54a0a9ddb1711d46e1eb17bf6 |
|
BLAKE2b-256 | 113a41aa46af6e4a04ae4561e4cb632f6332af37c3ffcd49ddff35b6ecbc2899 |