 |
pacemaker
2.0.1-9e909a5bdd
Scalable High-Availability cluster resource manager
|
Go to the documentation of this file.
9 # define PE_INTERNAL__H
14 # define pe_rsc_info(rsc, fmt, args...) crm_log_tag(LOG_INFO, rsc ? rsc->id : "<NULL>", fmt, ##args)
15 # define pe_rsc_debug(rsc, fmt, args...) crm_log_tag(LOG_DEBUG, rsc ? rsc->id : "<NULL>", fmt, ##args)
16 # define pe_rsc_trace(rsc, fmt, args...) crm_log_tag(LOG_TRACE, rsc ? rsc->id : "<NULL>", fmt, ##args)
18 # define pe_err(fmt...) { was_processing_error = TRUE; crm_config_error = TRUE; crm_err(fmt); }
19 # define pe_warn(fmt...) { was_processing_warning = TRUE; crm_config_warning = TRUE; crm_warn(fmt); }
20 # define pe_proc_err(fmt...) { was_processing_error = TRUE; crm_err(fmt); }
21 # define pe_proc_warn(fmt...) { was_processing_warning = TRUE; crm_warn(fmt); }
22 # define pe_set_action_bit(action, bit) action->flags = crm_set_bit(__FUNCTION__, __LINE__, action->uuid, action->flags, bit)
23 # define pe_clear_action_bit(action, bit) action->flags = crm_clear_bit(__FUNCTION__, __LINE__, action->uuid, action->flags, bit)
73 void add_hash_param(GHashTable * hash,
const char *name,
const char *value);
140 unsigned int *count_all,
141 unsigned int *count_clean);
143 unsigned int *count);
157 static inline gpointer
158 pe_hash_table_lookup(GHashTable * hash, gconstpointer key)
161 return g_hash_table_lookup(hash, key);
172 extern void print_node(
const char *pre_text,
node_t * node, gboolean details);
177 resource_t * rsc,
const char *comment, GHashTable * nodes);
182 # define dump_node_scores(level, rsc, text, nodes) do { \
183 dump_node_scores_worker(level, __FILE__, __FUNCTION__, __LINE__, rsc, text, nodes); \
195 # define delete_key(rsc) generate_op_key(rsc->id, CRMD_ACTION_DELETE, 0)
196 # define delete_action(rsc, node, optional) custom_action( \
197 rsc, delete_key(rsc), CRMD_ACTION_DELETE, node, \
198 optional, TRUE, data_set);
200 # define stopped_key(rsc) generate_op_key(rsc->id, CRMD_ACTION_STOPPED, 0)
201 # define stopped_action(rsc, node, optional) custom_action( \
202 rsc, stopped_key(rsc), CRMD_ACTION_STOPPED, node, \
203 optional, TRUE, data_set);
205 # define stop_key(rsc) generate_op_key(rsc->id, CRMD_ACTION_STOP, 0)
206 # define stop_action(rsc, node, optional) custom_action( \
207 rsc, stop_key(rsc), CRMD_ACTION_STOP, node, \
208 optional, TRUE, data_set);
210 # define reload_key(rsc) generate_op_key(rsc->id, CRMD_ACTION_RELOAD, 0)
211 # define start_key(rsc) generate_op_key(rsc->id, CRMD_ACTION_START, 0)
212 # define start_action(rsc, node, optional) custom_action( \
213 rsc, start_key(rsc), CRMD_ACTION_START, node, \
214 optional, TRUE, data_set)
216 # define started_key(rsc) generate_op_key(rsc->id, CRMD_ACTION_STARTED, 0)
217 # define started_action(rsc, node, optional) custom_action( \
218 rsc, started_key(rsc), CRMD_ACTION_STARTED, node, \
219 optional, TRUE, data_set)
221 # define promote_key(rsc) generate_op_key(rsc->id, CRMD_ACTION_PROMOTE, 0)
222 # define promote_action(rsc, node, optional) custom_action( \
223 rsc, promote_key(rsc), CRMD_ACTION_PROMOTE, node, \
224 optional, TRUE, data_set)
226 # define promoted_key(rsc) generate_op_key(rsc->id, CRMD_ACTION_PROMOTED, 0)
227 # define promoted_action(rsc, node, optional) custom_action( \
228 rsc, promoted_key(rsc), CRMD_ACTION_PROMOTED, node, \
229 optional, TRUE, data_set)
231 # define demote_key(rsc) generate_op_key(rsc->id, CRMD_ACTION_DEMOTE, 0)
232 # define demote_action(rsc, node, optional) custom_action( \
233 rsc, demote_key(rsc), CRMD_ACTION_DEMOTE, node, \
234 optional, TRUE, data_set)
236 # define demoted_key(rsc) generate_op_key(rsc->id, CRMD_ACTION_DEMOTED, 0)
237 # define demoted_action(rsc, node, optional) custom_action( \
238 rsc, demoted_key(rsc), CRMD_ACTION_DEMOTED, node, \
239 optional, TRUE, data_set)
247 gboolean allow_non_atomic);
273 pe_base_name_eq(
resource_t *rsc,
const char *
id)
275 if (
id && rsc && rsc->
id) {
279 return (strlen(
id) == base_len) && !strncmp(
id, rsc->
id, base_len);
321 #define pe_action_required(action, reason, text) pe_action_set_flag_reason(__FUNCTION__, __LINE__, action, reason, text, pe_action_optional, FALSE)
322 #define pe_action_implies(action, reason, flag) pe_action_set_flag_reason(__FUNCTION__, __LINE__, action, reason, NULL, flag, FALSE)
327 gboolean
add_tag_ref(GHashTable * tags,
const char * tag_name,
const char * obj_ref);
330 void * print_data, gboolean print_all);
gboolean get_target_role(resource_t *rsc, enum rsc_role_e *role)
const char * pe_base_name_end(const char *id)
gboolean order_actions(action_t *lh_action, action_t *rh_action, enum pe_ordering order)
enum rsc_role_e native_resource_state(const resource_t *rsc, gboolean current)
xmlNode * find_rsc_op_entry(resource_t *rsc, const char *key)
gboolean container_unpack(resource_t *rsc, pe_working_set_t *data_set)
gboolean group_active(resource_t *rsc, gboolean all)
enum rsc_digest_cmp_val rc
char * digest_secure_calc
void dump_node_capacity(int level, const char *comment, node_t *node)
void common_update_score(resource_t *rsc, const char *id, int score)
void common_free(resource_t *rsc)
struct pe__location_constraint_s pe__location_t
enum rsc_role_e clone_resource_state(const resource_t *rsc, gboolean current)
gint sort_rsc_index(gconstpointer a, gconstpointer b)
gboolean native_unpack(resource_t *rsc, pe_working_set_t *data_set)
resource_t * native_find_rsc(resource_t *rsc, const char *id, const node_t *node, int flags)
gint sort_rsc_priority(gconstpointer a, gconstpointer b)
void print_rscs_brief(GListPtr rsc_list, const char *pre_text, long options, void *print_data, gboolean print_all)
enum action_tasks get_complex_task(resource_t *rsc, const char *name, gboolean allow_non_atomic)
action_t * custom_action(resource_t *rsc, char *key, const char *task, node_t *on_node, gboolean optional, gboolean foo, pe_working_set_t *data_set)
resource_t * find_clone_instance(resource_t *rsc, const char *sub_id, pe_working_set_t *data_set)
enum crm_ais_msg_types type
bool pe_can_fence(pe_working_set_t *data_set, node_t *node)
int pe_get_configured_timeout(resource_t *rsc, const char *action, pe_working_set_t *data_set)
GListPtr find_actions_exact(GListPtr input, const char *key, node_t *on_node)
pe_node_t * native_location(const pe_resource_t *rsc, GList **list, int current)
enum rsc_role_e container_resource_state(const resource_t *rsc, gboolean current)
void trigger_unfencing(resource_t *rsc, node_t *node, const char *reason, action_t *dependency, pe_working_set_t *data_set)
void pe_action_set_flag_reason(const char *function, long line, pe_action_t *action, pe_action_t *reason, const char *text, enum pe_action_flags flags, bool overwrite)
gboolean common_unpack(xmlNode *xml_obj, resource_t **rsc, resource_t *parent, pe_working_set_t *data_set)
int pe_get_failcount(node_t *node, resource_t *rsc, time_t *last_failure, uint32_t flags, xmlNode *xml_op, pe_working_set_t *data_set)
void container_print(resource_t *rsc, const char *pre_text, long options, void *print_data)
void native_free(resource_t *rsc)
void clone_print(resource_t *rsc, const char *pre_text, long options, void *print_data)
void common_print(resource_t *rsc, const char *pre_text, const char *name, node_t *node, long options, void *print_data)
void print_node(const char *pre_text, node_t *node, gboolean details)
action_t * get_pseudo_op(const char *name, pe_working_set_t *data_set)
void set_bit_recursive(resource_t *rsc, unsigned long long flag)
void pe_fence_node(pe_working_set_t *data_set, node_t *node, const char *reason)
Schedule a fence action for a node.
GListPtr node_list_dup(GListPtr list, gboolean reset, gboolean filter)
op_digest_cache_t * rsc_action_digest_cmp(resource_t *rsc, xmlNode *xml_op, node_t *node, pe_working_set_t *data_set)
enum rsc_role_e role_filter
void clone_free(resource_t *rsc)
void group_print(resource_t *rsc, const char *pre_text, long options, void *print_data)
bool is_set_recursive(resource_t *rsc, long long flag, bool any)
void pe_action_set_reason(pe_action_t *action, const char *reason, bool overwrite)
gboolean clone_unpack(resource_t *rsc, pe_working_set_t *data_set)
const char * pe_node_attribute_calculated(const pe_node_t *node, const char *name, const resource_t *rsc)
void pe__foreach_param_check(pe_working_set_t *data_set, void(*cb)(pe_resource_t *, pe_node_t *, xmlNode *, enum pe_check_parameters, pe_working_set_t *))
void native_add_running(resource_t *rsc, node_t *node, pe_working_set_t *data_set)
gint sort_op_by_callid(gconstpointer a, gconstpointer b)
struct notify_data_s notify_data_t
time_t get_effective_time(pe_working_set_t *data_set)
enum pe_discover_e discover_mode
char * clone_strip(const char *last_rsc_id)
node_t * node_copy(const node_t *this_node)
const char * container_fix_remote_addr_in(resource_t *rsc, xmlNode *xml, const char *field)
pe_node_t * pe__find_active_on(const pe_resource_t *rsc, unsigned int *count_all, unsigned int *count_clean)
GHashTable * node_hash_from_list(GListPtr list)
gboolean clone_active(resource_t *rsc, gboolean all)
char * digest_restart_calc
node_t * pe_create_node(const char *id, const char *uname, const char *type, const char *score, pe_working_set_t *data_set)
gint sort_node_uname(gconstpointer a, gconstpointer b)
ticket_t * ticket_new(const char *ticket_id, pe_working_set_t *data_set)
void add_hash_param(GHashTable *hash, const char *name, const char *value)
gboolean add_tag_ref(GHashTable *tags, const char *tag_name, const char *obj_ref)
resource_t * find_container_child(const resource_t *bundle, const node_t *node)
action_t * pe_fence_op(node_t *node, const char *op, bool optional, const char *reason, pe_working_set_t *data_set)
GHashTable * node_hash_dup(GHashTable *hash)
void resource_location(resource_t *rsc, node_t *node, int score, const char *tag, pe_working_set_t *data_set)
struct pe__order_constraint_s pe__ordering_t
char * native_parameter(resource_t *rsc, node_t *node, gboolean create, const char *name, pe_working_set_t *data_set)
GListPtr find_actions(GListPtr input, const char *key, const node_t *on_node)
bool remote_id_conflict(const char *remote_name, pe_working_set_t *data)
void verify_pe_options(GHashTable *options)
gboolean container_active(resource_t *rsc, gboolean all)
void dump_node_scores_worker(int level, const char *file, const char *function, int line, resource_t *rsc, const char *comment, GHashTable *nodes)
GHashTable * allowed_nodes
void group_free(resource_t *rsc)
void dump_rsc_utilization(int level, const char *comment, resource_t *rsc, node_t *node)
void pe__free_param_checks(pe_working_set_t *data_set)
int get_target_rc(xmlNode *xml_op)
void pe__add_param_check(xmlNode *rsc_op, pe_resource_t *rsc, pe_node_t *node, enum pe_check_parameters, pe_working_set_t *data_set)
void native_print(resource_t *rsc, const char *pre_text, long options, void *print_data)
pe_action_t * pe__clear_failcount(pe_resource_t *rsc, pe_node_t *node, const char *reason, pe_working_set_t *data_set)
Schedule a controller operation to clear a fail count.
enum rsc_role_e group_resource_state(const resource_t *rsc, gboolean current)
pe_node_t * pe__find_active_requires(const pe_resource_t *rsc, unsigned int *count)
void node_list_exclude(GHashTable *list, GListPtr list2, gboolean merge_scores)
bool container_fix_remote_addr(resource_t *rsc)
const char * pe_node_attribute_raw(pe_node_t *node, const char *name)
gboolean group_unpack(resource_t *rsc, pe_working_set_t *data_set)
struct op_digest_cache_s op_digest_cache_t
int merge_weights(int w1, int w2)
gboolean native_active(resource_t *rsc, gboolean all)
char * clone_zero(const char *last_rsc_id)
void container_free(resource_t *rsc)
void pe_free_action(action_t *action)
void clear_bit_recursive(resource_t *rsc, unsigned long long flag)
void destroy_ticket(gpointer data)
bool pe__is_universal_clone(pe_resource_t *rsc, pe_working_set_t *data_set)
Cluster status and scheduling.
void print_resource(int log_level, const char *pre_text, resource_t *rsc, gboolean details)
GListPtr find_recurring_actions(GListPtr input, node_t *not_on_node)
action_t * find_first_action(GListPtr input, const char *uuid, const char *task, node_t *on_node)