Log file descriptor limits at startup (#3567)

Fixes #3564
This commit is contained in:
pasquier-s 2017-12-11 14:01:53 +01:00 committed by Brian Brazil
parent 838fc5a4d1
commit 2440696961
3 changed files with 54 additions and 0 deletions

View file

@ -0,0 +1,32 @@
// Copyright 2017 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 main
import (
"fmt"
"log"
"syscall"
)
// FdLimits returns the soft and hard limits for file descriptors
func FdLimits() string {
flimit := syscall.Rlimit{}
err := syscall.Getrlimit(syscall.RLIMIT_NOFILE, &flimit)
if err != nil {
log.Fatal("Error!")
}
return fmt.Sprintf("(soft=%d, hard=%d)", flimit.Cur, flimit.Max)
}

View file

@ -0,0 +1,21 @@
// Copyright 2017 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 main
// FdLimits not supported on Windows
func FdLimits() string {
return "N/A"
}

View file

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