#!/bin/sh # Copyright 2015 Red Hat, Inc. # # Description: Manages compute daemons # # Authors: Andrew Beekhof # # Support: openstack@lists.openstack.org # License: Apache Software License (ASL) 2.0 # ####################################################################### # 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 [ $? = 0 ]; then NOVA_HOST="$parsed_value" fi done if [ -z "$NOVA_HOST" ]; then if [ "x${OCF_RESKEY_domain}" != x ]; then NOVA_HOST=$(uname -n | awk -F. '{print $1}') else NOVA_HOST=$(uname -n) fi validate_host=0 fi # We only need to check a configured value, calculated ones are fine if [ $validate_host -eq 1 ]; 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