fdlimit_windows.go 1.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748
  1. // Copyright 2018 The go-ethereum Authors
  2. // This file is part of the go-ethereum library.
  3. //
  4. // The go-ethereum library is free software: you can redistribute it and/or modify
  5. // it under the terms of the GNU Lesser General Public License as published by
  6. // the Free Software Foundation, either version 3 of the License, or
  7. // (at your option) any later version.
  8. //
  9. // The go-ethereum library is distributed in the hope that it will be useful,
  10. // but WITHOUT ANY WARRANTY; without even the implied warranty of
  11. // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  12. // GNU Lesser General Public License for more details.
  13. //
  14. // You should have received a copy of the GNU Lesser General Public License
  15. // along with the go-ethereum library. If not, see <http://www.gnu.org/licenses/>.
  16. package fdlimit
  17. import "errors"
  18. // Raise tries to maximize the file descriptor allowance of this process
  19. // to the maximum hard-limit allowed by the OS.
  20. func Raise(max uint64) error {
  21. // This method is NOP by design:
  22. // * Linux/Darwin counterparts need to manually increase per process limits
  23. // * On Windows Go uses the CreateFile API, which is limited to 16K files, non
  24. // changeable from within a running process
  25. // This way we can always "request" raising the limits, which will either have
  26. // or not have effect based on the platform we're running on.
  27. if max > 16384 {
  28. return errors.New("file descriptor limit (16384) reached")
  29. }
  30. return nil
  31. }
  32. // Current retrieves the number of file descriptors allowed to be opened by this
  33. // process.
  34. func Current() (int, error) {
  35. // Please see Raise for the reason why we use hard coded 16K as the limit
  36. return 16384, nil
  37. }
  38. // Maximum retrieves the maximum number of file descriptors this process is
  39. // allowed to request for itself.
  40. func Maximum() (int, error) {
  41. return Current()
  42. }