.github
alerting
client
config
core
docs
example
jsonpath
k8s
k8stest
metric
pattern
security
static
vendor
cloud.google.com
github.com
beorn7
cespare
davecgh
gogo
golang
google
googleapis
imdario
json-iterator
matttproud
miekg
modern-go
prometheus
client_golang
client_model
common
procfs
internal
.gitignore
.golangci.yml
CONTRIBUTING.md
LICENSE
MAINTAINERS.md
Makefile
Makefile.common
NOTICE
README.md
arp.go
buddyinfo.go
cpuinfo.go
cpuinfo_arm.go
cpuinfo_arm64.go
cpuinfo_default.go
cpuinfo_mips.go
cpuinfo_mips64.go
cpuinfo_mips64le.go
cpuinfo_mipsle.go
cpuinfo_ppc64.go
cpuinfo_ppc64le.go
cpuinfo_s390x.go
crypto.go
doc.go
fixtures.ttar
fs.go
fscache.go
go.mod
go.sum
ipvs.go
kernel_random.go
loadavg.go
mdstat.go
meminfo.go
mountinfo.go
mountstats.go
net_conntrackstat.go
net_dev.go
net_sockstat.go
net_softnet.go
net_udp.go
net_unix.go
proc.go
proc_cgroup.go
proc_environ.go
proc_fdinfo.go
proc_io.go
proc_limits.go
proc_maps.go
proc_ns.go
proc_psi.go
proc_smaps.go
proc_stat.go
proc_status.go
schedstat.go
stat.go
swaps.go
ttar
vm.go
xfrm.go
zoneinfo.go
spf13
golang.org
google.golang.org
gopkg.in
k8s.io
sigs.k8s.io
modules.txt
watchdog
.dockerignore
.gitattributes
.gitignore
Dockerfile
LICENSE.md
README.md
config.yaml
go.mod
go.sum
gzip.go
main.go
63 lines
2.1 KiB
Go
63 lines
2.1 KiB
Go
// Copyright 2020 The Prometheus Authors
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
// you may not use this file except in compliance with the License.
|
|
// You may obtain a copy of the License at
|
|
//
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
//
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
// See the License for the specific language governing permissions and
|
|
// limitations under the License.
|
|
|
|
// +build !windows
|
|
|
|
package procfs
|
|
|
|
import (
|
|
"os"
|
|
|
|
"github.com/prometheus/procfs/internal/util"
|
|
)
|
|
|
|
// KernelRandom contains information about to the kernel's random number generator.
|
|
type KernelRandom struct {
|
|
// EntropyAvaliable gives the available entropy, in bits.
|
|
EntropyAvaliable *uint64
|
|
// PoolSize gives the size of the entropy pool, in bytes.
|
|
PoolSize *uint64
|
|
// URandomMinReseedSeconds is the number of seconds after which the DRNG will be reseeded.
|
|
URandomMinReseedSeconds *uint64
|
|
// WriteWakeupThreshold the number of bits of entropy below which we wake up processes
|
|
// that do a select(2) or poll(2) for write access to /dev/random.
|
|
WriteWakeupThreshold *uint64
|
|
// ReadWakeupThreshold is the number of bits of entropy required for waking up processes that sleep
|
|
// waiting for entropy from /dev/random.
|
|
ReadWakeupThreshold *uint64
|
|
}
|
|
|
|
// KernelRandom returns values from /proc/sys/kernel/random.
|
|
func (fs FS) KernelRandom() (KernelRandom, error) {
|
|
random := KernelRandom{}
|
|
|
|
for file, p := range map[string]**uint64{
|
|
"entropy_avail": &random.EntropyAvaliable,
|
|
"poolsize": &random.PoolSize,
|
|
"urandom_min_reseed_secs": &random.URandomMinReseedSeconds,
|
|
"write_wakeup_threshold": &random.WriteWakeupThreshold,
|
|
"read_wakeup_threshold": &random.ReadWakeupThreshold,
|
|
} {
|
|
val, err := util.ReadUintFromFile(fs.proc.Path("sys", "kernel", "random", file))
|
|
if os.IsNotExist(err) {
|
|
continue
|
|
}
|
|
if err != nil {
|
|
return random, err
|
|
}
|
|
*p = &val
|
|
}
|
|
|
|
return random, nil
|
|
}
|