From a6145d678d32a456ec7dd9182a36a1628ff21b9a Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Rados=C5=82aw=20Piliszek?= Date: Mon, 7 Mar 2022 10:20:08 +0100 Subject: [PATCH] [CI] Ironic: use ipmitool retries In Ironic jobs with Tenks, we saw issues with IPMI commands failing, resuling in job failures: Error setting Chassis Boot Parameter 5 A metal3.io commit [1] was found that fixes the issue by moving IPMI retries from ironic to ipmitool, which has a side-effect of increasing the timeout. This change applies the same configuration. This change has been adapted from an analogous change in kayobe-config-dev. [2] [1] https://github.com/metal3-io/ironic-image/commit/6bc1499d8bb04c2c859b970b3739c3a8ed66ae2a [2] Ib4fce74cebebe85c31049eafe2eeb6b28dfab041 Co-Authored-By: Mark Goddard Change-Id: I552417b9da03b8dfc9406e0ff644092579bc7122 --- tests/templates/ironic-overrides.j2 | 22 ++++++++++++++++++++++ 1 file changed, 22 insertions(+) diff --git a/tests/templates/ironic-overrides.j2 b/tests/templates/ironic-overrides.j2 index 49bee50385..19aa737aa6 100644 --- a/tests/templates/ironic-overrides.j2 +++ b/tests/templates/ironic-overrides.j2 @@ -1,3 +1,25 @@ [neutron] cleaning_network = public1 provisioning_network = public1 + +# This IPMI configuration has been taken from the metal3.io ironic-image +# project [1]. It is necessary to make IPMI reliable in Kolla Ansible Ironic +# jobs. Without it, we saw the following error: +# Error setting Chassis Boot Parameter 5 +# [1] https://github.com/metal3-io/ironic-image/commit/6bc1499d8bb04c2c859b970b3739c3a8ed66ae2a +[ipmi] +# use_ipmitool_retries transfers the responsibility of retrying to ipmitool +# when supported. If set to false, then ipmitool is called as follows : +# $ipmitool -R 1 -N 1 ... +# and Ironic handles the retry loop. +use_ipmitool_retries = true +# The following parameters are the defaults in Ironic. They are used in the +# following way if use_ipmitool_retries is set to true: +# $ipmitool -R -N ... +# where : +# X = command_retry_timeout / min_command_interval +# Y = min_command_interval +# If use_ipmitool_retries is false, then ironic retries X times, with an +# interval of Y in between each tries. +min_command_interval = 5 +command_retry_timeout = 60