sysinfo

package module
v1.14.0 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Apr 5, 2024 License: Apache-2.0 Imports: 7 Imported by: 1,104

README

go-sysinfo

go Go Documentation

go-sysinfo is a library for collecting system information. This includes information about the host machine and processes running on the host.

The available features vary based on what has been implemented by the "provider" for the operating system. At runtime you check to see if additional interfaces are implemented by the returned Host or Process. For example:

process, err := sysinfo.Self()
if err != nil {
	return err
}

if handleCounter, ok := process.(types.OpenHandleCounter); ok {
	count, err := handleCounter.OpenHandleCount()
	if err != nil {
		return err
	}
	log.Printf("%d open handles", count)
}

These tables show what methods are implemented as well as the extra interfaces that are implemented.

Host Features Darwin Linux Windows AIX
Info() x x x x
Memory() x x x x
CPUTimer x x x x
LoadAverage x x
VMStat x
NetworkCounters x
Process Features Darwin Linux Windows AIX
Info() x x x x
Memory() x x x x
User() x x x x
Parent() x x x x
CPUTimer x x x x
Environment x x x
OpenHandleEnumerator x
OpenHandleCounter x
Seccomp x
Capabilities x
NetworkCounters x
GOOS / GOARCH Pairs

This table lists the OS and architectures for which a "provider" is implemented.

GOOS / GOARCH Requires CGO Tested
aix/ppc64 x
darwin/amd64 optional * x
darwin/arm64 optional * x
linux/386
linux/amd64 x
linux/arm
linux/arm64
linux/mips
linux/mips64
linux/mips64le
linux/mipsle
linux/ppc64
linux/ppc64le
linux/riscv64
linux/s390x
windows/amd64 x
windows/arm64
windows/arm
  • On darwin (macOS) host information like machineid and process information like memory, cpu, user and starttime require cgo.
Supported Go versions

go-sysinfo supports the two most recent Go releases.

Documentation

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

func Go

func Go() types.GoInfo

Go returns information about the Go runtime.

func Host

func Host() (types.Host, error)

Host returns information about host on which this process is running. If host information collection is not implemented for this platform then types.ErrNotImplemented is returned. On Darwin (macOS) a types.ErrNotImplemented is returned with cgo disabled.

func Process

func Process(pid int) (types.Process, error)

Process returns a types.Process object representing the process associated with the given PID. The types.Process object can be used to query information about the process. If process information collection is not implemented for this platform then types.ErrNotImplemented is returned.

func Processes

func Processes() ([]types.Process, error)

Processes return a list of all processes. If process information collection is not implemented for this platform then types.ErrNotImplemented is returned.

func Self

func Self() (types.Process, error)

Self return a types.Process object representing this process. If process information collection is not implemented for this platform then types.ErrNotImplemented is returned.

Types

This section is empty.

Directories

Path Synopsis
internal
providers
aix
Package aix implements the HostProvider and ProcessProvider interfaces for providing information about IBM AIX on ppc64.
Package aix implements the HostProvider and ProcessProvider interfaces for providing information about IBM AIX on ppc64.
darwin
Package darwin implements the HostProvider and ProcessProvider interfaces for providing information about MacOS.
Package darwin implements the HostProvider and ProcessProvider interfaces for providing information about MacOS.
linux
Package linux implements the HostProvider and ProcessProvider interfaces for providing information about Linux.
Package linux implements the HostProvider and ProcessProvider interfaces for providing information about Linux.
windows
Package windows implements the HostProvider and ProcessProvider interfaces for providing information about Windows.
Package windows implements the HostProvider and ProcessProvider interfaces for providing information about Windows.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL