ansible: don't pin controller if <4 cores.

This commit is contained in:
David Wilson 2019-01-31 14:44:40 +00:00
parent b72d139bd2
commit a9d48a8fdc
1 changed files with 20 additions and 3 deletions

View File

@ -168,6 +168,10 @@ class LinuxPolicy(Policy):
more CPUs exist. more CPUs exist.
- Children such as SSH may be scheduled on any CPU except 0/1. - Children such as SSH may be scheduled on any CPU except 0/1.
If the machine has less than 4 cores available, the top-level and workers
are pinned between CPU 2..N, i.e. no CPU is reserved for the top-level
process.
This could at least be improved by having workers pinned to independent This could at least be improved by having workers pinned to independent
cores, before reusing the second hyperthread of an existing core. cores, before reusing the second hyperthread of an existing core.
@ -180,6 +184,14 @@ class LinuxPolicy(Policy):
self.mem = mmap.mmap(-1, 4096) self.mem = mmap.mmap(-1, 4096)
self.state = State.from_buffer(self.mem) self.state = State.from_buffer(self.mem)
self.state.lock.init() self.state.lock.init()
if self._cpu_count() < 4:
self._reserve_mask = 3
self._reserve_shift = 2
self._reserve_controller = True
else:
self._reserve_mask = 1
self._reserve_shift = 1
self._reserve_controller = False
def _set_affinity(self, mask): def _set_affinity(self, mask):
mitogen.parent._preexec_hook = self._clear mitogen.parent._preexec_hook = self._clear
@ -197,16 +209,21 @@ class LinuxPolicy(Policy):
finally: finally:
self.state.lock.release() self.state.lock.release()
self._set_cpu(2 + (n % max(1, (self._cpu_count() - 2)))) self._set_cpu(self._reserve_shift + (
(n % max(1, (self._cpu_count() - self._reserve_shift)))
)
def _set_cpu(self, cpu): def _set_cpu(self, cpu):
self._set_affinity(1 << cpu) self._set_affinity(1 << cpu)
def _clear(self): def _clear(self):
self._set_affinity(0xffffffff & ~3) self._set_affinity(0xffffffff & ~self._reserve_mask)
def assign_controller(self): def assign_controller(self):
if self._reserve_controller:
self._set_cpu(1) self._set_cpu(1)
else:
self._balance()
def assign_muxprocess(self): def assign_muxprocess(self):
self._set_cpu(0) self._set_cpu(0)