|
|
f312c6 |
From 9ee3d6c9b0aba6aae022cc152a3b3472fe388fa3 Mon Sep 17 00:00:00 2001
|
|
|
f312c6 |
From: Ken Gaillot <kgaillot@redhat.com>
|
|
|
f312c6 |
Date: Thu, 6 Jan 2022 16:44:32 -0600
|
|
|
f312c6 |
Subject: [PATCH 01/15] Refactor: fencer: add exit reason to fencing operation
|
|
|
f312c6 |
object
|
|
|
f312c6 |
|
|
|
f312c6 |
In order to pass a fencing action's exit reason with the action history,
|
|
|
f312c6 |
we need the exit reason in remote_fencing_op_t. Nothing sets or uses it as of
|
|
|
f312c6 |
this commit.
|
|
|
f312c6 |
---
|
|
|
f312c6 |
daemons/fenced/fenced_remote.c | 2 ++
|
|
|
f312c6 |
daemons/fenced/pacemaker-fenced.h | 4 +++-
|
|
|
f312c6 |
2 files changed, 5 insertions(+), 1 deletion(-)
|
|
|
f312c6 |
|
|
|
f312c6 |
diff --git a/daemons/fenced/fenced_remote.c b/daemons/fenced/fenced_remote.c
|
|
|
f312c6 |
index 6eebb7381e..0fa9706140 100644
|
|
|
f312c6 |
--- a/daemons/fenced/fenced_remote.c
|
|
|
f312c6 |
+++ b/daemons/fenced/fenced_remote.c
|
|
|
f312c6 |
@@ -260,6 +260,8 @@ free_remote_op(gpointer data)
|
|
|
f312c6 |
}
|
|
|
f312c6 |
g_list_free_full(op->automatic_list, free);
|
|
|
f312c6 |
g_list_free(op->duplicates);
|
|
|
f312c6 |
+
|
|
|
f312c6 |
+ pcmk__reset_result(&op->result);
|
|
|
f312c6 |
free(op);
|
|
|
f312c6 |
}
|
|
|
f312c6 |
|
|
|
f312c6 |
diff --git a/daemons/fenced/pacemaker-fenced.h b/daemons/fenced/pacemaker-fenced.h
|
|
|
f312c6 |
index 502fcc9a29..1a5c933ea7 100644
|
|
|
f312c6 |
--- a/daemons/fenced/pacemaker-fenced.h
|
|
|
f312c6 |
+++ b/daemons/fenced/pacemaker-fenced.h
|
|
|
f312c6 |
@@ -1,5 +1,5 @@
|
|
|
f312c6 |
/*
|
|
|
f312c6 |
- * Copyright 2009-2021 the Pacemaker project contributors
|
|
|
f312c6 |
+ * Copyright 2009-2022 the Pacemaker project contributors
|
|
|
f312c6 |
*
|
|
|
f312c6 |
* This source code is licensed under the GNU General Public License version 2
|
|
|
f312c6 |
* or later (GPLv2+) WITHOUT ANY WARRANTY.
|
|
|
f312c6 |
@@ -151,6 +151,8 @@ typedef struct remote_fencing_op_s {
|
|
|
f312c6 |
/*! The point at which the remote operation completed(nsec) */
|
|
|
f312c6 |
long long completed_nsec;
|
|
|
f312c6 |
|
|
|
f312c6 |
+ /*! The (potentially intermediate) result of the operation */
|
|
|
f312c6 |
+ pcmk__action_result_t result;
|
|
|
f312c6 |
} remote_fencing_op_t;
|
|
|
f312c6 |
|
|
|
f312c6 |
void fenced_broadcast_op_result(remote_fencing_op_t *op,
|
|
|
f312c6 |
--
|
|
|
f312c6 |
2.27.0
|
|
|
f312c6 |
|
|
|
f312c6 |
|
|
|
f312c6 |
From 97a2c318866adc5ef5e426c5c3b753df1fa3ab66 Mon Sep 17 00:00:00 2001
|
|
|
f312c6 |
From: Ken Gaillot <kgaillot@redhat.com>
|
|
|
f312c6 |
Date: Thu, 6 Jan 2022 17:08:42 -0600
|
|
|
f312c6 |
Subject: [PATCH 02/15] Refactor: fencer: track full result in
|
|
|
f312c6 |
remote_fencing_op_t
|
|
|
f312c6 |
|
|
|
f312c6 |
Now that remote_fencing_op_t has a place for the full result,
|
|
|
f312c6 |
set it before calling finalize_op(), instead of passing a separate result
|
|
|
f312c6 |
object to finalize_op().
|
|
|
f312c6 |
|
|
|
f312c6 |
As a bonus, this simplifies the memory management, reducing the chance of
|
|
|
f312c6 |
mistakes.
|
|
|
f312c6 |
---
|
|
|
f312c6 |
daemons/fenced/fenced_remote.c | 161 ++++++++++++++++-----------------
|
|
|
f312c6 |
1 file changed, 77 insertions(+), 84 deletions(-)
|
|
|
f312c6 |
|
|
|
f312c6 |
diff --git a/daemons/fenced/fenced_remote.c b/daemons/fenced/fenced_remote.c
|
|
|
f312c6 |
index 0fa9706140..30edbff890 100644
|
|
|
f312c6 |
--- a/daemons/fenced/fenced_remote.c
|
|
|
f312c6 |
+++ b/daemons/fenced/fenced_remote.c
|
|
|
f312c6 |
@@ -82,8 +82,7 @@ extern xmlNode *stonith_create_op(int call_id, const char *token, const char *op
|
|
|
f312c6 |
static void request_peer_fencing(remote_fencing_op_t *op,
|
|
|
f312c6 |
peer_device_info_t *peer,
|
|
|
f312c6 |
pcmk__action_result_t *result);
|
|
|
f312c6 |
-static void finalize_op(remote_fencing_op_t *op, xmlNode *data,
|
|
|
f312c6 |
- pcmk__action_result_t *result, bool dup);
|
|
|
f312c6 |
+static void finalize_op(remote_fencing_op_t *op, xmlNode *data, bool dup);
|
|
|
f312c6 |
static void report_timeout_period(remote_fencing_op_t * op, int op_timeout);
|
|
|
f312c6 |
static int get_op_total_timeout(const remote_fencing_op_t *op,
|
|
|
f312c6 |
const peer_device_info_t *chosen_peer);
|
|
|
f312c6 |
@@ -485,7 +484,9 @@ finalize_op_duplicates(remote_fencing_op_t *op, xmlNode *data,
|
|
|
f312c6 |
other->client_name, other->originator,
|
|
|
f312c6 |
pcmk_exec_status_str(result->execution_status),
|
|
|
f312c6 |
other->id);
|
|
|
f312c6 |
- finalize_op(other, data, result, true);
|
|
|
f312c6 |
+ pcmk__set_result(&other->result, result->exit_status,
|
|
|
f312c6 |
+ result->execution_status, result->exit_reason);
|
|
|
f312c6 |
+ finalize_op(other, data, true);
|
|
|
f312c6 |
|
|
|
f312c6 |
} else {
|
|
|
f312c6 |
// Possible if (for example) it timed out already
|
|
|
f312c6 |
@@ -520,20 +521,20 @@ delegate_from_xml(xmlNode *xml)
|
|
|
f312c6 |
*
|
|
|
f312c6 |
* \param[in] op Fencer operation that completed
|
|
|
f312c6 |
* \param[in] data If not NULL, XML reply of last delegated fencing operation
|
|
|
f312c6 |
- * \param[in] result Full operation result
|
|
|
f312c6 |
* \param[in] dup Whether this operation is a duplicate of another
|
|
|
f312c6 |
* (in which case, do not broadcast the result)
|
|
|
f312c6 |
+ *
|
|
|
f312c6 |
+ * \note The operation result should be set before calling this function.
|
|
|
f312c6 |
*/
|
|
|
f312c6 |
static void
|
|
|
f312c6 |
-finalize_op(remote_fencing_op_t *op, xmlNode *data,
|
|
|
f312c6 |
- pcmk__action_result_t *result, bool dup)
|
|
|
f312c6 |
+finalize_op(remote_fencing_op_t *op, xmlNode *data, bool dup)
|
|
|
f312c6 |
{
|
|
|
f312c6 |
int level = LOG_ERR;
|
|
|
f312c6 |
const char *subt = NULL;
|
|
|
f312c6 |
xmlNode *local_data = NULL;
|
|
|
f312c6 |
gboolean op_merged = FALSE;
|
|
|
f312c6 |
|
|
|
f312c6 |
- CRM_CHECK((op != NULL) && (result != NULL), return);
|
|
|
f312c6 |
+ CRM_CHECK((op != NULL), return);
|
|
|
f312c6 |
|
|
|
f312c6 |
if (op->notify_sent) {
|
|
|
f312c6 |
// Most likely, this is a timed-out action that eventually completed
|
|
|
f312c6 |
@@ -557,11 +558,11 @@ finalize_op(remote_fencing_op_t *op, xmlNode *data,
|
|
|
f312c6 |
local_data = data;
|
|
|
f312c6 |
|
|
|
f312c6 |
} else if (op->delegate == NULL) {
|
|
|
f312c6 |
- switch (result->execution_status) {
|
|
|
f312c6 |
+ switch (op->result.execution_status) {
|
|
|
f312c6 |
case PCMK_EXEC_NO_FENCE_DEVICE:
|
|
|
f312c6 |
break;
|
|
|
f312c6 |
case PCMK_EXEC_INVALID:
|
|
|
f312c6 |
- if (result->exit_status == CRM_EX_EXPIRED) {
|
|
|
f312c6 |
+ if (op->result.exit_status == CRM_EX_EXPIRED) {
|
|
|
f312c6 |
break;
|
|
|
f312c6 |
}
|
|
|
f312c6 |
// else fall through
|
|
|
f312c6 |
@@ -581,12 +582,12 @@ finalize_op(remote_fencing_op_t *op, xmlNode *data,
|
|
|
f312c6 |
subt = crm_element_value(data, F_SUBTYPE);
|
|
|
f312c6 |
if (!dup && !pcmk__str_eq(subt, "broadcast", pcmk__str_casei)) {
|
|
|
f312c6 |
/* Defer notification until the bcast message arrives */
|
|
|
f312c6 |
- fenced_broadcast_op_result(op, result, op_merged);
|
|
|
f312c6 |
+ fenced_broadcast_op_result(op, &op->result, op_merged);
|
|
|
f312c6 |
free_xml(local_data);
|
|
|
f312c6 |
return;
|
|
|
f312c6 |
}
|
|
|
f312c6 |
|
|
|
f312c6 |
- if (pcmk__result_ok(result) || dup
|
|
|
f312c6 |
+ if (pcmk__result_ok(&op->result) || dup
|
|
|
f312c6 |
|| !pcmk__str_eq(op->originator, stonith_our_uname, pcmk__str_casei)) {
|
|
|
f312c6 |
level = LOG_NOTICE;
|
|
|
f312c6 |
}
|
|
|
f312c6 |
@@ -595,16 +596,17 @@ finalize_op(remote_fencing_op_t *op, xmlNode *data,
|
|
|
f312c6 |
(op->target? op->target : ""),
|
|
|
f312c6 |
(op->delegate? op->delegate : "unknown node"),
|
|
|
f312c6 |
op->client_name, op->originator,
|
|
|
f312c6 |
- (op_merged? " (merged)" : ""), crm_exit_str(result->exit_status),
|
|
|
f312c6 |
- pcmk_exec_status_str(result->execution_status),
|
|
|
f312c6 |
- ((result->exit_reason == NULL)? "" : ": "),
|
|
|
f312c6 |
- ((result->exit_reason == NULL)? "" : result->exit_reason),
|
|
|
f312c6 |
+ (op_merged? " (merged)" : ""),
|
|
|
f312c6 |
+ crm_exit_str(op->result.exit_status),
|
|
|
f312c6 |
+ pcmk_exec_status_str(op->result.execution_status),
|
|
|
f312c6 |
+ ((op->result.exit_reason == NULL)? "" : ": "),
|
|
|
f312c6 |
+ ((op->result.exit_reason == NULL)? "" : op->result.exit_reason),
|
|
|
f312c6 |
op->id);
|
|
|
f312c6 |
|
|
|
f312c6 |
- handle_local_reply_and_notify(op, data, result);
|
|
|
f312c6 |
+ handle_local_reply_and_notify(op, data, &op->result);
|
|
|
f312c6 |
|
|
|
f312c6 |
if (!dup) {
|
|
|
f312c6 |
- finalize_op_duplicates(op, data, result);
|
|
|
f312c6 |
+ finalize_op_duplicates(op, data, &op->result);
|
|
|
f312c6 |
}
|
|
|
f312c6 |
|
|
|
f312c6 |
/* Free non-essential parts of the record
|
|
|
f312c6 |
@@ -634,7 +636,6 @@ static gboolean
|
|
|
f312c6 |
remote_op_watchdog_done(gpointer userdata)
|
|
|
f312c6 |
{
|
|
|
f312c6 |
remote_fencing_op_t *op = userdata;
|
|
|
f312c6 |
- pcmk__action_result_t result = PCMK__UNKNOWN_RESULT;
|
|
|
f312c6 |
|
|
|
f312c6 |
op->op_timer_one = 0;
|
|
|
f312c6 |
|
|
|
f312c6 |
@@ -642,8 +643,8 @@ remote_op_watchdog_done(gpointer userdata)
|
|
|
f312c6 |
CRM_XS " id=%.8s",
|
|
|
f312c6 |
op->action, op->target, op->client_name, op->id);
|
|
|
f312c6 |
op->state = st_done;
|
|
|
f312c6 |
- pcmk__set_result(&result, CRM_EX_OK, PCMK_EXEC_DONE, NULL);
|
|
|
f312c6 |
- finalize_op(op, NULL, &result, false);
|
|
|
f312c6 |
+ pcmk__set_result(&op->result, CRM_EX_OK, PCMK_EXEC_DONE, NULL);
|
|
|
f312c6 |
+ finalize_op(op, NULL, false);
|
|
|
f312c6 |
return G_SOURCE_REMOVE;
|
|
|
f312c6 |
}
|
|
|
f312c6 |
|
|
|
f312c6 |
@@ -676,8 +677,6 @@ remote_op_timeout_one(gpointer userdata)
|
|
|
f312c6 |
static void
|
|
|
f312c6 |
finalize_timed_out_op(remote_fencing_op_t *op, const char *reason)
|
|
|
f312c6 |
{
|
|
|
f312c6 |
- pcmk__action_result_t result = PCMK__UNKNOWN_RESULT;
|
|
|
f312c6 |
-
|
|
|
f312c6 |
op->op_timer_total = 0;
|
|
|
f312c6 |
|
|
|
f312c6 |
crm_debug("Action '%s' targeting %s for client %s timed out "
|
|
|
f312c6 |
@@ -690,13 +689,12 @@ finalize_timed_out_op(remote_fencing_op_t *op, const char *reason)
|
|
|
f312c6 |
* devices, and return success.
|
|
|
f312c6 |
*/
|
|
|
f312c6 |
op->state = st_done;
|
|
|
f312c6 |
- pcmk__set_result(&result, CRM_EX_OK, PCMK_EXEC_DONE, NULL);
|
|
|
f312c6 |
+ pcmk__set_result(&op->result, CRM_EX_OK, PCMK_EXEC_DONE, NULL);
|
|
|
f312c6 |
} else {
|
|
|
f312c6 |
op->state = st_failed;
|
|
|
f312c6 |
- pcmk__set_result(&result, CRM_EX_ERROR, PCMK_EXEC_TIMEOUT, reason);
|
|
|
f312c6 |
+ pcmk__set_result(&op->result, CRM_EX_ERROR, PCMK_EXEC_TIMEOUT, reason);
|
|
|
f312c6 |
}
|
|
|
f312c6 |
- finalize_op(op, NULL, &result, false);
|
|
|
f312c6 |
- pcmk__reset_result(&result);
|
|
|
f312c6 |
+ finalize_op(op, NULL, false);
|
|
|
f312c6 |
}
|
|
|
f312c6 |
|
|
|
f312c6 |
/*!
|
|
|
f312c6 |
@@ -1094,13 +1092,9 @@ fenced_handle_manual_confirmation(pcmk__client_t *client, xmlNode *msg)
|
|
|
f312c6 |
set_fencing_completed(op);
|
|
|
f312c6 |
op->delegate = strdup("a human");
|
|
|
f312c6 |
|
|
|
f312c6 |
- {
|
|
|
f312c6 |
- // For the fencer's purposes, the fencing operation is done
|
|
|
f312c6 |
- pcmk__action_result_t result = PCMK__UNKNOWN_RESULT;
|
|
|
f312c6 |
-
|
|
|
f312c6 |
- pcmk__set_result(&result, CRM_EX_OK, PCMK_EXEC_DONE, NULL);
|
|
|
f312c6 |
- finalize_op(op, msg, &result, false);
|
|
|
f312c6 |
- }
|
|
|
f312c6 |
+ // For the fencer's purposes, the fencing operation is done
|
|
|
f312c6 |
+ pcmk__set_result(&op->result, CRM_EX_OK, PCMK_EXEC_DONE, NULL);
|
|
|
f312c6 |
+ finalize_op(op, msg, false);
|
|
|
f312c6 |
|
|
|
f312c6 |
/* For the requester's purposes, the operation is still pending. The
|
|
|
f312c6 |
* actual result will be sent asynchronously via the operation's done_cb().
|
|
|
f312c6 |
@@ -1279,16 +1273,11 @@ initiate_remote_stonith_op(pcmk__client_t *client, xmlNode *request,
|
|
|
f312c6 |
switch (op->state) {
|
|
|
f312c6 |
case st_failed:
|
|
|
f312c6 |
// advance_topology_level() exhausted levels
|
|
|
f312c6 |
- {
|
|
|
f312c6 |
- pcmk__action_result_t result = PCMK__UNKNOWN_RESULT;
|
|
|
f312c6 |
-
|
|
|
f312c6 |
- pcmk__set_result(&result, CRM_EX_ERROR, PCMK_EXEC_ERROR,
|
|
|
f312c6 |
- "All topology levels failed");
|
|
|
f312c6 |
- crm_warn("Could not request peer fencing (%s) targeting %s "
|
|
|
f312c6 |
- CRM_XS " id=%.8s", op->action, op->target, op->id);
|
|
|
f312c6 |
- finalize_op(op, NULL, &result, false);
|
|
|
f312c6 |
- pcmk__reset_result(&result);
|
|
|
f312c6 |
- }
|
|
|
f312c6 |
+ pcmk__set_result(&op->result, CRM_EX_ERROR, PCMK_EXEC_ERROR,
|
|
|
f312c6 |
+ "All topology levels failed");
|
|
|
f312c6 |
+ crm_warn("Could not request peer fencing (%s) targeting %s "
|
|
|
f312c6 |
+ CRM_XS " id=%.8s", op->action, op->target, op->id);
|
|
|
f312c6 |
+ finalize_op(op, NULL, false);
|
|
|
f312c6 |
return op;
|
|
|
f312c6 |
|
|
|
f312c6 |
case st_duplicate:
|
|
|
f312c6 |
@@ -1613,10 +1602,6 @@ static void
|
|
|
f312c6 |
advance_topology_device_in_level(remote_fencing_op_t *op, const char *device,
|
|
|
f312c6 |
xmlNode *msg)
|
|
|
f312c6 |
{
|
|
|
f312c6 |
- pcmk__action_result_t result = PCMK__UNKNOWN_RESULT;
|
|
|
f312c6 |
-
|
|
|
f312c6 |
- pcmk__set_result(&result, CRM_EX_OK, PCMK_EXEC_DONE, NULL);
|
|
|
f312c6 |
-
|
|
|
f312c6 |
/* Advance to the next device at this topology level, if any */
|
|
|
f312c6 |
if (op->devices) {
|
|
|
f312c6 |
op->devices = op->devices->next;
|
|
|
f312c6 |
@@ -1644,6 +1629,10 @@ advance_topology_device_in_level(remote_fencing_op_t *op, const char *device,
|
|
|
f312c6 |
}
|
|
|
f312c6 |
|
|
|
f312c6 |
if (op->devices) {
|
|
|
f312c6 |
+ pcmk__action_result_t result = PCMK__UNKNOWN_RESULT;
|
|
|
f312c6 |
+
|
|
|
f312c6 |
+ pcmk__set_result(&result, CRM_EX_OK, PCMK_EXEC_DONE, NULL);
|
|
|
f312c6 |
+
|
|
|
f312c6 |
/* Necessary devices remain, so execute the next one */
|
|
|
f312c6 |
crm_trace("Next targeting %s on behalf of %s@%s",
|
|
|
f312c6 |
op->target, op->client_name, op->originator);
|
|
|
f312c6 |
@@ -1659,7 +1648,8 @@ advance_topology_device_in_level(remote_fencing_op_t *op, const char *device,
|
|
|
f312c6 |
crm_trace("Marking complex fencing op targeting %s as complete",
|
|
|
f312c6 |
op->target);
|
|
|
f312c6 |
op->state = st_done;
|
|
|
f312c6 |
- finalize_op(op, msg, &result, false);
|
|
|
f312c6 |
+ pcmk__set_result(&op->result, CRM_EX_OK, PCMK_EXEC_DONE, NULL);
|
|
|
f312c6 |
+ finalize_op(op, msg, false);
|
|
|
f312c6 |
}
|
|
|
f312c6 |
}
|
|
|
f312c6 |
|
|
|
f312c6 |
@@ -1868,7 +1858,9 @@ request_peer_fencing(remote_fencing_op_t *op, peer_device_info_t *peer,
|
|
|
f312c6 |
}
|
|
|
f312c6 |
|
|
|
f312c6 |
op->state = st_failed;
|
|
|
f312c6 |
- finalize_op(op, NULL, result, false);
|
|
|
f312c6 |
+ pcmk__set_result(&op->result, result->exit_status,
|
|
|
f312c6 |
+ result->execution_status, result->exit_reason);
|
|
|
f312c6 |
+ finalize_op(op, NULL, false);
|
|
|
f312c6 |
|
|
|
f312c6 |
} else {
|
|
|
f312c6 |
crm_info("Waiting for additional peers capable of fencing (%s) %s%s%s "
|
|
|
f312c6 |
@@ -2245,31 +2237,34 @@ fenced_process_fencing_reply(xmlNode *msg)
|
|
|
f312c6 |
/* Could be for an event that began before we started */
|
|
|
f312c6 |
/* TODO: Record the op for later querying */
|
|
|
f312c6 |
crm_info("Received peer result of unknown or expired operation %s", id);
|
|
|
f312c6 |
- goto done;
|
|
|
f312c6 |
+ pcmk__reset_result(&result);
|
|
|
f312c6 |
+ return;
|
|
|
f312c6 |
}
|
|
|
f312c6 |
|
|
|
f312c6 |
+ op->result = result; // The operation takes ownership of the result
|
|
|
f312c6 |
+
|
|
|
f312c6 |
if (op->devices && device && !pcmk__str_eq(op->devices->data, device, pcmk__str_casei)) {
|
|
|
f312c6 |
crm_err("Received outdated reply for device %s (instead of %s) to "
|
|
|
f312c6 |
"fence (%s) %s. Operation already timed out at peer level.",
|
|
|
f312c6 |
device, (const char *) op->devices->data, op->action, op->target);
|
|
|
f312c6 |
- goto done;
|
|
|
f312c6 |
+ return;
|
|
|
f312c6 |
}
|
|
|
f312c6 |
|
|
|
f312c6 |
if (pcmk__str_eq(crm_element_value(msg, F_SUBTYPE), "broadcast", pcmk__str_casei)) {
|
|
|
f312c6 |
crm_debug("Finalizing action '%s' targeting %s on behalf of %s@%s: %s%s%s%s "
|
|
|
f312c6 |
CRM_XS " id=%.8s",
|
|
|
f312c6 |
op->action, op->target, op->client_name, op->originator,
|
|
|
f312c6 |
- pcmk_exec_status_str(result.execution_status),
|
|
|
f312c6 |
- (result.exit_reason == NULL)? "" : " (",
|
|
|
f312c6 |
- (result.exit_reason == NULL)? "" : result.exit_reason,
|
|
|
f312c6 |
- (result.exit_reason == NULL)? "" : ")", op->id);
|
|
|
f312c6 |
- if (pcmk__result_ok(&result)) {
|
|
|
f312c6 |
+ pcmk_exec_status_str(op->result.execution_status),
|
|
|
f312c6 |
+ (op->result.exit_reason == NULL)? "" : " (",
|
|
|
f312c6 |
+ (op->result.exit_reason == NULL)? "" : op->result.exit_reason,
|
|
|
f312c6 |
+ (op->result.exit_reason == NULL)? "" : ")", op->id);
|
|
|
f312c6 |
+ if (pcmk__result_ok(&op->result)) {
|
|
|
f312c6 |
op->state = st_done;
|
|
|
f312c6 |
} else {
|
|
|
f312c6 |
op->state = st_failed;
|
|
|
f312c6 |
}
|
|
|
f312c6 |
- finalize_op(op, msg, &result, false);
|
|
|
f312c6 |
- goto done;
|
|
|
f312c6 |
+ finalize_op(op, msg, false);
|
|
|
f312c6 |
+ return;
|
|
|
f312c6 |
|
|
|
f312c6 |
} else if (!pcmk__str_eq(op->originator, stonith_our_uname, pcmk__str_casei)) {
|
|
|
f312c6 |
/* If this isn't a remote level broadcast, and we are not the
|
|
|
f312c6 |
@@ -2277,7 +2272,7 @@ fenced_process_fencing_reply(xmlNode *msg)
|
|
|
f312c6 |
crm_err("Received non-broadcast fencing result for operation %.8s "
|
|
|
f312c6 |
"we do not own (device %s targeting %s)",
|
|
|
f312c6 |
op->id, device, op->target);
|
|
|
f312c6 |
- goto done;
|
|
|
f312c6 |
+ return;
|
|
|
f312c6 |
}
|
|
|
f312c6 |
|
|
|
f312c6 |
if (pcmk_is_set(op->call_options, st_opt_topology)) {
|
|
|
f312c6 |
@@ -2286,58 +2281,58 @@ fenced_process_fencing_reply(xmlNode *msg)
|
|
|
f312c6 |
crm_notice("Action '%s' targeting %s using %s on behalf of %s@%s: %s%s%s%s",
|
|
|
f312c6 |
op->action, op->target, device, op->client_name,
|
|
|
f312c6 |
op->originator,
|
|
|
f312c6 |
- pcmk_exec_status_str(result.execution_status),
|
|
|
f312c6 |
- (result.exit_reason == NULL)? "" : " (",
|
|
|
f312c6 |
- (result.exit_reason == NULL)? "" : result.exit_reason,
|
|
|
f312c6 |
- (result.exit_reason == NULL)? "" : ")");
|
|
|
f312c6 |
+ pcmk_exec_status_str(op->result.execution_status),
|
|
|
f312c6 |
+ (op->result.exit_reason == NULL)? "" : " (",
|
|
|
f312c6 |
+ (op->result.exit_reason == NULL)? "" : op->result.exit_reason,
|
|
|
f312c6 |
+ (op->result.exit_reason == NULL)? "" : ")");
|
|
|
f312c6 |
|
|
|
f312c6 |
/* We own the op, and it is complete. broadcast the result to all nodes
|
|
|
f312c6 |
* and notify our local clients. */
|
|
|
f312c6 |
if (op->state == st_done) {
|
|
|
f312c6 |
- finalize_op(op, msg, &result, false);
|
|
|
f312c6 |
- goto done;
|
|
|
f312c6 |
+ finalize_op(op, msg, false);
|
|
|
f312c6 |
+ return;
|
|
|
f312c6 |
}
|
|
|
f312c6 |
|
|
|
f312c6 |
- if ((op->phase == 2) && !pcmk__result_ok(&result)) {
|
|
|
f312c6 |
+ if ((op->phase == 2) && !pcmk__result_ok(&op->result)) {
|
|
|
f312c6 |
/* A remapped "on" failed, but the node was already turned off
|
|
|
f312c6 |
* successfully, so ignore the error and continue.
|
|
|
f312c6 |
*/
|
|
|
f312c6 |
crm_warn("Ignoring %s 'on' failure (%s%s%s) targeting %s "
|
|
|
f312c6 |
"after successful 'off'",
|
|
|
f312c6 |
- device, pcmk_exec_status_str(result.execution_status),
|
|
|
f312c6 |
- (result.exit_reason == NULL)? "" : ": ",
|
|
|
f312c6 |
- (result.exit_reason == NULL)? "" : result.exit_reason,
|
|
|
f312c6 |
+ device, pcmk_exec_status_str(op->result.execution_status),
|
|
|
f312c6 |
+ (op->result.exit_reason == NULL)? "" : ": ",
|
|
|
f312c6 |
+ (op->result.exit_reason == NULL)? "" : op->result.exit_reason,
|
|
|
f312c6 |
op->target);
|
|
|
f312c6 |
- pcmk__set_result(&result, CRM_EX_OK, PCMK_EXEC_DONE, NULL);
|
|
|
f312c6 |
+ pcmk__set_result(&op->result, CRM_EX_OK, PCMK_EXEC_DONE, NULL);
|
|
|
f312c6 |
}
|
|
|
f312c6 |
|
|
|
f312c6 |
- if (pcmk__result_ok(&result)) {
|
|
|
f312c6 |
+ if (pcmk__result_ok(&op->result)) {
|
|
|
f312c6 |
/* An operation completed successfully. Try another device if
|
|
|
f312c6 |
* necessary, otherwise mark the operation as done. */
|
|
|
f312c6 |
advance_topology_device_in_level(op, device, msg);
|
|
|
f312c6 |
- goto done;
|
|
|
f312c6 |
+ return;
|
|
|
f312c6 |
} else {
|
|
|
f312c6 |
/* This device failed, time to try another topology level. If no other
|
|
|
f312c6 |
* levels are available, mark this operation as failed and report results. */
|
|
|
f312c6 |
if (advance_topology_level(op, false) != pcmk_rc_ok) {
|
|
|
f312c6 |
op->state = st_failed;
|
|
|
f312c6 |
- finalize_op(op, msg, &result, false);
|
|
|
f312c6 |
- goto done;
|
|
|
f312c6 |
+ finalize_op(op, msg, false);
|
|
|
f312c6 |
+ return;
|
|
|
f312c6 |
}
|
|
|
f312c6 |
}
|
|
|
f312c6 |
|
|
|
f312c6 |
- } else if (pcmk__result_ok(&result) && (op->devices == NULL)) {
|
|
|
f312c6 |
+ } else if (pcmk__result_ok(&op->result) && (op->devices == NULL)) {
|
|
|
f312c6 |
crm_trace("All done for %s", op->target);
|
|
|
f312c6 |
op->state = st_done;
|
|
|
f312c6 |
- finalize_op(op, msg, &result, false);
|
|
|
f312c6 |
- goto done;
|
|
|
f312c6 |
+ finalize_op(op, msg, false);
|
|
|
f312c6 |
+ return;
|
|
|
f312c6 |
|
|
|
f312c6 |
- } else if ((result.execution_status == PCMK_EXEC_TIMEOUT)
|
|
|
f312c6 |
+ } else if ((op->result.execution_status == PCMK_EXEC_TIMEOUT)
|
|
|
f312c6 |
&& (op->devices == NULL)) {
|
|
|
f312c6 |
/* If the operation timed out don't bother retrying other peers. */
|
|
|
f312c6 |
op->state = st_failed;
|
|
|
f312c6 |
- finalize_op(op, msg, &result, false);
|
|
|
f312c6 |
- goto done;
|
|
|
f312c6 |
+ finalize_op(op, msg, false);
|
|
|
f312c6 |
+ return;
|
|
|
f312c6 |
|
|
|
f312c6 |
} else {
|
|
|
f312c6 |
/* fall-through and attempt other fencing action using another peer */
|
|
|
f312c6 |
@@ -2346,10 +2341,8 @@ fenced_process_fencing_reply(xmlNode *msg)
|
|
|
f312c6 |
/* Retry on failure */
|
|
|
f312c6 |
crm_trace("Next for %s on behalf of %s@%s (result was: %s)",
|
|
|
f312c6 |
op->target, op->originator, op->client_name,
|
|
|
f312c6 |
- pcmk_exec_status_str(result.execution_status));
|
|
|
f312c6 |
- request_peer_fencing(op, NULL, &result);
|
|
|
f312c6 |
-done:
|
|
|
f312c6 |
- pcmk__reset_result(&result);
|
|
|
f312c6 |
+ pcmk_exec_status_str(op->result.execution_status));
|
|
|
f312c6 |
+ request_peer_fencing(op, NULL, &op->result);
|
|
|
f312c6 |
}
|
|
|
f312c6 |
|
|
|
f312c6 |
gboolean
|
|
|
f312c6 |
--
|
|
|
f312c6 |
2.27.0
|
|
|
f312c6 |
|
|
|
f312c6 |
|
|
|
f312c6 |
From c59d062154f7c9e15e90929a20ea244d7efd7247 Mon Sep 17 00:00:00 2001
|
|
|
f312c6 |
From: Ken Gaillot <kgaillot@redhat.com>
|
|
|
f312c6 |
Date: Thu, 6 Jan 2022 17:11:12 -0600
|
|
|
f312c6 |
Subject: [PATCH 03/15] Refactor: fencer: drop redundant argument from
|
|
|
f312c6 |
finalize_op_duplicates()
|
|
|
f312c6 |
|
|
|
f312c6 |
... now that the result is in the op
|
|
|
f312c6 |
---
|
|
|
f312c6 |
daemons/fenced/fenced_remote.c | 13 ++++++-------
|
|
|
f312c6 |
1 file changed, 6 insertions(+), 7 deletions(-)
|
|
|
f312c6 |
|
|
|
f312c6 |
diff --git a/daemons/fenced/fenced_remote.c b/daemons/fenced/fenced_remote.c
|
|
|
f312c6 |
index 30edbff890..8b496e1042 100644
|
|
|
f312c6 |
--- a/daemons/fenced/fenced_remote.c
|
|
|
f312c6 |
+++ b/daemons/fenced/fenced_remote.c
|
|
|
f312c6 |
@@ -468,11 +468,9 @@ handle_local_reply_and_notify(remote_fencing_op_t *op, xmlNode *data,
|
|
|
f312c6 |
*
|
|
|
f312c6 |
* \param[in] op Fencer operation that completed
|
|
|
f312c6 |
* \param[in] data Top-level XML to add notification to
|
|
|
f312c6 |
- * \param[in] result Full operation result
|
|
|
f312c6 |
*/
|
|
|
f312c6 |
static void
|
|
|
f312c6 |
-finalize_op_duplicates(remote_fencing_op_t *op, xmlNode *data,
|
|
|
f312c6 |
- pcmk__action_result_t *result)
|
|
|
f312c6 |
+finalize_op_duplicates(remote_fencing_op_t *op, xmlNode *data)
|
|
|
f312c6 |
{
|
|
|
f312c6 |
for (GList *iter = op->duplicates; iter != NULL; iter = iter->next) {
|
|
|
f312c6 |
remote_fencing_op_t *other = iter->data;
|
|
|
f312c6 |
@@ -482,10 +480,11 @@ finalize_op_duplicates(remote_fencing_op_t *op, xmlNode *data,
|
|
|
f312c6 |
crm_debug("Performing duplicate notification for %s@%s: %s "
|
|
|
f312c6 |
CRM_XS " id=%.8s",
|
|
|
f312c6 |
other->client_name, other->originator,
|
|
|
f312c6 |
- pcmk_exec_status_str(result->execution_status),
|
|
|
f312c6 |
+ pcmk_exec_status_str(op->result.execution_status),
|
|
|
f312c6 |
other->id);
|
|
|
f312c6 |
- pcmk__set_result(&other->result, result->exit_status,
|
|
|
f312c6 |
- result->execution_status, result->exit_reason);
|
|
|
f312c6 |
+ pcmk__set_result(&other->result, op->result.exit_status,
|
|
|
f312c6 |
+ op->result.execution_status,
|
|
|
f312c6 |
+ op->result.exit_reason);
|
|
|
f312c6 |
finalize_op(other, data, true);
|
|
|
f312c6 |
|
|
|
f312c6 |
} else {
|
|
|
f312c6 |
@@ -606,7 +605,7 @@ finalize_op(remote_fencing_op_t *op, xmlNode *data, bool dup)
|
|
|
f312c6 |
handle_local_reply_and_notify(op, data, &op->result);
|
|
|
f312c6 |
|
|
|
f312c6 |
if (!dup) {
|
|
|
f312c6 |
- finalize_op_duplicates(op, data, &op->result);
|
|
|
f312c6 |
+ finalize_op_duplicates(op, data);
|
|
|
f312c6 |
}
|
|
|
f312c6 |
|
|
|
f312c6 |
/* Free non-essential parts of the record
|
|
|
f312c6 |
--
|
|
|
f312c6 |
2.27.0
|
|
|
f312c6 |
|
|
|
f312c6 |
|
|
|
f312c6 |
From 6c49675855323a52a534afa112a0861ba2e3b1ad Mon Sep 17 00:00:00 2001
|
|
|
f312c6 |
From: Ken Gaillot <kgaillot@redhat.com>
|
|
|
f312c6 |
Date: Thu, 6 Jan 2022 17:15:17 -0600
|
|
|
f312c6 |
Subject: [PATCH 04/15] Refactor: fencer: drop redundant argument from
|
|
|
f312c6 |
fenced_broadcast_op_result()
|
|
|
f312c6 |
|
|
|
f312c6 |
... now that the op includes the result
|
|
|
f312c6 |
---
|
|
|
f312c6 |
daemons/fenced/fenced_history.c | 9 +++------
|
|
|
f312c6 |
daemons/fenced/fenced_remote.c | 8 +++-----
|
|
|
f312c6 |
daemons/fenced/pacemaker-fenced.h | 3 +--
|
|
|
f312c6 |
3 files changed, 7 insertions(+), 13 deletions(-)
|
|
|
f312c6 |
|
|
|
f312c6 |
diff --git a/daemons/fenced/fenced_history.c b/daemons/fenced/fenced_history.c
|
|
|
f312c6 |
index 0157deadb3..5cacf36ca8 100644
|
|
|
f312c6 |
--- a/daemons/fenced/fenced_history.c
|
|
|
f312c6 |
+++ b/daemons/fenced/fenced_history.c
|
|
|
f312c6 |
@@ -1,5 +1,5 @@
|
|
|
f312c6 |
/*
|
|
|
f312c6 |
- * Copyright 2009-2021 the Pacemaker project contributors
|
|
|
f312c6 |
+ * Copyright 2009-2022 the Pacemaker project contributors
|
|
|
f312c6 |
*
|
|
|
f312c6 |
* The version control history for this file may have further details.
|
|
|
f312c6 |
*
|
|
|
f312c6 |
@@ -359,8 +359,6 @@ stonith_local_history_diff_and_merge(GHashTable *remote_history,
|
|
|
f312c6 |
}
|
|
|
f312c6 |
|
|
|
f312c6 |
if (remote_history) {
|
|
|
f312c6 |
- pcmk__action_result_t result = PCMK__UNKNOWN_RESULT;
|
|
|
f312c6 |
-
|
|
|
f312c6 |
init_stonith_remote_op_hash_table(&stonith_remote_op_list);
|
|
|
f312c6 |
|
|
|
f312c6 |
updated |= g_hash_table_size(remote_history);
|
|
|
f312c6 |
@@ -378,10 +376,10 @@ stonith_local_history_diff_and_merge(GHashTable *remote_history,
|
|
|
f312c6 |
/* CRM_EX_EXPIRED + PCMK_EXEC_INVALID prevents finalize_op()
|
|
|
f312c6 |
* from setting a delegate
|
|
|
f312c6 |
*/
|
|
|
f312c6 |
- pcmk__set_result(&result, CRM_EX_EXPIRED, PCMK_EXEC_INVALID,
|
|
|
f312c6 |
+ pcmk__set_result(&op->result, CRM_EX_EXPIRED, PCMK_EXEC_INVALID,
|
|
|
f312c6 |
"Initiated by earlier fencer "
|
|
|
f312c6 |
"process and presumed failed");
|
|
|
f312c6 |
- fenced_broadcast_op_result(op, &result, false);
|
|
|
f312c6 |
+ fenced_broadcast_op_result(op, false);
|
|
|
f312c6 |
}
|
|
|
f312c6 |
|
|
|
f312c6 |
g_hash_table_iter_steal(&iter);
|
|
|
f312c6 |
@@ -396,7 +394,6 @@ stonith_local_history_diff_and_merge(GHashTable *remote_history,
|
|
|
f312c6 |
*/
|
|
|
f312c6 |
}
|
|
|
f312c6 |
|
|
|
f312c6 |
- pcmk__reset_result(&result);
|
|
|
f312c6 |
g_hash_table_destroy(remote_history); /* remove what is left */
|
|
|
f312c6 |
}
|
|
|
f312c6 |
|
|
|
f312c6 |
diff --git a/daemons/fenced/fenced_remote.c b/daemons/fenced/fenced_remote.c
|
|
|
f312c6 |
index 8b496e1042..fb5a5e980e 100644
|
|
|
f312c6 |
--- a/daemons/fenced/fenced_remote.c
|
|
|
f312c6 |
+++ b/daemons/fenced/fenced_remote.c
|
|
|
f312c6 |
@@ -390,16 +390,14 @@ fencing_result2xml(remote_fencing_op_t *op, pcmk__action_result_t *result)
|
|
|
f312c6 |
* \brief Broadcast a fence result notification to all CPG peers
|
|
|
f312c6 |
*
|
|
|
f312c6 |
* \param[in] op Fencer operation that completed
|
|
|
f312c6 |
- * \param[in] result Full operation result
|
|
|
f312c6 |
* \param[in] op_merged Whether this operation is a duplicate of another
|
|
|
f312c6 |
*/
|
|
|
f312c6 |
void
|
|
|
f312c6 |
-fenced_broadcast_op_result(remote_fencing_op_t *op,
|
|
|
f312c6 |
- pcmk__action_result_t *result, bool op_merged)
|
|
|
f312c6 |
+fenced_broadcast_op_result(remote_fencing_op_t *op, bool op_merged)
|
|
|
f312c6 |
{
|
|
|
f312c6 |
static int count = 0;
|
|
|
f312c6 |
xmlNode *bcast = create_xml_node(NULL, T_STONITH_REPLY);
|
|
|
f312c6 |
- xmlNode *notify_data = fencing_result2xml(op, result);
|
|
|
f312c6 |
+ xmlNode *notify_data = fencing_result2xml(op, &op->result);
|
|
|
f312c6 |
|
|
|
f312c6 |
count++;
|
|
|
f312c6 |
crm_trace("Broadcasting result to peers");
|
|
|
f312c6 |
@@ -581,7 +579,7 @@ finalize_op(remote_fencing_op_t *op, xmlNode *data, bool dup)
|
|
|
f312c6 |
subt = crm_element_value(data, F_SUBTYPE);
|
|
|
f312c6 |
if (!dup && !pcmk__str_eq(subt, "broadcast", pcmk__str_casei)) {
|
|
|
f312c6 |
/* Defer notification until the bcast message arrives */
|
|
|
f312c6 |
- fenced_broadcast_op_result(op, &op->result, op_merged);
|
|
|
f312c6 |
+ fenced_broadcast_op_result(op, op_merged);
|
|
|
f312c6 |
free_xml(local_data);
|
|
|
f312c6 |
return;
|
|
|
f312c6 |
}
|
|
|
f312c6 |
diff --git a/daemons/fenced/pacemaker-fenced.h b/daemons/fenced/pacemaker-fenced.h
|
|
|
f312c6 |
index 1a5c933ea7..6213407da3 100644
|
|
|
f312c6 |
--- a/daemons/fenced/pacemaker-fenced.h
|
|
|
f312c6 |
+++ b/daemons/fenced/pacemaker-fenced.h
|
|
|
f312c6 |
@@ -155,8 +155,7 @@ typedef struct remote_fencing_op_s {
|
|
|
f312c6 |
pcmk__action_result_t result;
|
|
|
f312c6 |
} remote_fencing_op_t;
|
|
|
f312c6 |
|
|
|
f312c6 |
-void fenced_broadcast_op_result(remote_fencing_op_t *op,
|
|
|
f312c6 |
- pcmk__action_result_t *result, bool op_merged);
|
|
|
f312c6 |
+void fenced_broadcast_op_result(remote_fencing_op_t *op, bool op_merged);
|
|
|
f312c6 |
|
|
|
f312c6 |
// Fencer-specific client flags
|
|
|
f312c6 |
enum st_client_flags {
|
|
|
f312c6 |
--
|
|
|
f312c6 |
2.27.0
|
|
|
f312c6 |
|
|
|
f312c6 |
|
|
|
f312c6 |
From 73994fc740b8833457b130368db479502d49f285 Mon Sep 17 00:00:00 2001
|
|
|
f312c6 |
From: Ken Gaillot <kgaillot@redhat.com>
|
|
|
f312c6 |
Date: Thu, 6 Jan 2022 17:17:33 -0600
|
|
|
f312c6 |
Subject: [PATCH 05/15] Refactor: fencer: drop redundant argument from
|
|
|
f312c6 |
handle_local_reply_and_notify()
|
|
|
f312c6 |
|
|
|
f312c6 |
... now that the op includes the result
|
|
|
f312c6 |
---
|
|
|
f312c6 |
daemons/fenced/fenced_remote.c | 12 +++++-------
|
|
|
f312c6 |
1 file changed, 5 insertions(+), 7 deletions(-)
|
|
|
f312c6 |
|
|
|
f312c6 |
diff --git a/daemons/fenced/fenced_remote.c b/daemons/fenced/fenced_remote.c
|
|
|
f312c6 |
index fb5a5e980e..2621cb2f19 100644
|
|
|
f312c6 |
--- a/daemons/fenced/fenced_remote.c
|
|
|
f312c6 |
+++ b/daemons/fenced/fenced_remote.c
|
|
|
f312c6 |
@@ -424,11 +424,9 @@ fenced_broadcast_op_result(remote_fencing_op_t *op, bool op_merged)
|
|
|
f312c6 |
*
|
|
|
f312c6 |
* \param[in] op Fencer operation that completed
|
|
|
f312c6 |
* \param[in] data Top-level XML to add notification to
|
|
|
f312c6 |
- * \param[in] result Full operation result
|
|
|
f312c6 |
*/
|
|
|
f312c6 |
static void
|
|
|
f312c6 |
-handle_local_reply_and_notify(remote_fencing_op_t *op, xmlNode *data,
|
|
|
f312c6 |
- pcmk__action_result_t *result)
|
|
|
f312c6 |
+handle_local_reply_and_notify(remote_fencing_op_t *op, xmlNode *data)
|
|
|
f312c6 |
{
|
|
|
f312c6 |
xmlNode *notify_data = NULL;
|
|
|
f312c6 |
xmlNode *reply = NULL;
|
|
|
f312c6 |
@@ -443,15 +441,15 @@ handle_local_reply_and_notify(remote_fencing_op_t *op, xmlNode *data,
|
|
|
f312c6 |
crm_xml_add(data, F_STONITH_TARGET, op->target);
|
|
|
f312c6 |
crm_xml_add(data, F_STONITH_OPERATION, op->action);
|
|
|
f312c6 |
|
|
|
f312c6 |
- reply = fenced_construct_reply(op->request, data, result);
|
|
|
f312c6 |
+ reply = fenced_construct_reply(op->request, data, &op->result);
|
|
|
f312c6 |
crm_xml_add(reply, F_STONITH_DELEGATE, op->delegate);
|
|
|
f312c6 |
|
|
|
f312c6 |
/* Send fencing OP reply to local client that initiated fencing */
|
|
|
f312c6 |
do_local_reply(reply, op->client_id, op->call_options & st_opt_sync_call, FALSE);
|
|
|
f312c6 |
|
|
|
f312c6 |
/* bcast to all local clients that the fencing operation happend */
|
|
|
f312c6 |
- notify_data = fencing_result2xml(op, result);
|
|
|
f312c6 |
- fenced_send_notification(T_STONITH_NOTIFY_FENCE, result, notify_data);
|
|
|
f312c6 |
+ notify_data = fencing_result2xml(op, &op->result);
|
|
|
f312c6 |
+ fenced_send_notification(T_STONITH_NOTIFY_FENCE, &op->result, notify_data);
|
|
|
f312c6 |
free_xml(notify_data);
|
|
|
f312c6 |
fenced_send_notification(T_STONITH_NOTIFY_HISTORY, NULL, NULL);
|
|
|
f312c6 |
|
|
|
f312c6 |
@@ -600,7 +598,7 @@ finalize_op(remote_fencing_op_t *op, xmlNode *data, bool dup)
|
|
|
f312c6 |
((op->result.exit_reason == NULL)? "" : op->result.exit_reason),
|
|
|
f312c6 |
op->id);
|
|
|
f312c6 |
|
|
|
f312c6 |
- handle_local_reply_and_notify(op, data, &op->result);
|
|
|
f312c6 |
+ handle_local_reply_and_notify(op, data);
|
|
|
f312c6 |
|
|
|
f312c6 |
if (!dup) {
|
|
|
f312c6 |
finalize_op_duplicates(op, data);
|
|
|
f312c6 |
--
|
|
|
f312c6 |
2.27.0
|
|
|
f312c6 |
|
|
|
f312c6 |
|
|
|
f312c6 |
From 194056d18d3b550d3a53b94d558ceed03b5e5442 Mon Sep 17 00:00:00 2001
|
|
|
f312c6 |
From: Ken Gaillot <kgaillot@redhat.com>
|
|
|
f312c6 |
Date: Thu, 6 Jan 2022 17:18:27 -0600
|
|
|
f312c6 |
Subject: [PATCH 06/15] Refactor: fencer: drop redundant argument from
|
|
|
f312c6 |
fencing_result2xml()
|
|
|
f312c6 |
|
|
|
f312c6 |
... now that the op includes the result
|
|
|
f312c6 |
---
|
|
|
f312c6 |
daemons/fenced/fenced_remote.c | 9 ++++-----
|
|
|
f312c6 |
1 file changed, 4 insertions(+), 5 deletions(-)
|
|
|
f312c6 |
|
|
|
f312c6 |
diff --git a/daemons/fenced/fenced_remote.c b/daemons/fenced/fenced_remote.c
|
|
|
f312c6 |
index 2621cb2f19..8d4f53eef6 100644
|
|
|
f312c6 |
--- a/daemons/fenced/fenced_remote.c
|
|
|
f312c6 |
+++ b/daemons/fenced/fenced_remote.c
|
|
|
f312c6 |
@@ -362,13 +362,12 @@ undo_op_remap(remote_fencing_op_t *op)
|
|
|
f312c6 |
* \brief Create notification data XML for a fencing operation result
|
|
|
f312c6 |
*
|
|
|
f312c6 |
* \param[in] op Fencer operation that completed
|
|
|
f312c6 |
- * \param[in] result Full operation result
|
|
|
f312c6 |
*
|
|
|
f312c6 |
* \return Newly created XML to add as notification data
|
|
|
f312c6 |
* \note The caller is responsible for freeing the result.
|
|
|
f312c6 |
*/
|
|
|
f312c6 |
static xmlNode *
|
|
|
f312c6 |
-fencing_result2xml(remote_fencing_op_t *op, pcmk__action_result_t *result)
|
|
|
f312c6 |
+fencing_result2xml(remote_fencing_op_t *op)
|
|
|
f312c6 |
{
|
|
|
f312c6 |
xmlNode *notify_data = create_xml_node(NULL, T_STONITH_NOTIFY_FENCE);
|
|
|
f312c6 |
|
|
|
f312c6 |
@@ -381,7 +380,7 @@ fencing_result2xml(remote_fencing_op_t *op, pcmk__action_result_t *result)
|
|
|
f312c6 |
crm_xml_add(notify_data, F_STONITH_CLIENTID, op->client_id);
|
|
|
f312c6 |
crm_xml_add(notify_data, F_STONITH_CLIENTNAME, op->client_name);
|
|
|
f312c6 |
|
|
|
f312c6 |
- stonith__xe_set_result(notify_data, result);
|
|
|
f312c6 |
+ stonith__xe_set_result(notify_data, &op->result);
|
|
|
f312c6 |
return notify_data;
|
|
|
f312c6 |
}
|
|
|
f312c6 |
|
|
|
f312c6 |
@@ -397,7 +396,7 @@ fenced_broadcast_op_result(remote_fencing_op_t *op, bool op_merged)
|
|
|
f312c6 |
{
|
|
|
f312c6 |
static int count = 0;
|
|
|
f312c6 |
xmlNode *bcast = create_xml_node(NULL, T_STONITH_REPLY);
|
|
|
f312c6 |
- xmlNode *notify_data = fencing_result2xml(op, &op->result);
|
|
|
f312c6 |
+ xmlNode *notify_data = fencing_result2xml(op);
|
|
|
f312c6 |
|
|
|
f312c6 |
count++;
|
|
|
f312c6 |
crm_trace("Broadcasting result to peers");
|
|
|
f312c6 |
@@ -448,7 +447,7 @@ handle_local_reply_and_notify(remote_fencing_op_t *op, xmlNode *data)
|
|
|
f312c6 |
do_local_reply(reply, op->client_id, op->call_options & st_opt_sync_call, FALSE);
|
|
|
f312c6 |
|
|
|
f312c6 |
/* bcast to all local clients that the fencing operation happend */
|
|
|
f312c6 |
- notify_data = fencing_result2xml(op, &op->result);
|
|
|
f312c6 |
+ notify_data = fencing_result2xml(op);
|
|
|
f312c6 |
fenced_send_notification(T_STONITH_NOTIFY_FENCE, &op->result, notify_data);
|
|
|
f312c6 |
free_xml(notify_data);
|
|
|
f312c6 |
fenced_send_notification(T_STONITH_NOTIFY_HISTORY, NULL, NULL);
|
|
|
f312c6 |
--
|
|
|
f312c6 |
2.27.0
|
|
|
f312c6 |
|
|
|
f312c6 |
|
|
|
f312c6 |
From c5d38cb201a1219ca95127cba9c3a778e31966a2 Mon Sep 17 00:00:00 2001
|
|
|
f312c6 |
From: Ken Gaillot <kgaillot@redhat.com>
|
|
|
f312c6 |
Date: Thu, 6 Jan 2022 17:35:43 -0600
|
|
|
f312c6 |
Subject: [PATCH 07/15] Refactor: fencer: drop redundant argument from
|
|
|
f312c6 |
request_peer_fencing()
|
|
|
f312c6 |
|
|
|
f312c6 |
... now that the op includes the result
|
|
|
f312c6 |
---
|
|
|
f312c6 |
daemons/fenced/fenced_remote.c | 66 +++++++++++++---------------------
|
|
|
f312c6 |
1 file changed, 25 insertions(+), 41 deletions(-)
|
|
|
f312c6 |
|
|
|
f312c6 |
diff --git a/daemons/fenced/fenced_remote.c b/daemons/fenced/fenced_remote.c
|
|
|
f312c6 |
index 8d4f53eef6..7fb7695fba 100644
|
|
|
f312c6 |
--- a/daemons/fenced/fenced_remote.c
|
|
|
f312c6 |
+++ b/daemons/fenced/fenced_remote.c
|
|
|
f312c6 |
@@ -80,8 +80,7 @@ extern xmlNode *stonith_create_op(int call_id, const char *token, const char *op
|
|
|
f312c6 |
int call_options);
|
|
|
f312c6 |
|
|
|
f312c6 |
static void request_peer_fencing(remote_fencing_op_t *op,
|
|
|
f312c6 |
- peer_device_info_t *peer,
|
|
|
f312c6 |
- pcmk__action_result_t *result);
|
|
|
f312c6 |
+ peer_device_info_t *peer);
|
|
|
f312c6 |
static void finalize_op(remote_fencing_op_t *op, xmlNode *data, bool dup);
|
|
|
f312c6 |
static void report_timeout_period(remote_fencing_op_t * op, int op_timeout);
|
|
|
f312c6 |
static int get_op_total_timeout(const remote_fencing_op_t *op,
|
|
|
f312c6 |
@@ -646,18 +645,16 @@ static gboolean
|
|
|
f312c6 |
remote_op_timeout_one(gpointer userdata)
|
|
|
f312c6 |
{
|
|
|
f312c6 |
remote_fencing_op_t *op = userdata;
|
|
|
f312c6 |
- pcmk__action_result_t result = PCMK__UNKNOWN_RESULT;
|
|
|
f312c6 |
|
|
|
f312c6 |
op->op_timer_one = 0;
|
|
|
f312c6 |
|
|
|
f312c6 |
crm_notice("Peer's '%s' action targeting %s for client %s timed out " CRM_XS
|
|
|
f312c6 |
" id=%.8s", op->action, op->target, op->client_name, op->id);
|
|
|
f312c6 |
- pcmk__set_result(&result, CRM_EX_ERROR, PCMK_EXEC_TIMEOUT,
|
|
|
f312c6 |
+ pcmk__set_result(&op->result, CRM_EX_ERROR, PCMK_EXEC_TIMEOUT,
|
|
|
f312c6 |
"Peer did not return fence result within timeout");
|
|
|
f312c6 |
|
|
|
f312c6 |
-
|
|
|
f312c6 |
// Try another device, if appropriate
|
|
|
f312c6 |
- request_peer_fencing(op, NULL, &result);
|
|
|
f312c6 |
+ request_peer_fencing(op, NULL);
|
|
|
f312c6 |
return FALSE;
|
|
|
f312c6 |
}
|
|
|
f312c6 |
|
|
|
f312c6 |
@@ -730,13 +727,10 @@ remote_op_query_timeout(gpointer data)
|
|
|
f312c6 |
crm_debug("Operation %.8s targeting %s already in progress",
|
|
|
f312c6 |
op->id, op->target);
|
|
|
f312c6 |
} else if (op->query_results) {
|
|
|
f312c6 |
- // Result won't be used in this case, but we need to pass something
|
|
|
f312c6 |
- pcmk__action_result_t result = PCMK__UNKNOWN_RESULT;
|
|
|
f312c6 |
-
|
|
|
f312c6 |
// Query succeeded, so attempt the actual fencing
|
|
|
f312c6 |
crm_debug("Query %.8s targeting %s complete (state=%s)",
|
|
|
f312c6 |
op->id, op->target, stonith_op_state_str(op->state));
|
|
|
f312c6 |
- request_peer_fencing(op, NULL, &result);
|
|
|
f312c6 |
+ request_peer_fencing(op, NULL);
|
|
|
f312c6 |
} else {
|
|
|
f312c6 |
crm_debug("Query %.8s targeting %s timed out (state=%s)",
|
|
|
f312c6 |
op->id, op->target, stonith_op_state_str(op->state));
|
|
|
f312c6 |
@@ -1622,11 +1616,10 @@ advance_topology_device_in_level(remote_fencing_op_t *op, const char *device,
|
|
|
f312c6 |
op_phase_on(op);
|
|
|
f312c6 |
}
|
|
|
f312c6 |
|
|
|
f312c6 |
- if (op->devices) {
|
|
|
f312c6 |
- pcmk__action_result_t result = PCMK__UNKNOWN_RESULT;
|
|
|
f312c6 |
-
|
|
|
f312c6 |
- pcmk__set_result(&result, CRM_EX_OK, PCMK_EXEC_DONE, NULL);
|
|
|
f312c6 |
+ // This function is only called if the previous device succeeded
|
|
|
f312c6 |
+ pcmk__set_result(&op->result, CRM_EX_OK, PCMK_EXEC_DONE, NULL);
|
|
|
f312c6 |
|
|
|
f312c6 |
+ if (op->devices) {
|
|
|
f312c6 |
/* Necessary devices remain, so execute the next one */
|
|
|
f312c6 |
crm_trace("Next targeting %s on behalf of %s@%s",
|
|
|
f312c6 |
op->target, op->client_name, op->originator);
|
|
|
f312c6 |
@@ -1636,13 +1629,12 @@ advance_topology_device_in_level(remote_fencing_op_t *op, const char *device,
|
|
|
f312c6 |
op->delay = 0;
|
|
|
f312c6 |
}
|
|
|
f312c6 |
|
|
|
f312c6 |
- request_peer_fencing(op, NULL, &result);
|
|
|
f312c6 |
+ request_peer_fencing(op, NULL);
|
|
|
f312c6 |
} else {
|
|
|
f312c6 |
/* We're done with all devices and phases, so finalize operation */
|
|
|
f312c6 |
crm_trace("Marking complex fencing op targeting %s as complete",
|
|
|
f312c6 |
op->target);
|
|
|
f312c6 |
op->state = st_done;
|
|
|
f312c6 |
- pcmk__set_result(&op->result, CRM_EX_OK, PCMK_EXEC_DONE, NULL);
|
|
|
f312c6 |
finalize_op(op, msg, false);
|
|
|
f312c6 |
}
|
|
|
f312c6 |
}
|
|
|
f312c6 |
@@ -1673,13 +1665,9 @@ check_watchdog_fencing_and_wait(remote_fencing_op_t * op)
|
|
|
f312c6 |
* \param[in] op Fencing operation to be executed
|
|
|
f312c6 |
* \param[in] peer If NULL or topology is in use, choose best peer to execute
|
|
|
f312c6 |
* the fencing, otherwise use this peer
|
|
|
f312c6 |
- * \param[in] result Full result of previous failed attempt, if any (used as
|
|
|
f312c6 |
- * final result only if a previous attempt failed, topology
|
|
|
f312c6 |
- * is not in use, and no devices remain to be attempted)
|
|
|
f312c6 |
*/
|
|
|
f312c6 |
static void
|
|
|
f312c6 |
-request_peer_fencing(remote_fencing_op_t *op, peer_device_info_t *peer,
|
|
|
f312c6 |
- pcmk__action_result_t *result)
|
|
|
f312c6 |
+request_peer_fencing(remote_fencing_op_t *op, peer_device_info_t *peer)
|
|
|
f312c6 |
{
|
|
|
f312c6 |
const char *device = NULL;
|
|
|
f312c6 |
int timeout;
|
|
|
f312c6 |
@@ -1822,27 +1810,26 @@ request_peer_fencing(remote_fencing_op_t *op, peer_device_info_t *peer,
|
|
|
f312c6 |
}
|
|
|
f312c6 |
}
|
|
|
f312c6 |
|
|
|
f312c6 |
- // This is the only case in which result will be used
|
|
|
f312c6 |
- CRM_CHECK(result != NULL, return);
|
|
|
f312c6 |
-
|
|
|
f312c6 |
if (op->state == st_query) {
|
|
|
f312c6 |
crm_info("No peers (out of %d) have devices capable of fencing "
|
|
|
f312c6 |
"(%s) %s for client %s " CRM_XS " state=%s",
|
|
|
f312c6 |
op->replies, op->action, op->target, op->client_name,
|
|
|
f312c6 |
stonith_op_state_str(op->state));
|
|
|
f312c6 |
|
|
|
f312c6 |
- pcmk__reset_result(result);
|
|
|
f312c6 |
- pcmk__set_result(result, CRM_EX_ERROR, PCMK_EXEC_NO_FENCE_DEVICE,
|
|
|
f312c6 |
- NULL);
|
|
|
f312c6 |
+ pcmk__reset_result(&op->result);
|
|
|
f312c6 |
+ pcmk__set_result(&op->result, CRM_EX_ERROR,
|
|
|
f312c6 |
+ PCMK_EXEC_NO_FENCE_DEVICE, NULL);
|
|
|
f312c6 |
} else {
|
|
|
f312c6 |
if (pcmk_is_set(op->call_options, st_opt_topology)) {
|
|
|
f312c6 |
- pcmk__reset_result(result);
|
|
|
f312c6 |
- pcmk__set_result(result, CRM_EX_ERROR,
|
|
|
f312c6 |
+ pcmk__reset_result(&op->result);
|
|
|
f312c6 |
+ pcmk__set_result(&op->result, CRM_EX_ERROR,
|
|
|
f312c6 |
PCMK_EXEC_NO_FENCE_DEVICE, NULL);
|
|
|
f312c6 |
}
|
|
|
f312c6 |
- /* ... else use result provided by caller -- overwriting it with
|
|
|
f312c6 |
- PCMK_EXEC_NO_FENCE_DEVICE would prevent finalize_op() from
|
|
|
f312c6 |
- setting the correct delegate if needed.
|
|
|
f312c6 |
+ /* ... else use existing result from previous failed attempt
|
|
|
f312c6 |
+ * (topology is not in use, and no devices remain to be attempted).
|
|
|
f312c6 |
+ * Overwriting the result with PCMK_EXEC_NO_FENCE_DEVICE would
|
|
|
f312c6 |
+ * prevent finalize_op() from setting the correct delegate if
|
|
|
f312c6 |
+ * needed.
|
|
|
f312c6 |
*/
|
|
|
f312c6 |
|
|
|
f312c6 |
crm_info("No peers (out of %d) are capable of fencing (%s) %s "
|
|
|
f312c6 |
@@ -1852,8 +1839,6 @@ request_peer_fencing(remote_fencing_op_t *op, peer_device_info_t *peer,
|
|
|
f312c6 |
}
|
|
|
f312c6 |
|
|
|
f312c6 |
op->state = st_failed;
|
|
|
f312c6 |
- pcmk__set_result(&op->result, result->exit_status,
|
|
|
f312c6 |
- result->execution_status, result->exit_reason);
|
|
|
f312c6 |
finalize_op(op, NULL, false);
|
|
|
f312c6 |
|
|
|
f312c6 |
} else {
|
|
|
f312c6 |
@@ -2104,7 +2089,6 @@ process_remote_stonith_query(xmlNode * msg)
|
|
|
f312c6 |
peer_device_info_t *peer = NULL;
|
|
|
f312c6 |
uint32_t replies_expected;
|
|
|
f312c6 |
xmlNode *dev = get_xpath_object("//@" F_STONITH_REMOTE_OP_ID, msg, LOG_ERR);
|
|
|
f312c6 |
- pcmk__action_result_t result = PCMK__UNKNOWN_RESULT;
|
|
|
f312c6 |
|
|
|
f312c6 |
CRM_CHECK(dev != NULL, return -EPROTO);
|
|
|
f312c6 |
|
|
|
f312c6 |
@@ -2139,7 +2123,7 @@ process_remote_stonith_query(xmlNode * msg)
|
|
|
f312c6 |
peer = add_result(op, host, ndevices, dev);
|
|
|
f312c6 |
}
|
|
|
f312c6 |
|
|
|
f312c6 |
- pcmk__set_result(&result, CRM_EX_OK, PCMK_EXEC_DONE, NULL);
|
|
|
f312c6 |
+ pcmk__set_result(&op->result, CRM_EX_OK, PCMK_EXEC_DONE, NULL);
|
|
|
f312c6 |
|
|
|
f312c6 |
if (pcmk_is_set(op->call_options, st_opt_topology)) {
|
|
|
f312c6 |
/* If we start the fencing before all the topology results are in,
|
|
|
f312c6 |
@@ -2148,12 +2132,12 @@ process_remote_stonith_query(xmlNode * msg)
|
|
|
f312c6 |
if (op->state == st_query && all_topology_devices_found(op)) {
|
|
|
f312c6 |
/* All the query results are in for the topology, start the fencing ops. */
|
|
|
f312c6 |
crm_trace("All topology devices found");
|
|
|
f312c6 |
- request_peer_fencing(op, peer, &result);
|
|
|
f312c6 |
+ request_peer_fencing(op, peer);
|
|
|
f312c6 |
|
|
|
f312c6 |
} else if (have_all_replies) {
|
|
|
f312c6 |
crm_info("All topology query replies have arrived, continuing (%d expected/%d received) ",
|
|
|
f312c6 |
replies_expected, op->replies);
|
|
|
f312c6 |
- request_peer_fencing(op, NULL, &result);
|
|
|
f312c6 |
+ request_peer_fencing(op, NULL);
|
|
|
f312c6 |
}
|
|
|
f312c6 |
|
|
|
f312c6 |
} else if (op->state == st_query) {
|
|
|
f312c6 |
@@ -2165,12 +2149,12 @@ process_remote_stonith_query(xmlNode * msg)
|
|
|
f312c6 |
/* we have a verified device living on a peer that is not the target */
|
|
|
f312c6 |
crm_trace("Found %d verified device%s",
|
|
|
f312c6 |
nverified, pcmk__plural_s(nverified));
|
|
|
f312c6 |
- request_peer_fencing(op, peer, &result);
|
|
|
f312c6 |
+ request_peer_fencing(op, peer);
|
|
|
f312c6 |
|
|
|
f312c6 |
} else if (have_all_replies) {
|
|
|
f312c6 |
crm_info("All query replies have arrived, continuing (%d expected/%d received) ",
|
|
|
f312c6 |
replies_expected, op->replies);
|
|
|
f312c6 |
- request_peer_fencing(op, NULL, &result);
|
|
|
f312c6 |
+ request_peer_fencing(op, NULL);
|
|
|
f312c6 |
|
|
|
f312c6 |
} else {
|
|
|
f312c6 |
crm_trace("Waiting for more peer results before launching fencing operation");
|
|
|
f312c6 |
@@ -2336,7 +2320,7 @@ fenced_process_fencing_reply(xmlNode *msg)
|
|
|
f312c6 |
crm_trace("Next for %s on behalf of %s@%s (result was: %s)",
|
|
|
f312c6 |
op->target, op->originator, op->client_name,
|
|
|
f312c6 |
pcmk_exec_status_str(op->result.execution_status));
|
|
|
f312c6 |
- request_peer_fencing(op, NULL, &op->result);
|
|
|
f312c6 |
+ request_peer_fencing(op, NULL);
|
|
|
f312c6 |
}
|
|
|
f312c6 |
|
|
|
f312c6 |
gboolean
|
|
|
f312c6 |
--
|
|
|
f312c6 |
2.27.0
|
|
|
f312c6 |
|
|
|
f312c6 |
|
|
|
f312c6 |
From be0a0b652c13161a82b05d3104449b7bfc06e8ac Mon Sep 17 00:00:00 2001
|
|
|
f312c6 |
From: Ken Gaillot <kgaillot@redhat.com>
|
|
|
f312c6 |
Date: Thu, 6 Jan 2022 17:56:24 -0600
|
|
|
f312c6 |
Subject: [PATCH 08/15] Feature: fencer: track full result in fencing history
|
|
|
f312c6 |
|
|
|
f312c6 |
Add fencing operation results when creating XML in
|
|
|
f312c6 |
stonith_local_history_diff_and_merge(), and parse the results from the received
|
|
|
f312c6 |
XML in stonith_xml_history_to_list().
|
|
|
f312c6 |
|
|
|
f312c6 |
With this, the fencer now always has full results in its op list, and returns
|
|
|
f312c6 |
them in the reply for STONITH_OP_FENCE_HISTORY requests (though nothing uses
|
|
|
f312c6 |
that as of this commit).
|
|
|
f312c6 |
---
|
|
|
f312c6 |
daemons/fenced/fenced_history.c | 2 ++
|
|
|
f312c6 |
1 file changed, 2 insertions(+)
|
|
|
f312c6 |
|
|
|
f312c6 |
diff --git a/daemons/fenced/fenced_history.c b/daemons/fenced/fenced_history.c
|
|
|
f312c6 |
index 5cacf36ca8..3ebf016e67 100644
|
|
|
f312c6 |
--- a/daemons/fenced/fenced_history.c
|
|
|
f312c6 |
+++ b/daemons/fenced/fenced_history.c
|
|
|
f312c6 |
@@ -257,6 +257,7 @@ stonith_xml_history_to_list(xmlNode *history)
|
|
|
f312c6 |
op->completed_nsec = completed_nsec;
|
|
|
f312c6 |
crm_element_value_int(xml_op, F_STONITH_STATE, &state);
|
|
|
f312c6 |
op->state = (enum op_state) state;
|
|
|
f312c6 |
+ stonith__xe_get_result(xml_op, &op->result);
|
|
|
f312c6 |
|
|
|
f312c6 |
g_hash_table_replace(rv, id, op);
|
|
|
f312c6 |
CRM_LOG_ASSERT(g_hash_table_lookup(rv, id) != NULL);
|
|
|
f312c6 |
@@ -355,6 +356,7 @@ stonith_local_history_diff_and_merge(GHashTable *remote_history,
|
|
|
f312c6 |
crm_xml_add_ll(entry, F_STONITH_DATE, op->completed);
|
|
|
f312c6 |
crm_xml_add_ll(entry, F_STONITH_DATE_NSEC, op->completed_nsec);
|
|
|
f312c6 |
crm_xml_add_int(entry, F_STONITH_STATE, op->state);
|
|
|
f312c6 |
+ stonith__xe_set_result(entry, &op->result);
|
|
|
f312c6 |
}
|
|
|
f312c6 |
}
|
|
|
f312c6 |
|
|
|
f312c6 |
--
|
|
|
f312c6 |
2.27.0
|
|
|
f312c6 |
|
|
|
f312c6 |
|
|
|
f312c6 |
From afc5292036e212bcfc7475893e0b326b2a69ac58 Mon Sep 17 00:00:00 2001
|
|
|
f312c6 |
From: Ken Gaillot <kgaillot@redhat.com>
|
|
|
f312c6 |
Date: Wed, 22 Dec 2021 17:17:21 -0600
|
|
|
f312c6 |
Subject: [PATCH 09/15] API: libstonithd: add exit_reason member to
|
|
|
f312c6 |
stonith_history_t
|
|
|
f312c6 |
|
|
|
f312c6 |
not yet used, but will be
|
|
|
f312c6 |
---
|
|
|
f312c6 |
include/crm/stonith-ng.h | 3 ++-
|
|
|
f312c6 |
lib/fencing/st_client.c | 3 ++-
|
|
|
f312c6 |
2 files changed, 4 insertions(+), 2 deletions(-)
|
|
|
f312c6 |
|
|
|
f312c6 |
diff --git a/include/crm/stonith-ng.h b/include/crm/stonith-ng.h
|
|
|
f312c6 |
index 3fe9cf54f8..2c79bfa579 100644
|
|
|
f312c6 |
--- a/include/crm/stonith-ng.h
|
|
|
f312c6 |
+++ b/include/crm/stonith-ng.h
|
|
|
f312c6 |
@@ -1,5 +1,5 @@
|
|
|
f312c6 |
/*
|
|
|
f312c6 |
- * Copyright 2004-2021 the Pacemaker project contributors
|
|
|
f312c6 |
+ * Copyright 2004-2022 the Pacemaker project contributors
|
|
|
f312c6 |
*
|
|
|
f312c6 |
* The version control history for this file may have further details.
|
|
|
f312c6 |
*
|
|
|
f312c6 |
@@ -111,6 +111,7 @@ typedef struct stonith_history_s {
|
|
|
f312c6 |
time_t completed;
|
|
|
f312c6 |
struct stonith_history_s *next;
|
|
|
f312c6 |
long completed_nsec;
|
|
|
f312c6 |
+ char *exit_reason;
|
|
|
f312c6 |
} stonith_history_t;
|
|
|
f312c6 |
|
|
|
f312c6 |
typedef struct stonith_s stonith_t;
|
|
|
f312c6 |
diff --git a/lib/fencing/st_client.c b/lib/fencing/st_client.c
|
|
|
f312c6 |
index 718739b321..57a2e03361 100644
|
|
|
f312c6 |
--- a/lib/fencing/st_client.c
|
|
|
f312c6 |
+++ b/lib/fencing/st_client.c
|
|
|
f312c6 |
@@ -1,5 +1,5 @@
|
|
|
f312c6 |
/*
|
|
|
f312c6 |
- * Copyright 2004-2021 the Pacemaker project contributors
|
|
|
f312c6 |
+ * Copyright 2004-2022 the Pacemaker project contributors
|
|
|
f312c6 |
*
|
|
|
f312c6 |
* The version control history for this file may have further details.
|
|
|
f312c6 |
*
|
|
|
f312c6 |
@@ -735,6 +735,7 @@ void stonith_history_free(stonith_history_t *history)
|
|
|
f312c6 |
free(hp->origin);
|
|
|
f312c6 |
free(hp->delegate);
|
|
|
f312c6 |
free(hp->client);
|
|
|
f312c6 |
+ free(hp->exit_reason);
|
|
|
f312c6 |
}
|
|
|
f312c6 |
}
|
|
|
f312c6 |
|
|
|
f312c6 |
--
|
|
|
f312c6 |
2.27.0
|
|
|
f312c6 |
|
|
|
f312c6 |
|
|
|
f312c6 |
From 1b9e2896322849002a5c0a3a34c9375ea32571d6 Mon Sep 17 00:00:00 2001
|
|
|
f312c6 |
From: Ken Gaillot <kgaillot@redhat.com>
|
|
|
f312c6 |
Date: Thu, 6 Jan 2022 18:04:15 -0600
|
|
|
f312c6 |
Subject: [PATCH 10/15] Feature: fencing: return exit reason with fencing
|
|
|
f312c6 |
history
|
|
|
f312c6 |
|
|
|
f312c6 |
libstonithd's stonith_t:cmds->history() method now parses exit reasons from the
|
|
|
f312c6 |
fencer reply, and returns them in the stonith_history_t results.
|
|
|
f312c6 |
---
|
|
|
f312c6 |
lib/fencing/st_client.c | 6 ++++++
|
|
|
f312c6 |
1 file changed, 6 insertions(+)
|
|
|
f312c6 |
|
|
|
f312c6 |
diff --git a/lib/fencing/st_client.c b/lib/fencing/st_client.c
|
|
|
f312c6 |
index 57a2e03361..d229b34805 100644
|
|
|
f312c6 |
--- a/lib/fencing/st_client.c
|
|
|
f312c6 |
+++ b/lib/fencing/st_client.c
|
|
|
f312c6 |
@@ -698,6 +698,7 @@ stonith_api_history(stonith_t * stonith, int call_options, const char *node,
|
|
|
f312c6 |
stonith_history_t *kvp;
|
|
|
f312c6 |
long long completed;
|
|
|
f312c6 |
long long completed_nsec = 0L;
|
|
|
f312c6 |
+ pcmk__action_result_t result = PCMK__UNKNOWN_RESULT;
|
|
|
f312c6 |
|
|
|
f312c6 |
kvp = calloc(1, sizeof(stonith_history_t));
|
|
|
f312c6 |
kvp->target = crm_element_value_copy(op, F_STONITH_TARGET);
|
|
|
f312c6 |
@@ -711,6 +712,11 @@ stonith_api_history(stonith_t * stonith, int call_options, const char *node,
|
|
|
f312c6 |
kvp->completed_nsec = completed_nsec;
|
|
|
f312c6 |
crm_element_value_int(op, F_STONITH_STATE, &kvp->state);
|
|
|
f312c6 |
|
|
|
f312c6 |
+ stonith__xe_get_result(op, &result);
|
|
|
f312c6 |
+ kvp->exit_reason = result.exit_reason;
|
|
|
f312c6 |
+ result.exit_reason = NULL;
|
|
|
f312c6 |
+ pcmk__reset_result(&result);
|
|
|
f312c6 |
+
|
|
|
f312c6 |
if (last) {
|
|
|
f312c6 |
last->next = kvp;
|
|
|
f312c6 |
} else {
|
|
|
f312c6 |
--
|
|
|
f312c6 |
2.27.0
|
|
|
f312c6 |
|
|
|
f312c6 |
|
|
|
f312c6 |
From ba4e77242e9be4ebeb2843b444ee4afad43c29f3 Mon Sep 17 00:00:00 2001
|
|
|
f312c6 |
From: Ken Gaillot <kgaillot@redhat.com>
|
|
|
f312c6 |
Date: Fri, 7 Jan 2022 09:44:39 -0600
|
|
|
f312c6 |
Subject: [PATCH 11/15] Feature: fencing: display exit reasons with failed
|
|
|
f312c6 |
fencing events
|
|
|
f312c6 |
|
|
|
f312c6 |
... when available
|
|
|
f312c6 |
---
|
|
|
f312c6 |
lib/fencing/st_output.c | 20 ++++++++++++++++----
|
|
|
f312c6 |
tools/crm_mon_curses.c | 9 +++++++--
|
|
|
f312c6 |
2 files changed, 23 insertions(+), 6 deletions(-)
|
|
|
f312c6 |
|
|
|
f312c6 |
diff --git a/lib/fencing/st_output.c b/lib/fencing/st_output.c
|
|
|
f312c6 |
index e484278867..18924d795d 100644
|
|
|
f312c6 |
--- a/lib/fencing/st_output.c
|
|
|
f312c6 |
+++ b/lib/fencing/st_output.c
|
|
|
f312c6 |
@@ -1,5 +1,5 @@
|
|
|
f312c6 |
/*
|
|
|
f312c6 |
- * Copyright 2019-2021 the Pacemaker project contributors
|
|
|
f312c6 |
+ * Copyright 2019-2022 the Pacemaker project contributors
|
|
|
f312c6 |
*
|
|
|
f312c6 |
* The version control history for this file may have further details.
|
|
|
f312c6 |
*
|
|
|
f312c6 |
@@ -11,6 +11,7 @@
|
|
|
f312c6 |
#include <stdarg.h>
|
|
|
f312c6 |
|
|
|
f312c6 |
#include <crm/stonith-ng.h>
|
|
|
f312c6 |
+#include <crm/msg_xml.h>
|
|
|
f312c6 |
#include <crm/common/iso8601.h>
|
|
|
f312c6 |
#include <crm/common/util.h>
|
|
|
f312c6 |
#include <crm/common/xml.h>
|
|
|
f312c6 |
@@ -263,8 +264,12 @@ stonith_event_html(pcmk__output_t *out, va_list args) {
|
|
|
f312c6 |
char *failed_s = time_t_string(event->completed);
|
|
|
f312c6 |
|
|
|
f312c6 |
out->list_item(out, "failed-stonith-event",
|
|
|
f312c6 |
- "%s of %s failed : delegate=%s, client=%s, origin=%s, %s='%s' %s",
|
|
|
f312c6 |
+ "%s of %s failed%s%s%s: "
|
|
|
f312c6 |
+ "delegate=%s, client=%s, origin=%s, %s='%s' %s",
|
|
|
f312c6 |
stonith_action_str(event->action), event->target,
|
|
|
f312c6 |
+ (event->exit_reason == NULL)? "" : " (",
|
|
|
f312c6 |
+ (event->exit_reason == NULL)? "" : event->exit_reason,
|
|
|
f312c6 |
+ (event->exit_reason == NULL)? "" : ")",
|
|
|
f312c6 |
event->delegate ? event->delegate : "",
|
|
|
f312c6 |
event->client, event->origin,
|
|
|
f312c6 |
full_history ? "completed" : "last-failed",
|
|
|
f312c6 |
@@ -296,8 +301,13 @@ stonith_event_text(pcmk__output_t *out, va_list args) {
|
|
|
f312c6 |
|
|
|
f312c6 |
switch (event->state) {
|
|
|
f312c6 |
case st_failed:
|
|
|
f312c6 |
- pcmk__indented_printf(out, "%s of %s failed: delegate=%s, client=%s, origin=%s, %s='%s' %s\n",
|
|
|
f312c6 |
+ pcmk__indented_printf(out,
|
|
|
f312c6 |
+ "%s of %s failed%s%s%s: "
|
|
|
f312c6 |
+ "delegate=%s, client=%s, origin=%s, %s='%s' %s\n",
|
|
|
f312c6 |
stonith_action_str(event->action), event->target,
|
|
|
f312c6 |
+ (event->exit_reason == NULL)? "" : " (",
|
|
|
f312c6 |
+ (event->exit_reason == NULL)? "" : event->exit_reason,
|
|
|
f312c6 |
+ (event->exit_reason == NULL)? "" : ")",
|
|
|
f312c6 |
event->delegate ? event->delegate : "",
|
|
|
f312c6 |
event->client, event->origin,
|
|
|
f312c6 |
full_history ? "completed" : "last-failed", buf,
|
|
|
f312c6 |
@@ -341,7 +351,9 @@ stonith_event_xml(pcmk__output_t *out, va_list args) {
|
|
|
f312c6 |
|
|
|
f312c6 |
switch (event->state) {
|
|
|
f312c6 |
case st_failed:
|
|
|
f312c6 |
- crm_xml_add(node, "status", "failed");
|
|
|
f312c6 |
+ pcmk__xe_set_props(node, "status", "failed",
|
|
|
f312c6 |
+ XML_LRM_ATTR_EXIT_REASON, event->exit_reason,
|
|
|
f312c6 |
+ NULL);
|
|
|
f312c6 |
break;
|
|
|
f312c6 |
|
|
|
f312c6 |
case st_done:
|
|
|
f312c6 |
diff --git a/tools/crm_mon_curses.c b/tools/crm_mon_curses.c
|
|
|
f312c6 |
index bae3710c44..73c8516a8c 100644
|
|
|
f312c6 |
--- a/tools/crm_mon_curses.c
|
|
|
f312c6 |
+++ b/tools/crm_mon_curses.c
|
|
|
f312c6 |
@@ -1,5 +1,5 @@
|
|
|
f312c6 |
/*
|
|
|
f312c6 |
- * Copyright 2019-2021 the Pacemaker project contributors
|
|
|
f312c6 |
+ * Copyright 2019-2022 the Pacemaker project contributors
|
|
|
f312c6 |
*
|
|
|
f312c6 |
* The version control history for this file may have further details.
|
|
|
f312c6 |
*
|
|
|
f312c6 |
@@ -463,8 +463,13 @@ stonith_event_console(pcmk__output_t *out, va_list args) {
|
|
|
f312c6 |
|
|
|
f312c6 |
switch (event->state) {
|
|
|
f312c6 |
case st_failed:
|
|
|
f312c6 |
- curses_indented_printf(out, "%s of %s failed: delegate=%s, client=%s, origin=%s, %s='%s'%s\n",
|
|
|
f312c6 |
+ curses_indented_printf(out,
|
|
|
f312c6 |
+ "%s of %s failed%s%s%s: "
|
|
|
f312c6 |
+ "delegate=%s, client=%s, origin=%s, %s='%s' %s\n",
|
|
|
f312c6 |
stonith_action_str(event->action), event->target,
|
|
|
f312c6 |
+ (event->exit_reason == NULL)? "" : " (",
|
|
|
f312c6 |
+ (event->exit_reason == NULL)? "" : event->exit_reason,
|
|
|
f312c6 |
+ (event->exit_reason == NULL)? "" : ")",
|
|
|
f312c6 |
event->delegate ? event->delegate : "",
|
|
|
f312c6 |
event->client, event->origin,
|
|
|
f312c6 |
full_history ? "completed" : "last-failed", buf,
|
|
|
f312c6 |
--
|
|
|
f312c6 |
2.27.0
|
|
|
f312c6 |
|
|
|
f312c6 |
|
|
|
f312c6 |
From 8105fb4a3a786780fdf85b3d0308eaf6df1ea434 Mon Sep 17 00:00:00 2001
|
|
|
f312c6 |
From: Ken Gaillot <kgaillot@redhat.com>
|
|
|
f312c6 |
Date: Fri, 7 Jan 2022 09:45:22 -0600
|
|
|
f312c6 |
Subject: [PATCH 12/15] Low: schemas: copy fence-event API schema in
|
|
|
f312c6 |
preparation for changes
|
|
|
f312c6 |
|
|
|
f312c6 |
---
|
|
|
f312c6 |
include/crm/common/output_internal.h | 2 +-
|
|
|
f312c6 |
xml/api/fence-event-2.15.rng | 33 ++++++++++++++++++++++++++++
|
|
|
f312c6 |
2 files changed, 34 insertions(+), 1 deletion(-)
|
|
|
f312c6 |
create mode 100644 xml/api/fence-event-2.15.rng
|
|
|
f312c6 |
|
|
|
f312c6 |
diff --git a/include/crm/common/output_internal.h b/include/crm/common/output_internal.h
|
|
|
f312c6 |
index 479f0e4b43..8c5dcee17c 100644
|
|
|
f312c6 |
--- a/include/crm/common/output_internal.h
|
|
|
f312c6 |
+++ b/include/crm/common/output_internal.h
|
|
|
f312c6 |
@@ -27,7 +27,7 @@ extern "C" {
|
|
|
f312c6 |
# include <glib.h>
|
|
|
f312c6 |
# include <crm/common/results.h>
|
|
|
f312c6 |
|
|
|
f312c6 |
-# define PCMK__API_VERSION "2.14"
|
|
|
f312c6 |
+# define PCMK__API_VERSION "2.15"
|
|
|
f312c6 |
|
|
|
f312c6 |
#if defined(PCMK__WITH_ATTRIBUTE_OUTPUT_ARGS)
|
|
|
f312c6 |
# define PCMK__OUTPUT_ARGS(ARGS...) __attribute__((output_args(ARGS)))
|
|
|
f312c6 |
diff --git a/xml/api/fence-event-2.15.rng b/xml/api/fence-event-2.15.rng
|
|
|
f312c6 |
new file mode 100644
|
|
|
f312c6 |
index 0000000000..e54687cd25
|
|
|
f312c6 |
--- /dev/null
|
|
|
f312c6 |
+++ b/xml/api/fence-event-2.15.rng
|
|
|
f312c6 |
@@ -0,0 +1,33 @@
|
|
|
f312c6 |
+
|
|
|
f312c6 |
+
|
|
|
f312c6 |
+ datatypeLibrary="http://www.w3.org/2001/XMLSchema-datatypes">
|
|
|
f312c6 |
+
|
|
|
f312c6 |
+ <start>
|
|
|
f312c6 |
+ <ref name="fencing-history-event"/>
|
|
|
f312c6 |
+ </start>
|
|
|
f312c6 |
+
|
|
|
f312c6 |
+ <define name="fencing-history-event">
|
|
|
f312c6 |
+ <element name="fence_event">
|
|
|
f312c6 |
+ <attribute name="status">
|
|
|
f312c6 |
+ <choice>
|
|
|
f312c6 |
+ <value>failed</value>
|
|
|
f312c6 |
+ <value>success</value>
|
|
|
f312c6 |
+ <value>pending</value>
|
|
|
f312c6 |
+ </choice>
|
|
|
f312c6 |
+ </attribute>
|
|
|
f312c6 |
+ <optional>
|
|
|
f312c6 |
+ <attribute name="extended-status"> <text /> </attribute>
|
|
|
f312c6 |
+ </optional>
|
|
|
f312c6 |
+ <optional>
|
|
|
f312c6 |
+ <attribute name="delegate"> <text /> </attribute>
|
|
|
f312c6 |
+ </optional>
|
|
|
f312c6 |
+ <attribute name="action"> <text /> </attribute>
|
|
|
f312c6 |
+ <attribute name="target"> <text /> </attribute>
|
|
|
f312c6 |
+ <attribute name="client"> <text /> </attribute>
|
|
|
f312c6 |
+ <attribute name="origin"> <text /> </attribute>
|
|
|
f312c6 |
+ <optional>
|
|
|
f312c6 |
+ <attribute name="completed"> <text /> </attribute>
|
|
|
f312c6 |
+ </optional>
|
|
|
f312c6 |
+ </element>
|
|
|
f312c6 |
+ </define>
|
|
|
f312c6 |
+</grammar>
|
|
|
f312c6 |
--
|
|
|
f312c6 |
2.27.0
|
|
|
f312c6 |
|
|
|
f312c6 |
|
|
|
f312c6 |
From 46dd9b74d2ee8f7ab70a0c7fe3a998954d4029e8 Mon Sep 17 00:00:00 2001
|
|
|
f312c6 |
From: Ken Gaillot <kgaillot@redhat.com>
|
|
|
f312c6 |
Date: Fri, 7 Jan 2022 09:47:16 -0600
|
|
|
f312c6 |
Subject: [PATCH 13/15] Low: schemas: update fence-event API schema for recent
|
|
|
f312c6 |
change
|
|
|
f312c6 |
|
|
|
f312c6 |
---
|
|
|
f312c6 |
xml/api/fence-event-2.15.rng | 3 +++
|
|
|
f312c6 |
1 file changed, 3 insertions(+)
|
|
|
f312c6 |
|
|
|
f312c6 |
diff --git a/xml/api/fence-event-2.15.rng b/xml/api/fence-event-2.15.rng
|
|
|
f312c6 |
index e54687cd25..8e000cafa5 100644
|
|
|
f312c6 |
--- a/xml/api/fence-event-2.15.rng
|
|
|
f312c6 |
+++ b/xml/api/fence-event-2.15.rng
|
|
|
f312c6 |
@@ -18,6 +18,9 @@
|
|
|
f312c6 |
<optional>
|
|
|
f312c6 |
<attribute name="extended-status"> <text /> </attribute>
|
|
|
f312c6 |
</optional>
|
|
|
f312c6 |
+ <optional>
|
|
|
f312c6 |
+ <attribute name="exit-reason"> <text /> </attribute>
|
|
|
f312c6 |
+ </optional>
|
|
|
f312c6 |
<optional>
|
|
|
f312c6 |
<attribute name="delegate"> <text /> </attribute>
|
|
|
f312c6 |
</optional>
|
|
|
f312c6 |
--
|
|
|
f312c6 |
2.27.0
|
|
|
f312c6 |
|
|
|
f312c6 |
|
|
|
f312c6 |
From 350e71772f67f28af6b67f864cbabc481730035c Mon Sep 17 00:00:00 2001
|
|
|
f312c6 |
From: Ken Gaillot <kgaillot@redhat.com>
|
|
|
f312c6 |
Date: Fri, 7 Jan 2022 11:32:09 -0600
|
|
|
f312c6 |
Subject: [PATCH 14/15] Build: libstonithd: bump shared library version
|
|
|
f312c6 |
|
|
|
f312c6 |
... for stonith_history_t change since 2.1.2.
|
|
|
f312c6 |
|
|
|
f312c6 |
The struct should only ever be returned by the library as a pointer, so the
|
|
|
f312c6 |
changes can be considered backward-compatible. Normally we wouldn't bump shared
|
|
|
f312c6 |
library versions mid-cycle, but this will simplify expected backports of this
|
|
|
f312c6 |
change.
|
|
|
f312c6 |
---
|
|
|
f312c6 |
lib/fencing/Makefile.am | 4 ++--
|
|
|
f312c6 |
1 file changed, 2 insertions(+), 2 deletions(-)
|
|
|
f312c6 |
|
|
|
f312c6 |
diff --git a/lib/fencing/Makefile.am b/lib/fencing/Makefile.am
|
|
|
f312c6 |
index 1ffa3e051b..a10ddb88ec 100644
|
|
|
f312c6 |
--- a/lib/fencing/Makefile.am
|
|
|
f312c6 |
+++ b/lib/fencing/Makefile.am
|
|
|
f312c6 |
@@ -2,7 +2,7 @@
|
|
|
f312c6 |
# Original Author: Sun Jiang Dong <sunjd@cn.ibm.com>
|
|
|
f312c6 |
# Copyright 2004 International Business Machines
|
|
|
f312c6 |
#
|
|
|
f312c6 |
-# with later changes copyright 2004-2021 the Pacemaker project contributors.
|
|
|
f312c6 |
+# with later changes copyright 2004-2022 the Pacemaker project contributors.
|
|
|
f312c6 |
# The version control history for this file may have further details.
|
|
|
f312c6 |
#
|
|
|
f312c6 |
# This source code is licensed under the GNU General Public License version 2
|
|
|
f312c6 |
@@ -14,7 +14,7 @@ noinst_HEADERS = fencing_private.h
|
|
|
f312c6 |
|
|
|
f312c6 |
lib_LTLIBRARIES = libstonithd.la
|
|
|
f312c6 |
|
|
|
f312c6 |
-libstonithd_la_LDFLAGS = -version-info 33:0:7
|
|
|
f312c6 |
+libstonithd_la_LDFLAGS = -version-info 34:0:8
|
|
|
f312c6 |
|
|
|
f312c6 |
libstonithd_la_CFLAGS = $(CFLAGS_HARDENED_LIB)
|
|
|
f312c6 |
libstonithd_la_LDFLAGS += $(LDFLAGS_HARDENED_LIB)
|
|
|
f312c6 |
--
|
|
|
f312c6 |
2.27.0
|
|
|
f312c6 |
|
|
|
f312c6 |
|
|
|
f312c6 |
From 63ea88620a62ff0759560a02bb5e284ebdd03eb6 Mon Sep 17 00:00:00 2001
|
|
|
f312c6 |
From: Ken Gaillot <kgaillot@redhat.com>
|
|
|
f312c6 |
Date: Wed, 19 Jan 2022 16:53:45 -0600
|
|
|
f312c6 |
Subject: [PATCH 15/15] Low: fencer: reset op result before grabbing new one
|
|
|
f312c6 |
|
|
|
f312c6 |
just in case
|
|
|
f312c6 |
---
|
|
|
f312c6 |
daemons/fenced/fenced_remote.c | 1 +
|
|
|
f312c6 |
1 file changed, 1 insertion(+)
|
|
|
f312c6 |
|
|
|
f312c6 |
diff --git a/daemons/fenced/fenced_remote.c b/daemons/fenced/fenced_remote.c
|
|
|
f312c6 |
index 7fb7695fba..dc4649e0fc 100644
|
|
|
f312c6 |
--- a/daemons/fenced/fenced_remote.c
|
|
|
f312c6 |
+++ b/daemons/fenced/fenced_remote.c
|
|
|
f312c6 |
@@ -2219,6 +2219,7 @@ fenced_process_fencing_reply(xmlNode *msg)
|
|
|
f312c6 |
return;
|
|
|
f312c6 |
}
|
|
|
f312c6 |
|
|
|
f312c6 |
+ pcmk__reset_result(&op->result);
|
|
|
f312c6 |
op->result = result; // The operation takes ownership of the result
|
|
|
f312c6 |
|
|
|
f312c6 |
if (op->devices && device && !pcmk__str_eq(op->devices->data, device, pcmk__str_casei)) {
|
|
|
f312c6 |
--
|
|
|
f312c6 |
2.27.0
|
|
|
f312c6 |
|