2016-01-20 19:19:15 -08:00
# procfs
This procfs package provides functions to retrieve system, kernel and process
2019-05-31 09:30:37 -07:00
metrics from the pseudo-filesystems /proc and /sys.
2016-01-20 19:19:15 -08:00
*WARNING*: This package is a work in progress. Its API may still break in
backwards-incompatible ways without warnings. Use it at your own risk.
[![GoDoc ](https://godoc.org/github.com/prometheus/procfs?status.png )](https://godoc.org/github.com/prometheus/procfs)
[![Build Status ](https://travis-ci.org/prometheus/procfs.svg?branch=master )](https://travis-ci.org/prometheus/procfs)
2017-02-14 08:04:28 -08:00
[![Go Report Card ](https://goreportcard.com/badge/github.com/prometheus/procfs )](https://goreportcard.com/report/github.com/prometheus/procfs)
2019-05-31 09:30:37 -07:00
## Usage
The procfs library is organized by packages based on whether the gathered data is coming from
/proc, /sys, or both. Each package contains an `FS` type which represents the path to either /proc, /sys, or both. For example, current cpu statistics are gathered from
`/proc/stat` and are available via the root procfs package. First, the proc filesystem mount
point is initialized, and then the stat information is read.
```go
fs, err := procfs.NewFS("/proc")
2019-06-12 11:47:16 -07:00
stats, err := fs.Stat()
```
Some sub-packages such as `blockdevice` , require access to both the proc and sys filesystems.
```go
fs, err := blockdevice.NewFS("/proc", "/sys")
stats, err := fs.ProcDiskstats()
2019-05-31 09:30:37 -07:00
```
## Building and Testing
The procfs library is normally built as part of another application. However, when making
changes to the library, the `make test` command can be used to run the API test suite.
### Updating Test Fixtures
The procfs library includes a set of test fixtures which include many example files from
2019-06-12 11:47:16 -07:00
the `/proc` and `/sys` filesystems. These fixtures are included as a [ttar ](https://github.com/ideaship/ttar ) file
2019-05-31 09:30:37 -07:00
which is extracted automatically during testing. To add/update the test fixtures, first
ensure the `fixtures` directory is up to date by removing the existing directory and then
extracting the ttar file using `make fixtures/.unpacked` or just `make test` .
```bash
rm -rf fixtures
make test
```
Next, make the required changes to the extracted files in the `fixtures` directory. When
the changes are complete, run `make update_fixtures` to create a new `fixtures.ttar` file
based on the updated `fixtures` directory. And finally, verify the changes using
`git diff fixtures.ttar` .