fdlimit_windows.go 1.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950
  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 "fmt"
  18. // hardlimit is the number of file descriptors allowed at max by the kernel.
  19. const hardlimit = 16384
  20. // Raise tries to maximize the file descriptor allowance of this process
  21. // to the maximum hard-limit allowed by the OS.
  22. func Raise(max uint64) (uint64, error) {
  23. // This method is NOP by design:
  24. // * Linux/Darwin counterparts need to manually increase per process limits
  25. // * On Windows Go uses the CreateFile API, which is limited to 16K files, non
  26. // changeable from within a running process
  27. // This way we can always "request" raising the limits, which will either have
  28. // or not have effect based on the platform we're running on.
  29. if max > hardlimit {
  30. return hardlimit, fmt.Errorf("file descriptor limit (%d) reached", hardlimit)
  31. }
  32. return max, nil
  33. }
  34. // Current retrieves the number of file descriptors allowed to be opened by this
  35. // process.
  36. func Current() (int, error) {
  37. // Please see Raise for the reason why we use hard coded 16K as the limit
  38. return hardlimit, nil
  39. }
  40. // Maximum retrieves the maximum number of file descriptors this process is
  41. // allowed to request for itself.
  42. func Maximum() (int, error) {
  43. return Current()
  44. }