Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/remram44/cowblock
Block-level copy-on-write tool
https://github.com/remram44/cowblock
copy-on-write data-management filesystem fuse rust
Last synced: about 2 months ago
JSON representation
Block-level copy-on-write tool
- Host: GitHub
- URL: https://github.com/remram44/cowblock
- Owner: remram44
- Created: 2022-09-12T03:01:41.000Z (over 2 years ago)
- Default Branch: trunk
- Last Pushed: 2023-06-05T03:58:48.000Z (over 1 year ago)
- Last Synced: 2024-10-04T13:38:56.273Z (3 months ago)
- Topics: copy-on-write, data-management, filesystem, fuse, rust
- Language: Rust
- Homepage:
- Size: 42 KB
- Stars: 17
- Watchers: 2
- Forks: 1
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
Block-Level Copy-on-Write
=========================What is this?
-------------This is a little tool allowing you to make changes to a big file without affecting the original, and without making an entire copy either.
It is implemented as a filesystem in userspace that keeps track of changes to the blocks of a file.
For example, if you have a big database or virtual hard drive and you want to make changes but keep the original; you can use this tool to create a copy of the file:
```
$ touch virtual_copy.db
$ cowblock original.db virtual_copy.db &
$ sqlite3 virtual_copy.db
# Make changes here
# The changes are visible in virtual_copy.db,
# but no change is made to original.db
# The changed blocks are stored in virtual_copy.db-diff and virtual_copy.db-extra,
# which are much smaller files
$ fusermount -u virtual_copy.db
```Why?
----There are options for copy-on-write filesystems, however they are quite limited:
* Tools like unionfs-fuse, aufs, and overlayfs do copy-on-write for filesystems, but copy whole files when you need to write to them. There is no way to copy part of a big file without makine a copy of it.
* Filesystems like btrfs or zfs offer copy-on-write (with `cp --reflink`), but you need to be using that filesystem to benefit from it.
* You can abuse devicemapper to do this but it is pretty difficult (and you'll get devices rather than regular files)How?
----The diff file contains an index at the start, indicating where the blocks of the file can be found in the diff. Blocks that haven't been overwritten yet are 0, while other numbers are the index of the block in the diff file.
The index is checked before every block read to determine whether we should read from the original or the diff.