less blocking on fact reading (#73951)

* less blocking on fact reading


Co-authored-by: Martin Krizek <martin.krizek@gmail.com>
pull/74011/head
Brian Coca 4 years ago committed by GitHub
parent 2bff120db6
commit 232eeee206
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

@ -0,0 +1,2 @@
bugfixes:
- Try to avoid kernel 'blocking' state on reading files while fact gathering.

@ -16,26 +16,47 @@
from __future__ import (absolute_import, division, print_function)
__metaclass__ = type
import fcntl
import os
def get_file_content(path, default=None, strip=True):
'''
Return the contents of a given file path
:args path: path to file to return contents from
:args default: value to return if we could not read file
:args strip: controls if we strip whitespace from the result or not
:returns: String with file contents (optionally stripped) or 'default' value
'''
data = default
if os.path.exists(path) and os.access(path, os.R_OK):
try:
datafile = open(path)
try:
datafile = open(path)
data = datafile.read()
if strip:
data = data.strip()
if len(data) == 0:
data = default
finally:
datafile.close()
# try to not enter kernel 'block' mode, which prevents timeouts
fd = datafile.fileno()
flag = fcntl.fcntl(fd, fcntl.F_GETFL)
fcntl.fcntl(fd, fcntl.F_SETFL, flag | os.O_NONBLOCK)
except Exception:
pass # not required to operate, but would have been nice!
# actually read the data
data = datafile.read()
if strip:
data = data.strip()
if len(data) == 0:
data = default
except Exception:
# ignore errors as some jails/containers might have readable permissions but not allow reads to proc
# done in 2 blocks for 2.4 compat
# ignore errors as some jails/containers might have readable permissions but not allow reads
pass
finally:
datafile.close()
return data

Loading…
Cancel
Save