podman-build/vendor/github.com/mistifyio/go-zfs/v3
2025-10-11 12:30:35 +09:00
..
.envrc First commit for v5.6.2 2025-10-11 12:30:35 +09:00
.gitignore First commit for v5.6.2 2025-10-11 12:30:35 +09:00
.golangci.yml First commit for v5.6.2 2025-10-11 12:30:35 +09:00
.yamllint First commit for v5.6.2 2025-10-11 12:30:35 +09:00
CHANGELOG.md First commit for v5.6.2 2025-10-11 12:30:35 +09:00
CONTRIBUTING.md First commit for v5.6.2 2025-10-11 12:30:35 +09:00
error.go First commit for v5.6.2 2025-10-11 12:30:35 +09:00
LICENSE First commit for v5.6.2 2025-10-11 12:30:35 +09:00
lint.mk First commit for v5.6.2 2025-10-11 12:30:35 +09:00
Makefile First commit for v5.6.2 2025-10-11 12:30:35 +09:00
README.md First commit for v5.6.2 2025-10-11 12:30:35 +09:00
rules.mk First commit for v5.6.2 2025-10-11 12:30:35 +09:00
shell.nix First commit for v5.6.2 2025-10-11 12:30:35 +09:00
utils_notsolaris.go First commit for v5.6.2 2025-10-11 12:30:35 +09:00
utils_solaris.go First commit for v5.6.2 2025-10-11 12:30:35 +09:00
utils.go First commit for v5.6.2 2025-10-11 12:30:35 +09:00
Vagrantfile First commit for v5.6.2 2025-10-11 12:30:35 +09:00
zfs.go First commit for v5.6.2 2025-10-11 12:30:35 +09:00
zpool.go First commit for v5.6.2 2025-10-11 12:30:35 +09:00

Go Wrapper for ZFS

Simple wrappers for ZFS command line tools.

GoDoc

Requirements

You need a working ZFS setup. To use on Ubuntu 14.04, setup ZFS:

sudo apt-get install python-software-properties
sudo apt-add-repository ppa:zfs-native/stable
sudo apt-get update
sudo apt-get install ubuntu-zfs libzfs-dev

Developed using Go 1.3, but currently there isn't anything 1.3 specific. Don't use Ubuntu packages for Go, use http://golang.org/doc/install

Generally you need root privileges to use anything zfs related.

Status

This has been only been tested on Ubuntu 14.04

In the future, we hope to work directly with libzfs.

Hacking

The tests have decent examples for most functions.

//assuming a zpool named test
//error handling omitted


f, err := zfs.CreateFilesystem("test/snapshot-test", nil)
ok(t, err)

s, err := f.Snapshot("test", nil)
ok(t, err)

// snapshot is named "test/snapshot-test@test"

c, err := s.Clone("test/clone-test", nil)

err := c.Destroy()
err := s.Destroy()
err := f.Destroy()

Contributing

See the contributing guidelines