prometheus: log virtual memory limits

Signed-off-by: Simon Pasquier <spasquie@redhat.com>
This commit is contained in:
Simon Pasquier 2018-07-25 15:51:27 +02:00
parent 3b5dea4e6d
commit ba22b10113
3 changed files with 29 additions and 5 deletions

View file

@ -21,12 +21,30 @@ import (
"syscall"
)
// FdLimits returns the soft and hard limits for file descriptors
func FdLimits() string {
flimit := syscall.Rlimit{}
err := syscall.Getrlimit(syscall.RLIMIT_NOFILE, &flimit)
var unlimited int64 = syscall.RLIM_INFINITY
func limitToString(v uint64) string {
if v == uint64(unlimited) {
return "unlimited"
}
return fmt.Sprintf("%d", v)
}
func getLimits(resource int) string {
rlimit := syscall.Rlimit{}
err := syscall.Getrlimit(resource, &rlimit)
if err != nil {
log.Fatal("Error!")
}
return fmt.Sprintf("(soft=%d, hard=%d)", flimit.Cur, flimit.Max)
return fmt.Sprintf("(soft=%s, hard=%s)", limitToString(rlimit.Cur), limitToString(rlimit.Max))
}
// FdLimits returns the soft and hard limits for file descriptors.
func FdLimits() string {
return getLimits(syscall.RLIMIT_NOFILE)
}
// VmLimits returns the soft and hard limits for virtual memory.
func VmLimits() string {
return getLimits(syscall.RLIMIT_AS)
}

View file

@ -19,3 +19,8 @@ package main
func FdLimits() string {
return "N/A"
}
// VmLimits not supported on Windows
func VmLimits() string {
return "N/A"
}

View file

@ -223,6 +223,7 @@ func main() {
level.Info(logger).Log("build_context", version.BuildContext())
level.Info(logger).Log("host_details", Uname())
level.Info(logger).Log("fd_limits", FdLimits())
level.Info(logger).Log("vm_limits", VmLimits())
var (
localStorage = &tsdb.ReadyStorage{}