|
@@ -1,6 +1,9 @@
|
|
|
# pylint: disable=missing-docstring
|
|
|
from openshift_checks import OpenShiftCheck, get_var
|
|
|
|
|
|
+MIB = 2**20
|
|
|
+GIB = 2**30
|
|
|
+
|
|
|
|
|
|
class MemoryAvailability(OpenShiftCheck):
|
|
|
"""Check that recommended memory is available."""
|
|
@@ -11,10 +14,12 @@ class MemoryAvailability(OpenShiftCheck):
|
|
|
# Values taken from the official installation documentation:
|
|
|
# https://docs.openshift.org/latest/install_config/install/prerequisites.html#system-requirements
|
|
|
recommended_memory_bytes = {
|
|
|
- "masters": 16 * 10**9,
|
|
|
- "nodes": 8 * 10**9,
|
|
|
- "etcd": 8 * 10**9,
|
|
|
+ "masters": 16 * GIB,
|
|
|
+ "nodes": 8 * GIB,
|
|
|
+ "etcd": 8 * GIB,
|
|
|
}
|
|
|
+ # https://access.redhat.com/solutions/3006511 physical RAM is partly reserved from memtotal
|
|
|
+ memtotal_adjustment = 1 * GIB
|
|
|
|
|
|
@classmethod
|
|
|
def is_active(cls, task_vars):
|
|
@@ -25,21 +30,21 @@ class MemoryAvailability(OpenShiftCheck):
|
|
|
|
|
|
def run(self, tmp, task_vars):
|
|
|
group_names = get_var(task_vars, "group_names")
|
|
|
- total_memory_bytes = get_var(task_vars, "ansible_memtotal_mb") * 10**6
|
|
|
+ total_memory_bytes = get_var(task_vars, "ansible_memtotal_mb") * MIB
|
|
|
|
|
|
recommended_min = max(self.recommended_memory_bytes.get(name, 0) for name in group_names)
|
|
|
- configured_min = int(get_var(task_vars, "openshift_check_min_host_memory_gb", default=0)) * 10**9
|
|
|
+ configured_min = float(get_var(task_vars, "openshift_check_min_host_memory_gb", default=0)) * GIB
|
|
|
min_memory_bytes = configured_min or recommended_min
|
|
|
|
|
|
- if total_memory_bytes < min_memory_bytes:
|
|
|
+ if total_memory_bytes + self.memtotal_adjustment < min_memory_bytes:
|
|
|
return {
|
|
|
'failed': True,
|
|
|
'msg': (
|
|
|
- 'Available memory ({available:.1f} GB) '
|
|
|
- 'below recommended value ({recommended:.1f} GB)'
|
|
|
+ 'Available memory ({available:.1f} GiB) is too far '
|
|
|
+ 'below recommended value ({recommended:.1f} GiB)'
|
|
|
).format(
|
|
|
- available=float(total_memory_bytes) / 10**9,
|
|
|
- recommended=float(min_memory_bytes) / 10**9,
|
|
|
+ available=float(total_memory_bytes) / GIB,
|
|
|
+ recommended=float(min_memory_bytes) / GIB,
|
|
|
),
|
|
|
}
|
|
|
|