mirror of
https://github.com/samba-team/samba.git
synced 2025-01-03 01:18:10 +03:00
ctdb: send a CTDB_SRVID_START_IPREALLOCATE message after CTDB_EVENT_START_IPREALLOCATE
Event scripts run the "start_ipreallocate" hook in order to notice that some ip addresses in the cluster potentially changed. CTDB_SRVID_START_IPREALLOCATE gives C code a chance to get notified as well once the event scripts are finished. Signed-off-by: Vinit Agnihotri <vagnihotri@ddn.com> Reviewed-by: Martin Schwenke <mschwenke@ddn.com> Reviewed-by: Volker Lendecke <vl@samba.org>
This commit is contained in:
parent
2483a2ae20
commit
7dacbcd0ec
@ -143,6 +143,9 @@ struct ctdb_call {
|
|||||||
/* SRVID to inform clients that CTDB_EVENT_IPREALLOCATED finished */
|
/* SRVID to inform clients that CTDB_EVENT_IPREALLOCATED finished */
|
||||||
#define CTDB_SRVID_IPREALLOCATED 0xF302000000000000LL
|
#define CTDB_SRVID_IPREALLOCATED 0xF302000000000000LL
|
||||||
|
|
||||||
|
/* SRVID to inform clients that CTDB_EVENT_START_IPREALLOCATE finished */
|
||||||
|
#define CTDB_SRVID_START_IPREALLOCATE 0xF303000000000000LL
|
||||||
|
|
||||||
/* SRVID to inform recovery daemon of the node flags - OBSOLETE */
|
/* SRVID to inform recovery daemon of the node flags - OBSOLETE */
|
||||||
#define CTDB_SRVID_SET_NODE_FLAGS 0xF400000000000000LL
|
#define CTDB_SRVID_SET_NODE_FLAGS 0xF400000000000000LL
|
||||||
|
|
||||||
|
@ -304,6 +304,8 @@ static void ctdb_srvid_print(uint64_t srvid, FILE *fp)
|
|||||||
fprintf(fp, "TAKE_IP");
|
fprintf(fp, "TAKE_IP");
|
||||||
} else if (srvid == CTDB_SRVID_IPREALLOCATED) {
|
} else if (srvid == CTDB_SRVID_IPREALLOCATED) {
|
||||||
fprintf(fp, "IPREALLOCATED");
|
fprintf(fp, "IPREALLOCATED");
|
||||||
|
} else if (srvid == CTDB_SRVID_START_IPREALLOCATE) {
|
||||||
|
fprintf(fp, "START_IPREALLOCATE");
|
||||||
} else if (srvid == CTDB_SRVID_SET_NODE_FLAGS) {
|
} else if (srvid == CTDB_SRVID_SET_NODE_FLAGS) {
|
||||||
fprintf(fp, "SET_NODE_FLAGS");
|
fprintf(fp, "SET_NODE_FLAGS");
|
||||||
} else if (srvid == CTDB_SRVID_RECD_UPDATE_IP) {
|
} else if (srvid == CTDB_SRVID_RECD_UPDATE_IP) {
|
||||||
|
@ -60,6 +60,9 @@ static size_t ctdb_message_data_len(union ctdb_message_data *mdata,
|
|||||||
case CTDB_SRVID_IPREALLOCATED:
|
case CTDB_SRVID_IPREALLOCATED:
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case CTDB_SRVID_START_IPREALLOCATE:
|
||||||
|
break;
|
||||||
|
|
||||||
case CTDB_SRVID_SET_NODE_FLAGS:
|
case CTDB_SRVID_SET_NODE_FLAGS:
|
||||||
len = ctdb_node_flag_change_len(mdata->flag_change);
|
len = ctdb_node_flag_change_len(mdata->flag_change);
|
||||||
break;
|
break;
|
||||||
@ -154,6 +157,9 @@ static void ctdb_message_data_push(union ctdb_message_data *mdata,
|
|||||||
case CTDB_SRVID_IPREALLOCATED:
|
case CTDB_SRVID_IPREALLOCATED:
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case CTDB_SRVID_START_IPREALLOCATE:
|
||||||
|
break;
|
||||||
|
|
||||||
case CTDB_SRVID_SET_NODE_FLAGS:
|
case CTDB_SRVID_SET_NODE_FLAGS:
|
||||||
ctdb_node_flag_change_push(mdata->flag_change, buf, &np);
|
ctdb_node_flag_change_push(mdata->flag_change, buf, &np);
|
||||||
break;
|
break;
|
||||||
@ -253,6 +259,9 @@ static int ctdb_message_data_pull(uint8_t *buf, size_t buflen,
|
|||||||
case CTDB_SRVID_IPREALLOCATED:
|
case CTDB_SRVID_IPREALLOCATED:
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case CTDB_SRVID_START_IPREALLOCATE:
|
||||||
|
break;
|
||||||
|
|
||||||
case CTDB_SRVID_SET_NODE_FLAGS:
|
case CTDB_SRVID_SET_NODE_FLAGS:
|
||||||
ret = ctdb_node_flag_change_pull(buf, buflen, mem_ctx,
|
ret = ctdb_node_flag_change_pull(buf, buflen, mem_ctx,
|
||||||
&mdata->flag_change, &np);
|
&mdata->flag_change, &np);
|
||||||
|
@ -2458,6 +2458,7 @@ static void ctdb_start_ipreallocate_callback(struct ctdb_context *ctdb,
|
|||||||
{
|
{
|
||||||
struct start_ipreallocate_callback_state *state = talloc_get_type_abort(
|
struct start_ipreallocate_callback_state *state = talloc_get_type_abort(
|
||||||
p, struct start_ipreallocate_callback_state);
|
p, struct start_ipreallocate_callback_state);
|
||||||
|
TDB_DATA data = { .dsize = 0, };
|
||||||
|
|
||||||
if (status != 0) {
|
if (status != 0) {
|
||||||
D_ERR("\"startipreallocate\" event failed (status %d)\n",
|
D_ERR("\"startipreallocate\" event failed (status %d)\n",
|
||||||
@ -2467,6 +2468,12 @@ static void ctdb_start_ipreallocate_callback(struct ctdb_context *ctdb,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
D_INFO("Sending START_IPREALLOCATE message\n");
|
||||||
|
ctdb_daemon_send_message(ctdb,
|
||||||
|
ctdb->pnn,
|
||||||
|
CTDB_SRVID_START_IPREALLOCATE,
|
||||||
|
data);
|
||||||
|
|
||||||
ctdb_request_control_reply(ctdb, state->c, NULL, status, NULL);
|
ctdb_request_control_reply(ctdb, state->c, NULL, status, NULL);
|
||||||
talloc_free(state);
|
talloc_free(state);
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user