2017-04-14 01:40:49 +02:00
|
|
|
# zrepl
|
2017-09-24 13:42:04 +02:00
|
|
|
zrepl is a ZFS filesystem backup & replication solution written in Go.
|
|
|
|
|
|
|
|
## User Documentation
|
|
|
|
|
2017-11-16 21:48:21 +01:00
|
|
|
**User Documentation** can be found at [zrepl.github.io](https://zrepl.github.io).
|
2017-09-24 13:42:04 +02:00
|
|
|
|
|
|
|
## Bug Reports
|
|
|
|
|
|
|
|
1. If the issue is reproducible, enable debug logging, reproduce and capture the log.
|
|
|
|
2. Open an issue on GitHub, with logs pasted as GitHub gists / inline.
|
|
|
|
|
|
|
|
## Feature Requests
|
|
|
|
|
|
|
|
1. Does you feature request require default values / some kind of configuration?
|
|
|
|
If so, think of an expressive configuration example.
|
|
|
|
2. Think of at least one use case that generalizes from your concrete application.
|
|
|
|
3. Open an issue on GitHub with example conf & use case attached.
|
|
|
|
|
|
|
|
The above does not apply if you already implemented everything.
|
|
|
|
Check out the *Coding Workflow* section below for details.
|
|
|
|
|
|
|
|
## Developer Documentation
|
|
|
|
|
|
|
|
### Overall Architecture
|
|
|
|
|
|
|
|
The application architecture is documented as part of the user docs in the *Implementation* section (`docs/content/impl`).
|
|
|
|
Make sure to develop an understanding how zrepl is typically used by studying the user docs first.
|
|
|
|
|
|
|
|
### Project Structure
|
|
|
|
|
|
|
|
```
|
|
|
|
├── cmd
|
|
|
|
│ ├── sampleconf # example configuration
|
2017-11-11 23:19:58 +01:00
|
|
|
├── docs # sphinx-based documentation
|
|
|
|
│ ├── **/*.rst # documentation in reStructuredText
|
|
|
|
│ ├── conf.py # sphinx configuration
|
|
|
|
│ ├── publish.sh # shell script for automated rendering & deploy to zrepl.github.io repo
|
|
|
|
│ ├── public_git # checkout of zrepl.github.io used by above shell script
|
2017-09-24 13:42:04 +02:00
|
|
|
├── jobrun # OBSOLETE
|
|
|
|
├── logger # logger package used by zrepl
|
|
|
|
├── rpc # rpc protocol implementation
|
|
|
|
├── scratchpad # small example programs demoing some internal packages. probably OBSOLETE
|
|
|
|
├── sshbytestream # io.ReadWriteCloser over SSH
|
|
|
|
├── util
|
|
|
|
└── zfs # ZFS wrappers, filesystemm diffing
|
|
|
|
```
|
|
|
|
|
|
|
|
### Coding Workflow
|
|
|
|
|
|
|
|
* Open an issue when starting to hack on a new feature
|
|
|
|
* Commits should reference the issue they are related to
|
|
|
|
* Docs improvements not documenting new features do not require an issue.
|
2017-10-05 21:56:37 +02:00
|
|
|
|
2017-11-12 14:10:16 +01:00
|
|
|
### Breaking Changes
|
|
|
|
|
|
|
|
Backward-incompatible changes must be documented in the git commit message and are listed in `docs/changelog.rst`.
|
|
|
|
|
|
|
|
* Config-breaking changes must contain a line `BREAK CONFIG` in the commit message
|
|
|
|
* Other breaking changes must contain a line `BREAK` in the commit message
|
|
|
|
|
2017-10-05 21:56:37 +02:00
|
|
|
### Glossary & Naming Inconsistencies
|
|
|
|
|
|
|
|
In ZFS, *dataset* refers to the objects *filesystem*, *ZVOL* and *snapshot*. <br />
|
|
|
|
However, we need a word for *filesystem* & *ZVOL* but not a snapshot, bookmark, etc.
|
|
|
|
|
|
|
|
Toward the user, the following terminology is used:
|
|
|
|
|
|
|
|
* **filesystem**: a ZFS filesystem or a ZVOL
|
|
|
|
* **filesystem version**: a ZFS snapshot or a bookmark
|
|
|
|
|
|
|
|
Sadly, the zrepl implementation is inconsistent in its use of these words:
|
|
|
|
variables and types are often named *dataset* when they in fact refer to a *filesystem*.
|
|
|
|
|
|
|
|
There will not be a big refactoring (an attempt was made, but it's destroying too much history without much gain).
|
|
|
|
|
|
|
|
However, new contributions & patches should fix naming without further notice in the commit message.
|
2017-11-11 23:32:21 +01:00
|
|
|
|
|
|
|
### Building `docs`
|
|
|
|
|
|
|
|
```
|
|
|
|
cd docs
|
|
|
|
pip install sphinx sphinx-rtd-theme
|
|
|
|
make clean html
|
|
|
|
xdg-open _build/html/index.html
|
|
|
|
```
|