Merge pull request #787 from runcom/max-threads

server: set golang runtime max threads
This commit is contained in:
Mrunal Patel 2017-08-24 10:27:34 -07:00 committed by GitHub
commit a38419af88

View file

@ -8,6 +8,9 @@ import (
"net/http" "net/http"
"os" "os"
"path/filepath" "path/filepath"
"runtime/debug"
"strconv"
"strings"
"sync" "sync"
"github.com/fsnotify/fsnotify" "github.com/fsnotify/fsnotify"
@ -145,6 +148,23 @@ func (s *Server) Shutdown() error {
return s.ContainerServer.Shutdown() return s.ContainerServer.Shutdown()
} }
// configureMaxThreads sets the Go runtime max threads threshold
// which is 90% of the kernel setting from /proc/sys/kernel/threads-max
func configureMaxThreads() error {
mt, err := ioutil.ReadFile("/proc/sys/kernel/threads-max")
if err != nil {
return err
}
mtint, err := strconv.Atoi(strings.TrimSpace(string(mt)))
if err != nil {
return err
}
maxThreads := (mtint / 100) * 90
debug.SetMaxThreads(maxThreads)
logrus.Debugf("Golang's threads limit set to %d", maxThreads)
return nil
}
// New creates a new Server with options provided // New creates a new Server with options provided
func New(config *Config) (*Server, error) { func New(config *Config) (*Server, error) {
if err := os.MkdirAll("/var/run/crio", 0755); err != nil { if err := os.MkdirAll("/var/run/crio", 0755); err != nil {
@ -199,6 +219,10 @@ func New(config *Config) (*Server, error) {
} }
} }
if err := configureMaxThreads(); err != nil {
return nil, err
}
s.restore() s.restore()
s.cleanupSandboxesOnShutdown() s.cleanupSandboxesOnShutdown()