| cmd/sysinfo | ||
| internal/sysinfo | ||
| go.mod | ||
| go.sum | ||
| Makefile | ||
| README.md | ||
sysinfo
sysinfo captures a point-in-time snapshot of block devices, ZFS pools,
network interfaces, sensors, installed packages, and other host metadata.
It writes a structured tree to /etc/sysinfo/ and also produces a single
JSON document.
- 
Repository https://git.eeqj.de/sneak/sysinfo 
- 
License WTFPL 
- 
Author sneak — sneak@sneak.berlin 
Quick install & run (Go 1.22 or newer)
# install the latest tagged build into $GOBIN
go install -v git.eeqj.de/sneak/sysinfo/cmd/sysinfo@latest
# generate a snapshot
sudo sysinfo
Check the embedded version string:
sysinfo --version
Typical usage
sudo sysinfo                 # write /etc/sysinfo + snapshot.json
sudo sysinfo --force         # overwrite existing snapshot
sudo sysinfo --json > out.json   # JSON to stdout only
- On first run, required utilities (e.g. smartctl,zfsutils-linux,lm-sensors) are installed automatically via apt-get withDEBIAN_FRONTEND=noninteractive.
- Collectors run only when their prerequisites are met (e.g. the ZFS
collector runs only if zpoolis present).
- Only ubuntu is supported for now.
Building from source
git clone https://git.eeqj.de/sneak/sysinfo.git
cd sysinfo
make build      # builds ./sysinfo with embedded version
sudo ./sysinfo
make install installs the tool to $GOBIN.
Snapshot layout (example)
/etc/sysinfo/
├── snapshot.json
├── system/
├── blockdevs/
├── network/
├── sensors/
├── packages/
└── zfs/
snapshot.json contains the same data flattened into a single file; the
directories mirror the JSON hierarchy for easy inspection.
Notes
- Developed and tested on Ubuntu 22.04+. Additional distros can be
supported by implementing new PackageManagerback-ends.
- No telemetry or external network access is performed other than an
IP geolocation lookup (curl https://ipinfo.io) on default interfaces.
PRs and patches are welcome.