Skip to content

Commit

Permalink
ARTESCA-10079 force bootstrap bundle roles on ext pillar
Browse files Browse the repository at this point in the history
  • Loading branch information
aprucolimartins committed Nov 13, 2023
1 parent c19a4e6 commit 81662d7
Show file tree
Hide file tree
Showing 2 changed files with 34 additions and 3 deletions.
4 changes: 4 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,10 @@

### Bug fixes

- Force bootstrap roles on ext_pillar to prevent bootstrap
deployment to fail when re-run.
(PR[4196](https://github.com/scality/metalk8s/pull/4196))

- Fix bug that make upgrade fail due a ETCd backup mishandle.
A retry logic was added to mitigate this problem.
(PR[4168](https://github.com/scality/metalk8s/pull/4168))
Expand Down
33 changes: 30 additions & 3 deletions salt/_pillar/metalk8s_nodes.py
Original file line number Diff line number Diff line change
Expand Up @@ -20,12 +20,13 @@ def __virtual__():
return __virtualname__


def node_info(node, ca_minion):
def node_info(node, ca_minion, pillar):
result = {
"roles": [],
"version": None,
}

node_name = node["metadata"]["name"]
roles = set()

if VERSION_LABEL in node["metadata"]["labels"]:
Expand All @@ -37,7 +38,33 @@ def node_info(node, ca_minion):
if role:
roles.add(role)

if node["metadata"]["name"] == ca_minion:
# Introduced as a workaround in cases which bootstrap setup fails after the
# kubernetes API server is up and running but node role labels are still
# not set.
#
# The issue is that when the API server is running the ext_pillar will
# overwrite the hardcoded roles with the ones from the API. It will cause
# bootstrap setup failure as described here:
# https://github.com/scality/metalk8s/issues/2137
#
# The `is_bootstrap` flag is set in pillar only when run the
# `metalk8s.orchestrate.bootstrap` state.
def get_roles_from_pillar(pillar, node_name):
try:
return pillar["metalk8s"]["nodes"][node_name]["roles"]
except Exception: # pylint: disable=broad-except
return []

if not roles and pillar.get("is_bootstrap", False):
roles = set(get_roles_from_pillar(pillar, node_name))
log.info(
"Workaround: Adding roles '%s' to pillar in node '%s'",
roles,
node_name,
)
# End of workaround

if node_name == ca_minion:
roles.add("ca")

result["roles"] = list(roles)
Expand Down Expand Up @@ -152,7 +179,7 @@ def ext_pillar(minion_id, pillar, kubeconfig):
else:
log.debug("Successfully retrieved nodes for ext_pillar")
pillar_nodes = dict(
(node["metadata"]["name"], node_info(node, ca_minion))
(node["metadata"]["name"], node_info(node, ca_minion, pillar))
for node in node_list
)

Expand Down

0 comments on commit 81662d7

Please sign in to comment.