2019-11-28 16:41:55 +01:00
|
|
|
From e27ccce1429fa604137df35d8dabbc8016c2b5c9 Mon Sep 17 00:00:00 2001
|
2019-04-26 12:09:06 +02:00
|
|
|
From: =?UTF-8?q?Pablo=20Su=C3=A1rez=20Hern=C3=A1ndez?=
|
|
|
|
<psuarezhernandez@suse.com>
|
|
|
|
Date: Fri, 12 Apr 2019 16:47:03 +0100
|
2019-11-28 16:41:55 +01:00
|
|
|
Subject: [PATCH] Calculate FQDNs in parallel to avoid blockings
|
|
|
|
(bsc#1129079)
|
2019-04-26 12:09:06 +02:00
|
|
|
|
|
|
|
Fix pylint issue
|
|
|
|
---
|
|
|
|
salt/grains/core.py | 31 ++++++++++++++++++++++++++-----
|
|
|
|
1 file changed, 26 insertions(+), 5 deletions(-)
|
|
|
|
|
|
|
|
diff --git a/salt/grains/core.py b/salt/grains/core.py
|
2019-11-28 16:41:55 +01:00
|
|
|
index 7d75d48bb5..ac66a437fd 100644
|
2019-04-26 12:09:06 +02:00
|
|
|
--- a/salt/grains/core.py
|
|
|
|
+++ b/salt/grains/core.py
|
2019-11-28 16:41:55 +01:00
|
|
|
@@ -20,12 +20,15 @@ import platform
|
2019-04-26 12:09:06 +02:00
|
|
|
import logging
|
|
|
|
import locale
|
|
|
|
import uuid
|
|
|
|
+import time
|
|
|
|
import zlib
|
|
|
|
from errno import EACCES, EPERM
|
|
|
|
import datetime
|
|
|
|
import warnings
|
2019-11-28 16:41:55 +01:00
|
|
|
import time
|
2019-04-26 12:09:06 +02:00
|
|
|
|
|
|
|
+from multiprocessing.dummy import Pool as ThreadPool
|
|
|
|
+
|
|
|
|
# pylint: disable=import-error
|
|
|
|
try:
|
|
|
|
import dateutil.tz
|
2019-11-28 16:41:55 +01:00
|
|
|
@@ -2255,13 +2258,10 @@ def fqdns():
|
2019-04-26 12:09:06 +02:00
|
|
|
grains = {}
|
|
|
|
fqdns = set()
|
|
|
|
|
|
|
|
- addresses = salt.utils.network.ip_addrs(include_loopback=False, interface_data=_get_interfaces())
|
|
|
|
- addresses.extend(salt.utils.network.ip_addrs6(include_loopback=False, interface_data=_get_interfaces()))
|
|
|
|
- err_message = 'Exception during resolving address: %s'
|
|
|
|
- for ip in addresses:
|
|
|
|
+ def _lookup_fqdn(ip):
|
|
|
|
try:
|
|
|
|
name, aliaslist, addresslist = socket.gethostbyaddr(ip)
|
|
|
|
- fqdns.update([socket.getfqdn(name)] + [als for als in aliaslist if salt.utils.network.is_fqdn(als)])
|
|
|
|
+ return [socket.getfqdn(name)] + [als for als in aliaslist if salt.utils.network.is_fqdn(als)]
|
|
|
|
except socket.herror as err:
|
|
|
|
if err.errno == 0:
|
|
|
|
# No FQDN for this IP address, so we don't need to know this all the time.
|
2019-11-28 16:41:55 +01:00
|
|
|
@@ -2271,6 +2271,27 @@ def fqdns():
|
2019-04-26 12:09:06 +02:00
|
|
|
except (socket.error, socket.gaierror, socket.timeout) as err:
|
2019-11-28 16:41:55 +01:00
|
|
|
log.error(err_message, ip, err)
|
2019-04-26 12:09:06 +02:00
|
|
|
|
|
|
|
+ start = time.time()
|
|
|
|
+
|
|
|
|
+ addresses = salt.utils.network.ip_addrs(include_loopback=False, interface_data=_get_interfaces())
|
|
|
|
+ addresses.extend(salt.utils.network.ip_addrs6(include_loopback=False, interface_data=_get_interfaces()))
|
|
|
|
+ err_message = 'Exception during resolving address: %s'
|
|
|
|
+
|
|
|
|
+ # Create a ThreadPool to process the underlying calls to 'socket.gethostbyaddr' in parallel.
|
|
|
|
+ # This avoid blocking the execution when the "fqdn" is not defined for certains IP addresses, which was causing
|
|
|
|
+ # that "socket.timeout" was reached multiple times secuencially, blocking execution for several seconds.
|
|
|
|
+ pool = ThreadPool(8)
|
|
|
|
+ results = pool.map(_lookup_fqdn, addresses)
|
|
|
|
+ pool.close()
|
|
|
|
+ pool.join()
|
|
|
|
+
|
|
|
|
+ for item in results:
|
|
|
|
+ if item:
|
|
|
|
+ fqdns.update(item)
|
|
|
|
+
|
|
|
|
+ elapsed = time.time() - start
|
|
|
|
+ log.debug('Elapsed time getting FQDNs: {} seconds'.format(elapsed))
|
|
|
|
+
|
|
|
|
return {"fqdns": sorted(list(fqdns))}
|
|
|
|
|
|
|
|
|
|
|
|
--
|
2019-11-28 16:41:55 +01:00
|
|
|
2.16.4
|
|
|
|
|
2019-04-26 12:09:06 +02:00
|
|
|
|