#!/bin/sh # # # NovaCompute agent manages compute daemons. # # Copyright (c) 2015 # # 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 ### : ${__OCF_ACTION=$1} ####################################################################### meta_data() { cat < 1.0 OpenStack Nova Compute Server. OpenStack Nova Compute Server Authorization URL for connecting to keystone in admin context Authorization URL Username for connecting to keystone in admin context Username Password for connecting to keystone in admin context Password Tenant name for connecting to keystone in admin context. Note that with Keystone V3 tenant names are only unique within a domain. Tenant name DNS domain in which hosts live, useful when the cluster uses short names and nova uses FQDN DNS domain Nova API location (internal, public or admin URL) Nova API location (internal, public or admin URL) Region name for connecting to nova. Region name Explicitly allow client to perform "insecure" TLS (https) requests. The server's certificate will not be verified against any certificate authorities. This option should be used with caution. Allow insecure TLS requests Indicate that nova storage for instances is not shared across compute nodes. This must match the reality of how nova storage is configured! Otherwise VMs could end up in error state upon evacuation. When storage is non-shared, instances on dead hypervisors will be rebuilt from their original image or volume, so anything on ephemeral storage will be lost. Disable shared storage recovery for instances How long to wait for nova to finish evacuating instances elsewhere before starting nova-compute. Only used when the agent detects evacuations might be in progress. You may need to increase the start timeout when increasing this value. Delay to allow evacuations time to complete END } ####################################################################### # don't exit on TERM, to test that lrmd makes sure that we do exit trap sigterm_handler TERM sigterm_handler() { ocf_log info "They use TERM to bring us down. No such luck." return } nova_usage() { cat </dev/null) if [ $? = 1 ]; then if [ "x${OCF_RESKEY_domain}" != x ]; then NOVA_HOST=$(uname -n | awk -F. '{print $1}') else NOVA_HOST=$(uname -n) fi fi # We only need to check a configured value, calculated ones are fine crudini --get /etc/nova/nova.conf DEFAULT host 2>/dev/null if [ $? = 0 ]; then if [ "x${OCF_RESKEY_domain}" != x ]; then short_host=$(uname -n | awk -F. '{print $1}') if [ "x$NOVA_HOST" != "x${short_host}" ]; then ocf_exit_reason "Invalid Nova host name, must be" \ "${short_host} in order for instance recovery to function" rc=$OCF_ERR_CONFIGURED fi elif [ "x$NOVA_HOST" != "x$(uname -n)" ]; then ocf_exit_reason "Invalid Nova host name, must be $(uname -n) in" \ "order for instance recovery to function" rc=$OCF_ERR_CONFIGURED fi fi if [ $rc != $OCF_SUCCESS ]; then exit $rc fi return $rc } : ${OCF_RESKEY_evacuation_delay=120} case $__OCF_ACTION in meta-data) meta_data exit $OCF_SUCCESS ;; usage|help) nova_usage exit $OCF_SUCCESS ;; esac case $__OCF_ACTION in start) nova_validate nova_start ;; stop) nova_stop ;; monitor) nova_validate nova_monitor ;; notify) nova_notify ;; validate-all) exit $OCF_SUCCESS ;; *) nova_usage exit $OCF_ERR_UNIMPLEMENTED ;; esac rc=$? ocf_log debug "${OCF_RESOURCE_INSTANCE} $__OCF_ACTION : $rc" exit $rc