aboutsummaryrefslogtreecommitdiffstats
path: root/common/fdlimit/fdlimit_unix.go
diff options
context:
space:
mode:
authorMartin Holst Swende <martin@swende.se>2019-02-12 18:29:05 +0800
committerPéter Szilágyi <peterke@gmail.com>2019-02-19 16:57:49 +0800
commit048b463b301b1ac61be187d7195665d4ad31f51f (patch)
tree88d6920fafd764c1a9a879d4dca04fadfb2239d7 /common/fdlimit/fdlimit_unix.go
parent9f5fb15097198ea20aaae31983a7101ac0679eaa (diff)
downloadgo-tangerine-048b463b301b1ac61be187d7195665d4ad31f51f.tar
go-tangerine-048b463b301b1ac61be187d7195665d4ad31f51f.tar.gz
go-tangerine-048b463b301b1ac61be187d7195665d4ad31f51f.tar.bz2
go-tangerine-048b463b301b1ac61be187d7195665d4ad31f51f.tar.lz
go-tangerine-048b463b301b1ac61be187d7195665d4ad31f51f.tar.xz
go-tangerine-048b463b301b1ac61be187d7195665d4ad31f51f.tar.zst
go-tangerine-048b463b301b1ac61be187d7195665d4ad31f51f.zip
common/fdlimit: cap on MacOS file limits, fixes #18994 (#19035)
* common/fdlimit: cap on MacOS file limits, fixes #18994 * common/fdlimit: fix Maximum-check to respect OPEN_MAX * common/fdlimit: return error if OPEN_MAX is exceeded in Raise() * common/fdlimit: goimports * common/fdlimit: check value after setting fdlimit * common/fdlimit: make comment a bit more descriptive * cmd/utils: make fdlimit happy path a bit cleaner (cherry picked from commit f48da43bae183a04a23d298cb1790d2f8d2cec51)
Diffstat (limited to 'common/fdlimit/fdlimit_unix.go')
-rw-r--r--common/fdlimit/fdlimit_unix.go13
1 files changed, 9 insertions, 4 deletions
diff --git a/common/fdlimit/fdlimit_unix.go b/common/fdlimit/fdlimit_unix.go
index a25813235..670112751 100644
--- a/common/fdlimit/fdlimit_unix.go
+++ b/common/fdlimit/fdlimit_unix.go
@@ -22,11 +22,12 @@ import "syscall"
// Raise tries to maximize the file descriptor allowance of this process
// to the maximum hard-limit allowed by the OS.
-func Raise(max uint64) error {
+// Returns the size it was set to (may differ from the desired 'max')
+func Raise(max uint64) (uint64, error) {
// Get the current limit
var limit syscall.Rlimit
if err := syscall.Getrlimit(syscall.RLIMIT_NOFILE, &limit); err != nil {
- return err
+ return 0, err
}
// Try to update the limit to the max allowance
limit.Cur = limit.Max
@@ -34,9 +35,13 @@ func Raise(max uint64) error {
limit.Cur = max
}
if err := syscall.Setrlimit(syscall.RLIMIT_NOFILE, &limit); err != nil {
- return err
+ return 0, err
+ }
+ // MacOS can silently apply further caps, so retrieve the actually set limit
+ if err := syscall.Getrlimit(syscall.RLIMIT_NOFILE, &limit); err != nil {
+ return 0, err
}
- return nil
+ return limit.Cur, nil
}
// Current retrieves the number of file descriptors allowed to be opened by this