caddy-log-exporter/vendor/github.com/tklauser/numcpus
2024-09-23 09:37:27 +02:00
..
.cirrus.yml tes: adds integration tests with testcontainers 2024-09-23 09:37:27 +02:00
LICENSE tes: adds integration tests with testcontainers 2024-09-23 09:37:27 +02:00
numcpus_bsd.go tes: adds integration tests with testcontainers 2024-09-23 09:37:27 +02:00
numcpus_linux.go tes: adds integration tests with testcontainers 2024-09-23 09:37:27 +02:00
numcpus_solaris.go tes: adds integration tests with testcontainers 2024-09-23 09:37:27 +02:00
numcpus_unsupported.go tes: adds integration tests with testcontainers 2024-09-23 09:37:27 +02:00
numcpus_windows.go tes: adds integration tests with testcontainers 2024-09-23 09:37:27 +02:00
numcpus.go tes: adds integration tests with testcontainers 2024-09-23 09:37:27 +02:00
README.md tes: adds integration tests with testcontainers 2024-09-23 09:37:27 +02:00

numcpus

Go Reference GitHub Action Status

Package numcpus provides information about the number of CPUs in the system.

It gets the number of CPUs (online, offline, present, possible, configured or kernel maximum) on Linux, Darwin, FreeBSD, NetBSD, OpenBSD, DragonflyBSD or Solaris/Illumos systems.

On Linux, the information is retrieved by reading the corresponding CPU topology files in /sys/devices/system/cpu.

On BSD systems, the information is retrieved using the hw.ncpu and hw.ncpuonline sysctls, if supported.

Not all functions are supported on Darwin, FreeBSD, NetBSD, OpenBSD, DragonflyBSD and Solaris/Illumos. ErrNotSupported is returned in case a function is not supported on a particular platform.

Usage

package main

import (
	"fmt"
	"os"

	"github.com/tklauser/numcpus"
)

func main() {
	online, err := numcpus.GetOnline()
	if err != nil {
		fmt.Fprintf(os.Stderr, "GetOnline: %v\n", err)
	}
	fmt.Printf("online CPUs: %v\n", online)

	possible, err := numcpus.GetPossible()
	if err != nil {
		fmt.Fprintf(os.Stderr, "GetPossible: %v\n", err)
	}
	fmt.Printf("possible CPUs: %v\n", possible)
}

References