Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
In case maximum number of open files limit is set too high, both luaext/Pexec() and lib/doScriptExec() spend way too much time trying to set FD_CLOEXEC flag for all those file descriptors, resulting in severe increase of time it takes to execute say rpm or dnf. This becomes increasingly noticeable when running with e.g. under Docker, the reason being: > $ docker run fedora ulimit -n > 1048576 One obvious fix is to use procfs to get the actual list of opened fds and iterate over it. My quick-n-dirty benchmark shows the /proc approach is about 10x faster than iterating through a list of just 1024 fds, so it's an improvement even for default ulimit values. Note that the old method is still used in case /proc is not available. While at it, 1. fix the function by making sure we modify (rather than set) the existing flags. As the only known flag is FD_CLOEXEC, this change is currently purely aesthetical, but in case other flags will appear it will become a real bug fix. 2. get rid of magic number 3; use STDERR_FILENO Signed-off-by: Kir Kolyshkin <kolyshkin@gmail.com> Fixes #444
- Loading branch information