559483a527
- Build: lrmd: Include libxml/tree.h in lrmd.h * pacemaker-lrmd.h-include-libxml.patch - libfencing,fencing: properly remap "action" in configuration - libservices: ensure recurring actions table is created before using - libservices: improve error messages when creating operation - libservices: properly detect in-flight systemd/upstart ops when kicking - libservices: properly cancel in-flight systemd/upstart op - libservices: handle in-flight case first when cancelling an operation - libservices: prevent use-after-free when freeing an operation - libservices: ensure completed ops aren't on blocked ops list - libcrmcommon: assert if can't generate operation key - libcrmcommon: improve remote connection polling messages - crmd: clear failure only for requested node - crmd: improve message when clearing failures - pengine,libpe_status: make failcount clearing messages more helpful - pengine,libpe_status: don't clear same fail-count twice - cib: properly mark variable as volatile - libcib: avoid memory leak in query_node_uuid() - tools: avoid NULL dereference in crm_resource debug message - cib,libcrmcommon,lrmd: handle IP addresses better in messages - tools: crm_attribute should prefer node name from environment - libcrmcommon: Correctly delete XML comments according to their positions (bsc#1024037) - libcrmcommon: Correctly compare XML comments to prevent crmd from getting into infinite election loop (bsc#1024037) - crmd,libcrmcluster: minor log message improvements - tools: avoid deprecated function in notifyServicelogEvent - libcrmcommon,pengine,tools: pass local node name to resource agents - use callback instead of sync call - libcib: make querying node uuid more efficient - tools: allow regular expression with crm_attribute OBS-URL: https://build.opensuse.org/request/show/477365 OBS-URL: https://build.opensuse.org/package/show/network:ha-clustering:Factory/pacemaker?expand=0&rev=260
255 lines
8.8 KiB
Diff
255 lines
8.8 KiB
Diff
From ab4df57e195486ee651f56793470d421233a0896 Mon Sep 17 00:00:00 2001
|
|
From: =?UTF-8?q?Kristoffer=20Gr=C3=B6nlund?= <krig@koru.se>
|
|
Date: Thu, 2 Feb 2017 09:06:00 +0100
|
|
Subject: [PATCH] Medium: NodeUtilization: Add NodeUtilization agent
|
|
|
|
---
|
|
extra/resources/Makefile.am | 1 +
|
|
extra/resources/NodeUtilization | 224 ++++++++++++++++++++++++++++++++++++++++++++++
|
|
2 files changed, 225 insertions(+)
|
|
create mode 100644 extra/resources/NodeUtilization
|
|
|
|
diff --git a/extra/resources/Makefile.am b/extra/resources/Makefile.am
|
|
--- a/extra/resources/Makefile.am
|
|
+++ b/extra/resources/Makefile.am
|
|
@@ -38,7 +38,8 @@ ocf_SCRIPTS = ClusterMon \
|
|
SysInfo \
|
|
SystemHealth \
|
|
attribute \
|
|
- remote
|
|
+ remote \
|
|
+ NodeUtilization
|
|
|
|
isolationtech_SCRIPTS = docker-wrapper
|
|
|
|
diff --git a/extra/resources/NodeUtilization b/extra/resources/NodeUtilization
|
|
new file mode 100644
|
|
index 0000000..da5fb56
|
|
--- /dev/null
|
|
+++ b/extra/resources/NodeUtilization
|
|
@@ -0,0 +1,224 @@
|
|
+#!/bin/sh
|
|
+#
|
|
+#
|
|
+# NodeUtilization OCF Resource Agent
|
|
+#
|
|
+# Copyright (c) 2011 SUSE LINUX, John Shi
|
|
+# Copyright (c) 2016 SUSE LINUX, Kristoffer Gronlund
|
|
+# All Rights Reserved.
|
|
+#
|
|
+# This program is free software; you can redistribute it and/or modify
|
|
+# it under the terms of version 2 of the GNU General Public License as
|
|
+# published by the Free Software Foundation.
|
|
+#
|
|
+# This program is distributed in the hope that it would be useful, but
|
|
+# WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
|
+#
|
|
+# Further, this software is distributed without any warranty that it is
|
|
+# free of the rightful claim of any third person regarding infringement
|
|
+# or the like. Any license provided herein, whether implied or
|
|
+# otherwise, applies only to this software file. Patent licenses, if
|
|
+# any, provided herein do not apply to combinations of this program with
|
|
+# other software, or any other product whatsoever.
|
|
+#
|
|
+# You should have received a copy of the GNU General Public License
|
|
+# along with this program; if not, write the Free Software Foundation,
|
|
+# Inc., 59 Temple Place - Suite 330, Boston MA 02111-1307, USA.
|
|
+#
|
|
+#######################################################################
|
|
+# Initialization:
|
|
+
|
|
+: ${OCF_FUNCTIONS_DIR=${OCF_ROOT}/lib/heartbeat}
|
|
+. ${OCF_FUNCTIONS_DIR}/ocf-shellfuncs
|
|
+
|
|
+#######################################################################
|
|
+
|
|
+NodeUtilization_meta_data() {
|
|
+ cat <<END
|
|
+<?xml version="1.0"?>
|
|
+<!DOCTYPE resource-agent SYSTEM "ra-api-1.dtd">
|
|
+<resource-agent name="NodeUtilization">
|
|
+<version>1.0</version>
|
|
+
|
|
+<longdesc lang="en">
|
|
+The Node Utilization agent detects system parameters like available CPU, host
|
|
+memory and hypervisor memory availability, and adds them into the CIB for each
|
|
+node using crm_attribute. Run the agent as a clone resource to have it populate
|
|
+these parameters on each node.
|
|
+Note: Setting hv_memory only works with Xen at the moment, using the xl or xm
|
|
+command line tools.
|
|
+</longdesc>
|
|
+<shortdesc lang="en">Node Utilization</shortdesc>
|
|
+
|
|
+<parameters>
|
|
+<parameter name="dynamic" unique="0" required="0">
|
|
+<longdesc lang="en">
|
|
+If set, parameters will be updated if there are differences between the HA
|
|
+parameters and the system values when running the monitor action.
|
|
+If not set, the parameters will be set once when the resource instance starts.
|
|
+</longdesc>
|
|
+<shortdesc lang="en">Dynamically update parameters in monitor</shortdesc>
|
|
+<content type="boolean" default="true" />
|
|
+</parameter>
|
|
+
|
|
+<parameter name="utilization_cpu" unique="0" required="0">
|
|
+<longdesc lang="en">Enable setting node CPU utilization limit.</longdesc>
|
|
+<shortdesc lang="en">Set node CPU utilization limit.</shortdesc>
|
|
+<content type="boolean" default="true" />
|
|
+</parameter>
|
|
+
|
|
+<parameter name="utilization_cpu_reservation" unique="0" required="0">
|
|
+<longdesc lang="en">Subtract this value when setting the CPU utilization parameter.</longdesc>
|
|
+<shortdesc lang="en">CPU reservation.</shortdesc>
|
|
+<content type="integer" default="1" />
|
|
+</parameter>
|
|
+
|
|
+<parameter name="utilization_host_memory" unique="0" required="0">
|
|
+<longdesc lang="en">Enable setting available host memory.</longdesc>
|
|
+<shortdesc lang="en">Set available host memory.</shortdesc>
|
|
+<content type="boolean" default="true" />
|
|
+</parameter>
|
|
+
|
|
+<parameter name="utilization_host_memory_reservation" unique="0" required="0">
|
|
+<longdesc lang="en">Subtract this value when setting host memory utilization, in MB.</longdesc>
|
|
+<shortdesc lang="en">Host memory reservation, in MB.</shortdesc>
|
|
+<content type="integer" default="512" />
|
|
+</parameter>
|
|
+
|
|
+<parameter name="utilization_hv_memory" unique="0" required="0">
|
|
+<longdesc lang="en">Enable setting available hypervisor memory.</longdesc>
|
|
+<shortdesc lang="en">Set available hypervisor memory.</shortdesc>
|
|
+<content type="boolean" default="true" />
|
|
+</parameter>
|
|
+
|
|
+<parameter name="utilization_hv_memory_reservation" unique="0" required="0">
|
|
+<longdesc lang="en">Subtract this value when setting hypervisor memory utilization, in MB.</longdesc>
|
|
+<shortdesc lang="en">Hypervisor memory reservation, in MB.</shortdesc>
|
|
+<content type="integer" default="512" />
|
|
+</parameter>
|
|
+</parameters>
|
|
+
|
|
+<actions>
|
|
+<action name="start" timeout="90" />
|
|
+<action name="stop" timeout="100" />
|
|
+<action name="monitor" timeout="20s" interval="60s"/>
|
|
+<action name="meta-data" timeout="5" />
|
|
+<action name="validate-all" timeout="30" />
|
|
+</actions>
|
|
+</resource-agent>
|
|
+END
|
|
+}
|
|
+
|
|
+Host_Total_Memory() {
|
|
+ local xentool
|
|
+
|
|
+ xentool=$(which xl 2> /dev/null || which xm 2> /dev/null)
|
|
+
|
|
+ if [ -x $xentool ]; then
|
|
+ $xentool info | awk '/total_memory/{printf("%d\n",$3);exit(0)}'
|
|
+ else
|
|
+ ocf_log warn "Can only set hv_memory for Xen hypervisor"
|
|
+ echo "0"
|
|
+ fi
|
|
+}
|
|
+
|
|
+
|
|
+set_utilization() {
|
|
+ host_name="$(ocf_local_nodename)"
|
|
+
|
|
+ if ocf_is_true "$OCF_RESKEY_utilization_cpu"; then
|
|
+ sys_cpu=$(( $(grep -c processor /proc/cpuinfo) - $OCF_RESKEY_utilization_cpu_reservation ))
|
|
+ uti_cpu=$(crm_attribute -Q -t nodes -U "$host_name" -z -n cpu 2>/dev/null)
|
|
+
|
|
+ if [ "$sys_cpu" != "$uti_cpu" ]; then
|
|
+ if ! crm_attribute -t nodes -U "$host_name" -z -n cpu -v $sys_cpu; then
|
|
+ ocf_log err "Failed to set the cpu utilization attribute for $host_name using crm_attribute."
|
|
+ return 1
|
|
+ fi
|
|
+ fi
|
|
+ fi
|
|
+
|
|
+ if ocf_is_true "$OCF_RESKEY_utilization_host_memory"; then
|
|
+ sys_mem=$(( $(awk '/MemTotal/{printf("%d\n",$2/1024);exit(0)}' /proc/meminfo) - $OCF_RESKEY_utilization_host_memory_reservation ))
|
|
+ uti_mem=$(crm_attribute -Q -t nodes -U "$host_name" -z -n host_memory 2>/dev/null)
|
|
+
|
|
+ if [ "$sys_mem" != "$uti_mem" ]; then
|
|
+ if ! crm_attribute -t nodes -U "$host_name" -z -n host_memory -v $sys_mem; then
|
|
+ ocf_log err "Failed to set the host_memory utilization attribute for $host_name using crm_attribute."
|
|
+ return 1
|
|
+ fi
|
|
+ fi
|
|
+ fi
|
|
+
|
|
+ if ocf_is_true "$OCF_RESKEY_utilization_hv_memory"; then
|
|
+ hv_mem=$(( $(Host_Total_Memory) - OCF_RESKEY_utilization_hv_memory_reservation ))
|
|
+ uti_mem=$(crm_attribute -Q -t nodes -U "$host_name" -z -n hv_memory 2>/dev/null)
|
|
+
|
|
+ if [ "$hv_mem" != "$uti_mem" ]; then
|
|
+ if ! crm_attribute -t nodes -U "$host_name" -z -n hv_memory -v $hv_mem; then
|
|
+ ocf_log err "Failed to set the hv_memory utilization attribute for $host_name using crm_attribute."
|
|
+ return 1
|
|
+ fi
|
|
+ fi
|
|
+ fi
|
|
+}
|
|
+
|
|
+NodeUtilization_usage() {
|
|
+ cat <<END
|
|
+usage: $0 {start|stop|monitor|validate-all|meta-data}
|
|
+
|
|
+Expects to have a fully populated OCF RA-compliant environment set.
|
|
+END
|
|
+}
|
|
+
|
|
+NodeUtilization_start() {
|
|
+ ha_pseudo_resource $statefile start
|
|
+ if ! ocf_is_true "$OCF_RESKEY_dynamic"; then
|
|
+ if ! set_utilization; then
|
|
+ exit $OCF_ERR_GENERIC
|
|
+ fi
|
|
+ fi
|
|
+ exit $OCF_SUCCESS
|
|
+}
|
|
+
|
|
+NodeUtilization_stop() {
|
|
+ ha_pseudo_resource $statefile stop
|
|
+ exit $OCF_SUCCESS
|
|
+}
|
|
+
|
|
+NodeUtilization_monitor() {
|
|
+ local rc
|
|
+ ha_pseudo_resource $statefile monitor
|
|
+ rc=$?
|
|
+
|
|
+ case $rc in
|
|
+ $OCF_SUCCESS)
|
|
+ if ocf_is_true "$OCF_RESKEY_dynamic"; then
|
|
+ if ! set_utilization; then
|
|
+ exit $OCF_ERR_GENERIC
|
|
+ fi
|
|
+ fi
|
|
+ ;;
|
|
+ *) exit $rc;;
|
|
+ esac
|
|
+}
|
|
+
|
|
+NodeUtilization_validate() {
|
|
+ exit $OCF_SUCCESS
|
|
+}
|
|
+
|
|
+statefile=$OCF_RESOURCE_TYPE.$(echo $OCF_RESOURCE_INSTANCE | sed -e 's/^.*://')
|
|
+
|
|
+: ${OCF_RESKEY_pidfile:="$HA_VARRUN/NodeUtilization-${OCF_RESOURCE_INSTANCE}"}
|
|
+: ${OCF_RESKEY_dynamic:="true"}
|
|
+: ${OCF_RESKEY_utilization_cpu:="true"}
|
|
+: ${OCF_RESKEY_utilization_cpu_reservation="1"}
|
|
+: ${OCF_RESKEY_utilization_hv_memory:="true"}
|
|
+: ${OCF_RESKEY_utilization_hv_memory_reservation="512"}
|
|
+: ${OCF_RESKEY_utilization_host_memory:="true"}
|
|
+: ${OCF_RESKEY_utilization_host_memory_reservation="512"}
|
|
+
|
|
+OCF_REQUIRED_PARAMS=""
|
|
+OCF_REQUIRED_BINARIES=""
|
|
+ocf_rarun $*
|