Skip to content

Releases: ClusterLabs/pacemaker

Pacemaker 2.1.5 - Final

08 Dec 15:52
Compare
Choose a tag to compare

Release info

  • Wed Dec 7 2022 Ken Gaillot kgaillot@redhat.com Pacemaker-2.1.5
  • 1287 commits with 447 files changed, 33546 insertions(+), 21518 deletions(-)

Known regressions introduced in this release

  • If left to default, crmadmin blocks waiting on server communication rather than timing out after 30s (fixed in 2.1.9)
  • Asynchronous actions can leave zombie processes if they exit while a synchronous meta-data action is in progress (fixed in 2.1.8)
  • attrd_updater ignores its dampening argument when setting values (fixed in 2.1.7)
  • A double free crash can occur if a recurring action is disabled (fixed in 2.1.7)
  • If Pacemaker Remote is stopped, it will no longer wait until the cluster notifies it that all resources have been moved off the node (fixed in 2.1.6)
  • attrd_updater --query without --node shows attributes from the local node instead of all nodes (fixed in 2.1.6)

Features added since Pacemaker-2.1.4

  • CIB: access control lists (ACLs) for groups are supported
  • CIB: ACL target and group XML supports "name" attribute to specify a name that is not a unique XML ID
  • CIB: deprecate pacemaker-next schema
  • CIB: deprecate first-instance and then-instance in ordering constraints and rsc-instance and with-rsc-instance in colocation constraints (only usable with pacemaker-next schema)
  • CIB: deprecate "collocated" and "ordered" meta-attributes for groups (true is default, and resource sets should be used instead of false)
  • build: support building with -D_TIME_BITS=64
  • build: support building with compilers that are strict about void
  • build: allow building RPMs from source distribution
  • fencer: deprecate stand-alone mode
  • agents: ClusterMon, controld, HealthCPU, ifspeed, and SysInfo agents support OCF 1.1 standard
  • agents: non-functional SystemHealth agent has been removed
  • tools: non-functional ipmiservicelogd and notifyServicelogEvent tools have been removed
  • tools: crm_attribute supports querying all attributes on a given node
  • tools: crm_attribute --query, --delete, and --update support regular expressions
  • tools: crm_error supports standard --output-as/--output-to arguments
  • tools: crm_error lists all return codes if none are specified
  • tools: crm_mon --show-detail displays the CRM feature set of each node and makes display of fencing actions more technical
  • tools: crm_resource --why checks node health
  • tools: crm_resource --constraints now accepts --recursive (equivalent to --stack) and --force (to show constraints for a group member instead of the group)

Fixes since Pacemaker-2.1.4

  • tools: crm_error does not print spurious output when given a negative return code argument (regression introduced in 2.0.4)
  • tools: avoid crash if crm_resource is given extraneous arguments (regression introduced in 2.0.5)
  • tools: stonith_admin --validate XML output shows correct validation status and errors (regressions introduced in 2.0.5 and 2.1.2)
  • tools: crm_resource --list-operations shows pending operations as pending instead of complete (regression introduced in 2.1.0)
  • controller: move resources if appropriate after they are reordered in CIB (regression introduced in 2.1.3)
  • fencing: allow fence devices to be registered if local node is not in CIB (regression introduced in 2.1.3)
  • tools: crm_mon --one-shot should succeed even if pacemaker is shutting down (regression introduced in 2.1.3)
  • tools: avoid memory leak in crm_mon (regression introduced in 2.1.3)
  • tools: crm_attribute --quiet outputs nothing instead of "(null)" if attribute has no value (regression introduced in 2.1.3)
  • tools: accept deprecated and unused attrd_updater --quiet option (regression introduced in 2.1.3)
  • CIB: avoid crashes when XML IDs grow very long
  • controller: pre-load agent metadata asynchronously to avoid timeout when agent's metadata action runs crm_node
  • controller: avoid timing issue that increments resource fail count twice
  • fencing: unfence all nodes after device configuration changes
  • fencing: avoid memory leaks when processing topology requests
  • fencing: ignore node that executed action when checking whether actions are equivalent
  • scheduler,controller: calculate secure digest consistently
  • scheduler: consider roles when blocking colocation dependents
  • scheduler: prioritize group colocations properly
  • scheduler: properly consider effect of "with group" colocations
  • scheduler: handle corner cases in live migrations
  • scheduler: avoid perpetual moving of bundle containers in certain situations
  • scheduler: properly calculate resource parameter digests without history
  • scheduler: do not enforce stop if newer monitor indicates resource was not running on target of failed migrate_to
  • scheduler: do not enforce stop on rejoined node after failed migrate_to
  • scheduler: don't demote on expected node when multiple-active is set to stop_unexpected
  • scheduler: prevent resources running on multiple nodes after partial live migration
  • scheduler: restart resource instead of reload if extra parameters in operation change
  • schemas: Consider days, minutes, seconds, and yeardays in date expressions valid
  • schemas: Consider in_range with an end and duration valid
  • schemas: Consider score and score-attribute optional in rules
  • tools: crm_resource --digests uses most recent operation history entry
  • tools: if multiple return code options are given to crm_error, use the last one
  • tools: crm_resource correctly detects if a resource is unmanaged or disabled even if there are multiple settings using rules

Public API changes since Pacemaker-2.1.4

  • libcib: add cib_api_operations_t:set_primary
  • libcib: add cib_api_operations_t:set_secondary
  • libcib: deprecate cib_api_operations_t:delete_absolute()
  • libcib: deprecate cib_api_operations_t:is_master
  • libcib: deprecate cib_api_operations_t:set_master
  • libcib: deprecate cib_api_operations_t:set_slave
  • libcib: deprecate cib_api_operations_t:set_slave_all
  • libcrmcommon: deprecated XML_CIB_TAG_MASTER constant is usable again (regression introduced in 2.1.0)
  • libcrmcommon: pcmk_ipc_api_t supports attribute manager IPC
  • libcrmcommon: add pcmk_rc_unpack_error
  • libcrmcommon: add CRM_EX_FAILED_PROMOTED
  • libcrmcommon: add CRM_EX_NONE
  • libcrmcommon: add CRM_EX_PROMOTED
  • libcrmcommon: add pcmk_readable_score()
  • libcrmcommon: add PCMK_XA_PROMOTED_MAX_LEGACY string constant
  • libcrmcommon: add PCMK_XA_PROMOTED_NODE_MAX_LEGACY string constant
  • libcrmcommon: argument to crm_time_check() is now const
  • libcrmcommon: argument to pcmk_controld_api_replies_expected() is now const
  • libcrmcommon: argument to pcmk_xml_attrs2nvpairs() is now const
  • libcrmcommon: argument to xml2list() is now const
  • libcrmcommon: argument to xml_acl_denied() is now const
  • libcrmcommon: argument to xml_acl_enabled() is now const
  • libcrmcommon: argument to xml_get_path() is now const
  • libcrmcommon: arguments to crm_time_add() are now const
  • libcrmcommon: arguments to crm_time_compare() are now const
  • libcrmcommon: arguments to crm_time_subtract() are now const
  • libcrmcommon: argv argument to crm_log_preinit() is now char *const *
  • libcrmcommon: crm_time_calculate_duration() arguments are now const
  • libcrmcommon: deprecate CRM_ATTR_RA_VERSION
  • libcrmcommon: deprecate crm_destroy_xml()
  • libcrmcommon: deprecate crm_ipc_server_error
  • libcrmcommon: deprecate crm_ipc_server_info
  • libcrmcommon: deprecate CRM_OP_LRM_QUERY
  • libcrmcommon: deprecate crm_str()
  • libcrmcommon: deprecate PCMK_XE_PROMOTED_MAX_LEGACY string constant
  • libcrmcommon: deprecate PCMK_XE_PROMOTED_NODE_MAX_LEGACY constant
  • libcrmcommon: deprecate score2char()
  • libcrmcommon: deprecate score2char_stack()
  • libcrmcommon: deprecate XML_ATTR_RA_VERSION
  • libcrmcommon: deprecate xml_get_path()
  • libcrmcommon: deprecate XML_PARANOIA_CHECKS
  • libcrmcommon: deprecate XML_TAG_OP_VER_ATTRS
  • libcrmcommon: deprecate XML_TAG_OP_VER_META
  • libcrmcommon: deprecate XML_TAG_RSC_VER_ATTRS
  • libcrmcommon: dt argument of crm_time_get_gregorian() is now const
  • libcrmcommon: dt argument of crm_time_get_isoweek() is now const
  • libcrmcommon: dt argument of crm_time_get_ordinal() is now const
  • libcrmcommon: dt argument of crm_time_get_timeofday() is now const
  • libcrmcommon: dt argument of crm_time_get_timezone() is now const
  • libcrmcommon: first argument to create_reply() is now const
  • libcrmcommon: first argument to crm_copy_xml_element() is now const
  • libcrmcommon: first argument to find_xml_node() is now const
  • libcrmcommon: first argument to get_message_xml() is now const
  • libcrmcommon: first argument to pcmk_ipc_name() is now const
  • libcrmcommon: first argument to xml_patch_versions() is now const
  • libcrmcommon: last argument to crm_write_blackbox() is now const
  • libcrmcommon: add pcmk_rc_duplicate_id
  • libcrmcommon: add pcmk_result_get_strings()
  • libcrmcommon: add pcmk_result_type enum
  • libcrmcommon: add PCMK_XE_DATE_EXPRESSION constant
  • libcrmcommon: add PCMK_XE_OP_EXPRESSION constant
  • libcrmcommon: add PCMK_XE_RSC_EXPRESSION constant
  • libcrmcommon: first argument to crm_time_as_string() is now const
  • libcrmcommon: crm_time_t argument to crm_time_log_alias() is now const
  • libcrmcommon: argument to crm_time_get_seconds() is now const
  • libcrmcommon: argument to crm_time_get_seconds_since_epoch() is now const
  • libcrmcommon: sixth argument to log_data_element() is now const
  • libcrmcommon: source argument to crm_time_set() is now const
  • libcrmcommon: source argument to crm_time_set_timet() is now const
  • libcrmcommon: source argument to pcmk_copy_time() is now const
  • lib...
Read more

Pacemaker 2.1.5 - Release Candidate 3

22 Nov 17:08
Compare
Choose a tag to compare
Pre-release
  • Fixes since Pacemaker-2.1.5-rc2
    • Increment fail counts properly (regression introduced in 2.1.5-rc1)
    • Allow building RPMs from source distribution

Pacemaker 2.1.5 - Release Candidate 2

15 Nov 16:19
Compare
Choose a tag to compare
Pre-release
  • Features added since Pacemaker-2.1.5-rc1

    • tools: crm_resource --constraints now accepts --recursive (equivalent to --stack) and --force (to show constraints for a group member instead of the group)
  • Fixes since Pacemaker-2.1.5-rc1

    • tools: fix setting utilization attributes with crm_attribute (regression introduced in 2.1.3)
    • scheduler: consider roles when blocking colocation dependents
    • scheduler: prioritize group colocations properly
    • scheduler: properly consider effect of "with group" colocations

Pacemaker 2.1.5 - Release Candidate 1

24 Oct 15:10
Compare
Choose a tag to compare
Pre-release
  • Features added since Pacemaker-2.1.4

    • CIB: access control lists (ACLs) for groups are supported
    • CIB: ACL target and group XML supports "name" attribute to specify a name that is not a unique XML ID
    • CIB: deprecate pacemaker-next schema
    • CIB: deprecate first-instance and then-instance in ordering constraints and rsc-instance and with-rsc-instance in colocation constraints (only usable with pacemaker-next schema)
    • CIB: deprecate "collocated" and "ordered" meta-attributes for groups (true is default, and resource sets should be used instead of false)
    • build: support building with -D_TIME_BITS=64
    • build: support building with compilers that are strict about void
    • fencer: deprecate stand-alone mode
    • agents: ClusterMon, controld, HealthCPU, ifspeed, and SysInfo agents support OCF 1.1 standard
    • agents: non-functional SystemHealth agent has been removed
    • tools: non-functional ipmiservicelogd and notifyServicelogEvent tools have been removed
    • tools: crm_attribute supports querying all attributes on a given node
    • tools: crm_attribute --query, --delete, and --update support regular expressions
    • tools: crm_error supports standard --output-as/--output-to arguments
    • tools: crm_error lists all return codes if none are specified
    • tools: crm_mon --show-detail displays the CRM feature set of each node and makes display of fencing actions more technical
    • tools: crm_resource --why checks node health
  • Fixes since Pacemaker-2.1.4

    • tools: crm_error does not print spurious output when given a negative return code argument (regression introduced in 2.0.4)
    • tools: avoid crash if crm_resource is given extraneous arguments (regression introduced in 2.0.5)
    • tools: stonith_admin --validate XML output shows correct validation status and errors (regressions introduced in 2.0.5 and 2.1.2)
    • tools: crm_resource --list-operations shows pending operations as pending instead of complete (regression introduced in 2.1.0)
    • controller: move resources if appropriate after they are reordered in CIB (regression introduced in 2.1.3)
    • fencing: allow fence devices to be registered if local node is not in CIB (regression introduced in 2.1.3)
    • tools: crm_mon --one-shot succeeds even if pacemaker is shutting down (regression introduced in 2.1.3)
    • tools: avoid memory leak in crm_mon (regression introduced in 2.1.3)
    • tools: crm_attribute --quiet outputs nothing instead of "(null)" if attribute has no value (regression introduced in 2.1.3)
    • tools: accept deprecated and unused attrd_updater --quiet option (regression introduced in 2.1.3)
    • CIB: avoid crashes when XML IDs grow very long
    • controller: pre-load agent metadata asynchronously to avoid timeout when agent's metadata action runs crm_node
    • controller: avoid timing issue that increments resource fail count twice
    • fencing: unfence all nodes after device configuration changes
    • fencing: avoid memory leaks when processing topology requests
    • fencing: ignore node that executed action when checking whether actions are equivalent
    • scheduler,controller: calculate secure digest consistently
    • scheduler: handle corner cases in live migrations
    • scheduler: avoid perpetual moving of bundle containers in certain situations
    • scheduler: properly calculate resource parameter digests without history
    • scheduler: do not enforce stop if newer monitor indicates resource was not running on target of failed migrate_to
    • scheduler: do not enforce stop on rejoined node after failed migrate_to
    • scheduler: don't demote on expected node when multiple-active is set to stop_unexpected
    • scheduler: prevent resources running on multiple nodes after partial live migration
    • scheduler: restart resource instead of reload if extra parameters in operation change
    • schemas: Consider days, minutes, seconds, and yeardays in date expressions valid
    • schemas: Consider in_range with an end and duration valid
    • schemas: Consider score and score-attribute optional in rules
    • tools: crm_resource --digests uses most recent operation history entry
    • tools: if multiple return code options are given to crm_error, use the last one
    • tools: crm_resource correctly detects if a resource is unmanaged or disabled even if there are multiple settings using rules
  • Public API changes since Pacemaker-2.1.4

    • libcib: add cib_api_operations_t:set_primary
    • libcib: add cib_api_operations_t:set_secondary
    • libcib: deprecate cib_api_operations_t:delete_absolute()
    • libcib: deprecate cib_api_operations_t:is_master
    • libcib: deprecate cib_api_operations_t:set_master
    • libcib: deprecate cib_api_operations_t:set_slave
    • libcib: deprecate cib_api_operations_t:set_slave_all
    • libcrmcommon: deprecated XML_CIB_TAG_MASTER constant is usable again (regression introduced in 2.1.0)
    • libcrmcommon: pcmk_ipc_api_t supports attribute manager IPC
    • libcrmcommon: add pcmk_rc_unpack_error
    • libcrmcommon: add CRM_EX_FAILED_PROMOTED
    • libcrmcommon: add CRM_EX_NONE
    • libcrmcommon: add CRM_EX_PROMOTED
    • libcrmcommon: add pcmk_readable_score()
    • libcrmcommon: add PCMK_XA_PROMOTED_MAX_LEGACY string constant
    • libcrmcommon: add PCMK_XA_PROMOTED_NODE_MAX_LEGACY string constant
    • libcrmcommon: argument to crm_time_check() is now const
    • libcrmcommon: argument to pcmk_controld_api_replies_expected() is now const
    • libcrmcommon: argument to pcmk_xml_attrs2nvpairs() is now const
    • libcrmcommon: argument to xml2list() is now const
    • libcrmcommon: argument to xml_acl_denied() is now const
    • libcrmcommon: argument to xml_acl_enabled() is now const
    • libcrmcommon: argument to xml_get_path() is now const
    • libcrmcommon: arguments to crm_time_add() are now const
    • libcrmcommon: arguments to crm_time_compare() are now const
    • libcrmcommon: arguments to crm_time_subtract() are now const
    • libcrmcommon: argv argument to crm_log_preinit() is now char *const *
    • libcrmcommon: crm_time_calculate_duration() arguments are now const
    • libcrmcommon: deprecate CRM_ATTR_RA_VERSION
    • libcrmcommon: deprecate crm_destroy_xml()
    • libcrmcommon: deprecate crm_ipc_server_error
    • libcrmcommon: deprecate crm_ipc_server_info
    • libcrmcommon: deprecate CRM_OP_LRM_QUERY
    • libcrmcommon: deprecate crm_str()
    • libcrmcommon: deprecate PCMK_XE_PROMOTED_MAX_LEGACY string constant
    • libcrmcommon: deprecate PCMK_XE_PROMOTED_NODE_MAX_LEGACY constant
    • libcrmcommon: deprecate score2char()
    • libcrmcommon: deprecate score2char_stack()
    • libcrmcommon: deprecate XML_ATTR_RA_VERSION
    • libcrmcommon: deprecate xml_get_path()
    • libcrmcommon: deprecate XML_PARANOIA_CHECKS
    • libcrmcommon: deprecate XML_TAG_OP_VER_ATTRS
    • libcrmcommon: deprecate XML_TAG_OP_VER_META
    • libcrmcommon: deprecate XML_TAG_RSC_VER_ATTRS
    • libcrmcommon: dt argument of crm_time_get_gregorian() is now const
    • libcrmcommon: dt argument of crm_time_get_isoweek() is now const
    • libcrmcommon: dt argument of crm_time_get_ordinal() is now const
    • libcrmcommon: dt argument of crm_time_get_timeofday() is now const
    • libcrmcommon: dt argument of crm_time_get_timezone() is now const
    • libcrmcommon: first argument to create_reply() is now const
    • libcrmcommon: first argument to crm_copy_xml_element() is now const
    • libcrmcommon: first argument to find_xml_node() is now const
    • libcrmcommon: first argument to get_message_xml() is now const
    • libcrmcommon: first argument to pcmk_ipc_name() is now const
    • libcrmcommon: first argument to xml_patch_versions() is now const
    • libcrmcommon: last argument to crm_write_blackbox() is now const
    • libcrmcommon: add pcmk_rc_duplicate_id
    • libcrmcommon: add pcmk_result_get_strings()
    • libcrmcommon: add pcmk_result_type enum
    • libcrmcommon: add PCMK_XE_DATE_EXPRESSION constant
    • libcrmcommon: add PCMK_XE_OP_EXPRESSION constant
    • libcrmcommon: add PCMK_XE_RSC_EXPRESSION constant
    • libcrmcommon: first argument to crm_time_as_string() is now const
    • libcrmcommon: crm_time_t argument to crm_time_log_alias() is now const
    • libcrmcommon: argument to crm_time_get_seconds() is now const
    • libcrmcommon: argument to crm_time_get_seconds_since_epoch() is now const
    • libcrmcommon: sixth argument to log_data_element() is now const
    • libcrmcommon: source argument to crm_time_set() is now const
    • libcrmcommon: source argument to crm_time_set_timet() is now const
    • libcrmcommon: source argument to pcmk_copy_time() is now const
    • libpacemaker: add pcmk_check_rule()
    • libpacemaker: add pcmk_check_rules()
    • libpacemaker: add pcmk_show_result_code()
    • libpacemaker: add pcmk_list_result_codes()
    • libpacemaker: add pcmk_rc_disp_flags enum
    • libpacemaker: ipc_name argument to pcmk_pacemakerd_status() is now const
    • libpe_rules: deprecate version_expr enum value
    • libpe_rules: second argument to pe_eval_nvpairs() is now const
    • libpe_status: argument to pe_rsc_is_anon_clone() is now const
    • libpe_status: argument to pe_rsc_is_unique_clone() is now const
    • libpe_status: deprecate enum pe_graph_flags
    • libpe_status: first argument to pe_rsc_is_clone() is now const
    • libpe_status: two arguments to get_rsc_attributes() are now const
    • libpe_status: second argument to pe_eval_versioned_attributes() is now const
    • libpe_status: second argument to pe_rsc_params() is now const
    • libstonithd: deprecate stonith_event_t:message
    • libstonithd: deprecate stonith_event_t:type
    • libstonithd: last argument to stonith_api_operations_t:register_device() is now const
    • libstonithd: last argument to stonith_api_operations_t:register_level() is now const
    • libstonithd: last argument to stonith_api_operations_t:register_level_full() is now const
    • libstonithd: params argument to stonith_api_operations_t:validate() is now const

Pacemaker 2.1.4 - Final

15 Jun 14:30
Compare
Choose a tag to compare

Info

  • Mon Jun 13 2022 Ken Gaillot kgaillot@redhat.com Pacemaker-2.1.4
  • Changesets: 17
  • Diff: 9 files changed, 52 insertions(+), 18 deletions(-)

Known regressions introduced in this release

  • None

Fixes since Pacemaker-2.1.3

  • fencing: get target-by-attribute working again (regression in 2.1.3)
  • fencing: avoid use-after-free when processing self-fencing requests with topology (regression in 2.1.3)
  • resources: typo in HealthSMART meta-data (regression in 2.1.3)
  • fencing: avoid memory leaks when processing topology requests
  • fencing: delegate shouldn't matter when checking equivalent fencing
  • tools: fix CSS syntax error in crm_mon --output-as=html

Pacemaker 2.1.4 - Release Candidate 1

03 Jun 21:17
ea9bebf
Compare
Choose a tag to compare
Pre-release

Release info

  • Fri Jun 03 2022 Ken Gaillot kgaillot@redhat.com Pacemaker-2.1.4-rc1
  • Changesets: 11
  • Diff: 8 files changed, 31 insertions(+), 11 deletions(-)

Known regressions introduced in this release

  • None

Fixes since Pacemaker-2.1.3

  • fencing: get target-by-attribute working again (regression in 2.1.3)
  • fencing: avoid use-after-free when processing self-fencing requests with topology (regression in 2.1.3)
  • fencing: avoid memory leaks when processing topology requests
  • fencing: delegate shouldn't matter when checking equivalent fencing
  • tools: fix CSS syntax error in crm_mon --output-as=html

Pacemaker 2.1.3 - Final

01 Jun 23:34
Compare
Choose a tag to compare

Release info

  • Fri Jun 03 2022 Ken Gaillot kgaillot@redhat.com Pacemaker-2.1.4-rc1
  • Changesets: 11
  • Diff: 8 files changed, 31 insertions(+), 11 deletions(-)

Known regressions introduced in this release

  • Asynchronous IPC clients can leak file descriptors (fixed in 2.1.8)
  • The scheduler can crash when logging an invalid utilization value (fixed in 2.1.8)
  • Resources that need to move because they were reordered in the CIB might not do so until the next natural transition (fixed in 2.1.5)
  • Fence devices cannot be registered if the local node is not in the CIB (fixed in 2.1.5)
  • crm_attribute --utilization incorrectly sets the value of node utilization attributes (fixed in 2.1.5)
  • crm_attribute --quiet outputs "(null)" instead of nothing if the requested attribute has no value (fixed in 2.1.5)
  • crm_mon can return a failure code if pacemaker is shutting down, which can cause resource failures with resource agents that run crm_mon in monitor or stop actions (fixed in 2.1.5)
  • crm_mon can leak memory when run in daemon mode (fixed in 2.1.5)
  • attrd_updater rejects (deprecated and unused) --quiet option (fixed in 2.1.5)
  • Fencing devices configured with target-by-attribute no longer work (fixed in 2.1.4)
  • When debug logging is enabled, the fencer can have a use-after-free memory error when processing self-fencing requests with topology (fixed in 2.1.4)
  • ocf:pacemaker:HealthSMART meta-data has a typo (fixed in 2.1.4)

Features added since Pacemaker-2.1.2

  • Internal failures of resource actions (such as an OCF agent not being found) are shown with a detailed exit reason in logs, crm_mon output, etc.
  • Support for CIB entries with type="ping" is deprecated (this was an undocumented means of defining a quorum-only node)
  • build: configure script supports experimental --enable-nls option to enable native language translations (currently only Chinese translations of certain help text are available)
  • rpm: crm_attribute is now part of the pacemaker-cli package instead of the pacemaker package
  • CIB: resources support allow-unhealthy-nodes meta-attribute to exempt the resource from bans due to node health checks (particularly useful for health monitoring resources themselves)
  • CIB: multiple-active cluster property can be set to "stop_unexpected" to leave the expected instance running and stop only any unexpected ones
  • CIB: bundles support resource utilization
  • pacemakerd: regularly check that subdaemons are active and accepting IPC connections so sbd can self-fence a node with a malfunctioning subdaemon
  • pacemaker-schedulerd: support --output-as/--output-to options including XML output with interactive options
  • tools: cibadmin --show-access option to show CIB colorized for ACLs
  • tools: crm_attribute supports standard --output-as/--output-to options
  • tools: crm_mon output indicates if a node's health is yellow or red
  • tools: for probes that failed because the service is not installed or locally configured, crm_mon displays the resource as stopped rather than failed
  • tools: crm_rule supports standard --output-as/--output-to options, allows passing multiple -r options, and is no longer experimental
  • tools: stonith_admin fencing commands display reasons for failures
  • resource agents: HealthSMART supports OCF 1.1 standard and new OCF_RESKEY_dampen and OCF_RESKEY_smartctl parameters

Fixes since Pacemaker-2.1.2

  • build: avoid circular library dependency (regression introduced in 2.1.0)
  • systemd: if pacemakerd exits immediately after starting, wait 1 second before trying to respawn, and allow 5 attempts
  • fencer: get fencing completion time correctly (regression introduced in 2.1.2)
  • fencer: avoid memory leak when broadcasting history differences (regression introduced in 2.1.0)
  • controller: correctly match "node down" events so remote nodes don't get fenced when connection is stopped (regression introduced in 2.1.2)
  • executor: avoid possible double free during notify operation (regression introduced in 2.1.1)
  • tools: get stonith_admin -T/--tag option working again (regression introduced in 2.0.3)
  • resources: use correct syntax in Stateful meta-data (regression introduced in 2.1.0)
  • corosync: repeat corosync_cfg_trackstart if first attempt fails
  • libcrmcommon: retry IPC requests after EAGAIN errors
  • executor,scheduler: treat "no secrets" fence results as a hard error
  • fencing: handle dynamic target query failures better
  • fencing: don't set stonith action to pending if fork fails
  • pacemakerd: avoid race condition when subdaemaon is checked while exiting
  • scheduler: avoid memory leak when displaying clones in certain conditions
  • scheduler: properly set data set flags when scheduling actions
  • tools: support command-line crm_attribute calls on Pacemaker remote nodes whose node name in the cluster differs from their local hostname
  • tools: prevent possible crm_resource crashes if multiple commands specified

Public API changes since Pacemaker-2.1.2

  • libcrmcommon: pcmk_ipc_api_t supports scheduler IPC
  • libpacemaker: add pcmk_status() (equivalent to crm_mon)
  • libcib: deprecate get_object_parent()
  • libcib: deprecate get_object_path()
  • libcib: deprecate get_object_root()
  • libcrmcommon: add pcmk_cib_parent_name_for()
  • libcrmcommon: add pcmk_cib_xpath_for()
  • libcrmcommon: add pcmk_find_cib_element()
  • libcrmcommon: deprecate crm_xml_add_boolean()
  • libpe_status: add pe_flag_check_config
  • libpe_status: add pe_node_shared_s:data_set
  • libpe_status: add pe_rsc_restarting flag
  • libpe_status: add pe_rsc_stop_unexpected flag
  • libpe_status: add recovery_stop_unexpected to enum rsc_recovery_type
  • libpe_status: deprecate node_ping
  • libpe_status: deprecate pe_order_stonith_stop
  • libpe_status: deprecate pe_rsc_starting and pe_rsc_stopping
  • libstonithd: add exit_reason member to stonith_history_t
  • libstonithd: deprecate stonith_t:call_timeout
  • libstonithd: stonith_api_del_notification() with NULL second argument removes all notifications

Pacemaker 2.1.3 - Release Candidate 2

18 May 15:53
Compare
Choose a tag to compare
Pre-release
  • Features added since Pacemaker-2.1.3-rc1

    • rpm: crm_attribute is now part of the pacemaker-cli package instead of the pacemaker package
    • tools: the syntax for cibadmin's new ACL colorizing feature changed slightly
  • Fixes since Pacemaker-2.1.3-rc1

    • scheduler: make multiple-active="stop_unexpected" actually work
    • libcrmcommon: retry IPC requests after EAGAIN errors
    • tools: get attrd_updater -Y working again (regression in 2.1.3-rc1)
    • tools: support command-line crm_attribute calls on Pacemaker remote nodes whose node name in the cluster differs from their local hostname
  • Public API changes since Pacemaker-2.1.3-rc1

    • libstonithd: deprecate stonith_t:call_timeout

Pacemaker 2.1.3 - Release Candidate 1

21 Apr 21:15
Compare
Choose a tag to compare
Pre-release
  • Features added since Pacemaker-2.1.2

    • Internal failures of resource actions (such as an OCF agent not being found) are shown with a detailed exit reason in logs, crm_mon output, etc.
    • Support for CIB entries with type="ping" is deprecated (this was an undocumented means of defining a quorum-only node)
    • build: configure script supports experimental --enable-nls option to enable native language translations (currently only Chinese translations of certain help text are available)
    • CIB: resources support allow-unhealthy-nodes meta-attribute to exempt the resource from bans due to node health checks (particularly useful for health monitoring resources themselves)
    • CIB: multiple-active cluster property can be set to "stop_unexpected" to leave the expected instance running and stop only any unexpected ones
    • CIB: bundles support resource utilization
    • pacemakerd: regularly check that subdaemons are active and accepting IPC connections so sbd can self-fence a node with a malfunctioning subdaemon
    • pacemaker-schedulerd: support --output-as/--output-to options including XML output with interactive options
    • tools: cibadmin --show-access option to show CIB colorized for ACLs
    • tools: crm_attribute supports standard --output-as/--output-to options
    • tools: crm_mon output indicates if a node's health is yellow or red
    • tools: for probes that failed because the service is not installed or locally configured, crm_mon displays the resource as stopped rather than failed
    • tools: crm_rule supports standard --output-as/--output-to options, allows passing multiple -r options, and is no longer experimental
    • tools: stonith_admin fencing commands display reasons for failures
    • resource agents: HealthSMART supports OCF 1.1 standard and new OCF_RESKEY_dampen and OCF_RESKEY_smartctl parameters
  • Fixes since Pacemaker-2.1.2

    • build: avoid circular library dependency (regression introduced in 2.1.0)
    • systemd: if pacemakerd exits immediately after starting, wait 1 second before trying to respawn, and allow 5 attempts
    • fencer: get fencing completion time correctly (regression introduced in 2.1.2)
    • fencer: avoid memory leak when broadcasting history differences (regression introduced in 2.1.0)
    • controller: correctly match "node down" events so remote nodes don't get fenced when connection is stopped (regression introduced in 2.1.2)
    • executor: avoid possible double free during notify operation (regression introduced in 2.1.1)
    • tools: get stonith_admin -T/--tag option working again (regression introduced in 2.0.3)
    • resources: use correct syntax in Stateful meta-data (regression introduced in 2.1.0)
    • corosync: repeat corosync_cfg_trackstart if first attempt fails
    • executor,scheduler: treat "no secrets" fence results as a hard error
    • fencing: handle dynamic target query failures better
    • fencing: don't set stonith action to pending if fork fails
    • pacemakerd: avoid race condition when subdaemaon is checked while exiting
    • scheduler: avoid memory leak when displaying clones in certain conditions
    • scheduler: properly set data set flags when scheduling actions
    • tools: prevent possible crm_resource crashes if multiple commands specified
  • Public API changes since Pacemaker-2.1.2

    • libcrmcommon: pcmk_ipc_api_t supports scheduler IPC
    • libpacemaker: add pcmk_status() (equivalent to crm_mon)
    • libcib: deprecate get_object_parent()
    • libcib: deprecate get_object_path()
    • libcib: deprecate get_object_root()
    • libcrmcommon: add pcmk_cib_parent_name_for()
    • libcrmcommon: add pcmk_cib_xpath_for()
    • libcrmcommon: add pcmk_find_cib_element()
    • libcrmcommon: deprecate crm_xml_add_boolean()
    • libpe_status: add pe_flag_check_config
    • libpe_status: add pe_node_shared_s:data_set
    • libpe_status: add pe_rsc_restarting flag
    • libpe_status: add pe_rsc_stop_unexpected flag
    • libpe_status: add recovery_stop_unexpected to enum rsc_recovery_type
    • libpe_status: deprecate node_ping
    • libpe_status: deprecate pe_order_stonith_stop
    • libpe_status: deprecate pe_rsc_starting and pe_rsc_stopping
    • libstonithd: add exit_reason member to stonith_history_t
    • libstonithd: stonith_api_del_notification() with NULL second argument removes all notifications

Pacemaker 2.1.2 - Final

24 Nov 15:58
Compare
Choose a tag to compare

Known regressions introduced in this release

  • stonith_admin --validate XML output doesn't show validation failure messages (fixed in 2.1.5)
  • The fencer calculates an incorrect fencing completion time as shown in crm_mon etc. (fixed in 2.1.3)
  • Remote nodes may be fenced when their connection is stopped (fixed in 2.1.3)

Features added since Pacemaker-2.1.1

  • build: when built with --with-initdir, Pacemaker uses the value to find LSB resources (in addition to being where Pacemaker's own init scripts are installed)
  • build: cmocka is new dependency for unit tests ("make check")
  • rpm: fence_watchdog now comes with pacemaker package (not pacemaker-cli)
  • daemons: metadata for cluster options supports OCF 1.1 standard
  • executor: nagios warning results now map to OCF "degraded" result code
  • fencing: pcmk_delay_base can optionally specify different delays per node
  • fencing: pcmk_host_map supports escaped characters such as spaces in values
  • resources: HealthIOWait agent supports OCF 1.1 standard, and validate works
  • tools: crm_mon shows exit reasons for actions failed due to internal errors
  • tools: crm_mon failed action display is more human-friendly by default
  • tools: crm_resource --force-* now outputs exit reasons if available

Fixes since Pacemaker-2.1.1

  • pkg-config: return correct value for ocfdir (regression introduced in 2.1.0)
  • tools: fix crm_mon --hide-headers and related options (regression introduced in 2.0.4)
  • attrd: check election status upon node loss to avoid election timeout
  • controller: improved handling of executor connection failures
  • executor: properly detect systemd unit existence
  • pacemakerd: recover properly from Corosync crash
  • fencing: fencing results are now sorted with sub-second resolution
  • fencing: fix fence_watchdog version output, metadata output, and man page
  • fencing: mark state as done if remapped "on" times out
  • tools: map LSB status to OCF correctly with crm_resource --force-check

Public API changes since Pacemaker-2.1.1

  • libcrmcommon: deprecate PCMK_OCF_EXEC_ERROR
  • libcrmcommon: deprecate PCMK_OCF_PENDING
  • libcrmcommon: deprecate PCMK_OCF_SIGNAL
  • libcrmcommon: add CRM_EX_DEGRADED and CRM_EX_DEGRADED_PROMOTED
  • libcrmcommon: add enum pcmk_exec_status
  • libcrmcommon: add PCMK_EXEC_MAX
  • libcrmcommon: add PCMK_EXEC_NO_FENCE_DEVICE
  • libcrmcommon: add PCMK_EXEC_NO_SECRETS
  • libcrmcommon: add pcmk_exec_status_str()
  • libcrmcommon: add pcmk_rc2ocf()
  • libcrmcommon: deprecate PCMK_OCF_TIMEOUT
  • libcrmservice: add services_result2ocf()
  • libcrmservice: deprecate enum op_status
  • libcrmservice: deprecate LSB_ROOT_DIR
  • libcrmservice: deprecate NAGIOS_NOT_INSTALLED
  • libcrmservice: deprecate NAGIOS_STATE_DEPENDENT
  • libcrmservice: deprecate services_get_ocf_exitcode()
  • libcrmservice: deprecate services_list() and services_action_create()
  • libcrmservice: deprecate services_lrm_status_str()
  • libpacemaker: add enum pcmk_sim_flags
  • libpacemaker: add pcmk_injections_t
  • libpacemaker: add pcmk_free_injections()
  • libpacemaker: add pcmk_simulate()
  • libstonithd: add opaque member to stonith_event_t
  • libstonithd: add opaque member to stonith_callback_data_t