Merge "Add support to optionally launch the heat service."
This commit is contained in:
commit
5090fffa8b
@ -34,3 +34,8 @@ catalog.RegionOne.image.publicURL = http://%SERVICE_HOST%:9292
|
|||||||
catalog.RegionOne.image.adminURL = http://%SERVICE_HOST%:9292
|
catalog.RegionOne.image.adminURL = http://%SERVICE_HOST%:9292
|
||||||
catalog.RegionOne.image.internalURL = http://%SERVICE_HOST%:9292
|
catalog.RegionOne.image.internalURL = http://%SERVICE_HOST%:9292
|
||||||
catalog.RegionOne.image.name = Image Service
|
catalog.RegionOne.image.name = Image Service
|
||||||
|
|
||||||
|
catalog.RegionOne.heat.publicURL = http://%SERVICE_HOST%:8000/v1
|
||||||
|
catalog.RegionOne.heat.adminURL = http://%SERVICE_HOST%:8000/v1
|
||||||
|
catalog.RegionOne.heat.internalURL = http://%SERVICE_HOST%:8000/v1
|
||||||
|
catalog.RegionOne.heat.name = Heat Service
|
||||||
|
@ -10,6 +10,7 @@
|
|||||||
# service quantum admin # if enabled
|
# service quantum admin # if enabled
|
||||||
# service swift admin # if enabled
|
# service swift admin # if enabled
|
||||||
# service cinder admin # if enabled
|
# service cinder admin # if enabled
|
||||||
|
# service heat admin # if enabled
|
||||||
# demo admin admin
|
# demo admin admin
|
||||||
# demo demo Member, anotherrole
|
# demo demo Member, anotherrole
|
||||||
# invisible_to_admin demo Member
|
# invisible_to_admin demo Member
|
||||||
@ -154,6 +155,29 @@ if [[ "$ENABLED_SERVICES" =~ "n-vol" ]]; then
|
|||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
# Heat
|
||||||
|
if [[ "$ENABLED_SERVICES" =~ "heat" ]]; then
|
||||||
|
HEAT_USER=$(get_id keystone user-create --name=heat \
|
||||||
|
--pass="$SERVICE_PASSWORD" \
|
||||||
|
--tenant_id $SERVICE_TENANT \
|
||||||
|
--email=heat@example.com)
|
||||||
|
keystone user-role-add --tenant_id $SERVICE_TENANT \
|
||||||
|
--user_id $HEAT_USER \
|
||||||
|
--role_id $ADMIN_ROLE
|
||||||
|
if [[ "$KEYSTONE_CATALOG_BACKEND" = 'sql' ]]; then
|
||||||
|
HEAT_SERVICE=$(get_id keystone service-create \
|
||||||
|
--name=heat \
|
||||||
|
--type=orchestration \
|
||||||
|
--description="Heat Service")
|
||||||
|
keystone endpoint-create \
|
||||||
|
--region RegionOne \
|
||||||
|
--service_id $HEAT_SERVICE \
|
||||||
|
--publicurl "http://$SERVICE_HOST:$HEAT_API_PORT/v1" \
|
||||||
|
--adminurl "http://$SERVICE_HOST:$HEAT_API_PORT/v1" \
|
||||||
|
--internalurl "http://$SERVICE_HOST:$HEAT_API_PORT/v1"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
# Glance
|
# Glance
|
||||||
if [[ "$ENABLED_SERVICES" =~ "g-api" ]]; then
|
if [[ "$ENABLED_SERVICES" =~ "g-api" ]]; then
|
||||||
GLANCE_USER=$(get_id keystone user-create \
|
GLANCE_USER=$(get_id keystone user-create \
|
||||||
@ -296,3 +320,4 @@ if [[ "$ENABLED_SERVICES" =~ "c-api" ]]; then
|
|||||||
--internalurl "http://$SERVICE_HOST:8776/v1/\$(tenant_id)s"
|
--internalurl "http://$SERVICE_HOST:8776/v1/\$(tenant_id)s"
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
156
lib/heat
Normal file
156
lib/heat
Normal file
@ -0,0 +1,156 @@
|
|||||||
|
# lib/heat
|
||||||
|
# Install and start Heat service
|
||||||
|
# To enable, add the following to localrc
|
||||||
|
# ENABLED_SERVICES+=,heat,h-api,h-eng,h-meta
|
||||||
|
|
||||||
|
# Dependencies:
|
||||||
|
# - functions
|
||||||
|
|
||||||
|
# stack.sh
|
||||||
|
# ---------
|
||||||
|
# install_XXX
|
||||||
|
# configure_XXX
|
||||||
|
# init_XXX
|
||||||
|
# start_XXX
|
||||||
|
# stop_XXX
|
||||||
|
# cleanup_XXX
|
||||||
|
|
||||||
|
# Print the commands being run so that we can see the command that triggers
|
||||||
|
# an error. It is also useful for following along as the install occurs.
|
||||||
|
set -o xtrace
|
||||||
|
|
||||||
|
|
||||||
|
# Defaults
|
||||||
|
# --------
|
||||||
|
HEAT_DIR=$DEST/heat
|
||||||
|
|
||||||
|
# set up default directories
|
||||||
|
|
||||||
|
# cleanup_heat() - Remove residual data files, anything left over from previous
|
||||||
|
# runs that a clean run would need to clean up
|
||||||
|
function cleanup_heat() {
|
||||||
|
# This function intentionally left blank
|
||||||
|
:
|
||||||
|
}
|
||||||
|
|
||||||
|
# configure_heat() - Set config files, create data dirs, etc
|
||||||
|
function configure_heat() {
|
||||||
|
setup_develop $HEAT_DIR
|
||||||
|
|
||||||
|
HEAT_CONF_DIR=/etc/heat
|
||||||
|
if [[ ! -d $HEAT_CONF_DIR ]]; then
|
||||||
|
sudo mkdir -p $HEAT_CONF_DIR
|
||||||
|
fi
|
||||||
|
sudo chown `whoami` $HEAT_CONF_DIR
|
||||||
|
|
||||||
|
HEAT_API_HOST=${HEAT_API_HOST:-$SERVICE_HOST}
|
||||||
|
HEAT_API_PORT=${HEAT_API_PORT:-8000}
|
||||||
|
HEAT_ENGINE_HOST=${HEAT_ENGINE_HOST:-$SERVICE_HOST}
|
||||||
|
HEAT_ENGINE_PORT=${HEAT_ENGINE_PORT:-8001}
|
||||||
|
HEAT_METADATA_HOST=${HEAT_METADATA_HOST:-$SERVICE_HOST}
|
||||||
|
HEAT_METADATA_PORT=${HEAT_METADATA_PORT:-8002}
|
||||||
|
|
||||||
|
HEAT_API_CONF=$HEAT_CONF_DIR/heat-api.conf
|
||||||
|
cp $HEAT_DIR/etc/heat-api.conf $HEAT_API_CONF
|
||||||
|
iniset $HEAT_API_CONF DEFAULT debug True
|
||||||
|
inicomment $HEAT_API_CONF DEFAULT log_file
|
||||||
|
iniset $HEAT_API_CONF DEFAULT use_syslog $SYSLOG
|
||||||
|
iniset $HEAT_API_CONF DEFAULT bind_host $HEAT_API_HOST
|
||||||
|
iniset $HEAT_API_CONF DEFAULT bind_port $HEAT_API_PORT
|
||||||
|
|
||||||
|
if is_service_enabled rabbit; then
|
||||||
|
iniset $HEAT_API_CONF DEFAULT rpc_backend heat.openstack.common.rpc.impl_kombu
|
||||||
|
iniset $HEAT_API_CONF DEFAULT rabbit_password $RABBIT_PASSWORD
|
||||||
|
iniset $HEAT_API_CONF DEFAULT rabbit_host $RABBIT_HOST
|
||||||
|
elif is_service_enabled qpid; then
|
||||||
|
iniset $HEAT_API_CONF DEFAULT rpc_backend heat.openstack.common.rpc.impl_qpid
|
||||||
|
fi
|
||||||
|
|
||||||
|
HEAT_API_PASTE_INI=$HEAT_CONF_DIR/heat-api-paste.ini
|
||||||
|
cp $HEAT_DIR/etc/heat-api-paste.ini $HEAT_API_PASTE_INI
|
||||||
|
iniset $HEAT_API_PASTE_INI filter:authtoken auth_host $KEYSTONE_AUTH_HOST
|
||||||
|
iniset $HEAT_API_PASTE_INI filter:authtoken auth_port $KEYSTONE_AUTH_PORT
|
||||||
|
iniset $HEAT_API_PASTE_INI filter:authtoken auth_protocol $KEYSTONE_AUTH_PROTOCOL
|
||||||
|
iniset $HEAT_API_PASTE_INI filter:authtoken auth_uri $KEYSTONE_SERVICE_PROTOCOL://$KEYSTONE_SERVICE_HOST:$KEYSTONE_SERVICE_PORT/v2.0
|
||||||
|
iniset $HEAT_API_PASTE_INI filter:authtoken admin_tenant_name $SERVICE_TENANT_NAME
|
||||||
|
iniset $HEAT_API_PASTE_INI filter:authtoken admin_user heat
|
||||||
|
iniset $HEAT_API_PASTE_INI filter:authtoken admin_password $SERVICE_PASSWORD
|
||||||
|
iniset $HEAT_API_PASTE_INI filter:ec2authtoken auth_uri $KEYSTONE_SERVICE_PROTOCOL://$KEYSTONE_SERVICE_HOST:$KEYSTONE_SERVICE_PORT/v2.0
|
||||||
|
iniset $HEAT_API_PASTE_INI filter:ec2authtoken keystone_ec2_uri $KEYSTONE_SERVICE_PROTOCOL://$KEYSTONE_SERVICE_HOST:$KEYSTONE_SERVICE_PORT/v2.0/ec2tokens
|
||||||
|
|
||||||
|
HEAT_ENGINE_CONF=$HEAT_CONF_DIR/heat-engine.conf
|
||||||
|
cp $HEAT_DIR/etc/heat-engine.conf $HEAT_ENGINE_CONF
|
||||||
|
iniset $HEAT_ENGINE_CONF DEFAULT debug True
|
||||||
|
inicomment $HEAT_ENGINE_CONF DEFAULT log_file
|
||||||
|
iniset $HEAT_ENGINE_CONF DEFAULT use_syslog $SYSLOG
|
||||||
|
iniset $HEAT_ENGINE_CONF DEFAULT bind_host $HEAT_ENGINE_HOST
|
||||||
|
iniset $HEAT_ENGINE_CONF DEFAULT bind_port $HEAT_ENGINE_PORT
|
||||||
|
iniset $HEAT_ENGINE_CONF DEFAULT sql_connection $BASE_SQL_CONN/heat?charset=utf8
|
||||||
|
iniset $HEAT_ENGINE_CONF DEFAULT auth_encryption_key `hexdump -n 16 -v -e '/1 "%02x"' /dev/random`
|
||||||
|
|
||||||
|
if is_service_enabled rabbit; then
|
||||||
|
iniset $HEAT_ENGINE_CONF DEFAULT rpc_backend heat.openstack.common.rpc.impl_kombu
|
||||||
|
iniset $HEAT_ENGINE_CONF DEFAULT rabbit_password $RABBIT_PASSWORD
|
||||||
|
iniset $HEAT_ENGINE_CONF DEFAULT rabbit_host $RABBIT_HOST
|
||||||
|
elif is_service_enabled qpid; then
|
||||||
|
iniset $HEAT_ENGINE_CONF DEFAULT rpc_backend heat.openstack.common.rpc.impl_qpid
|
||||||
|
fi
|
||||||
|
|
||||||
|
HEAT_ENGINE_PASTE_INI=$HEAT_CONF_DIR/heat-engine-paste.ini
|
||||||
|
cp $HEAT_DIR/etc/heat-engine-paste.ini $HEAT_ENGINE_PASTE_INI
|
||||||
|
iniset $HEAT_ENGINE_PASTE_INI filter:authtoken auth_host $KEYSTONE_AUTH_HOST
|
||||||
|
iniset $HEAT_ENGINE_PASTE_INI filter:authtoken auth_port $KEYSTONE_AUTH_PORT
|
||||||
|
iniset $HEAT_ENGINE_PASTE_INI filter:authtoken auth_protocol $KEYSTONE_AUTH_PROTOCOL
|
||||||
|
iniset $HEAT_ENGINE_PASTE_INI filter:authtoken auth_uri $KEYSTONE_SERVICE_PROTOCOL://$KEYSTONE_SERVICE_HOST:$KEYSTONE_SERVICE_PORT/v2.0
|
||||||
|
iniset $HEAT_ENGINE_PASTE_INI filter:authtoken admin_tenant_name $SERVICE_TENANT_NAME
|
||||||
|
iniset $HEAT_ENGINE_PASTE_INI filter:authtoken admin_user heat
|
||||||
|
iniset $HEAT_ENGINE_PASTE_INI filter:authtoken admin_password $SERVICE_PASSWORD
|
||||||
|
|
||||||
|
HEAT_METADATA_CONF=$HEAT_CONF_DIR/heat-metadata.conf
|
||||||
|
cp $HEAT_DIR/etc/heat-metadata.conf $HEAT_METADATA_CONF
|
||||||
|
iniset $HEAT_METADATA_CONF DEFAULT debug True
|
||||||
|
inicomment $HEAT_METADATA_CONF DEFAULT log_file
|
||||||
|
iniset $HEAT_METADATA_CONF DEFAULT use_syslog $SYSLOG
|
||||||
|
iniset $HEAT_METADATA_CONF DEFAULT bind_host $HEAT_METADATA_HOST
|
||||||
|
iniset $HEAT_METADATA_CONF DEFAULT bind_port $HEAT_METADATA_PORT
|
||||||
|
|
||||||
|
if is_service_enabled rabbit; then
|
||||||
|
iniset $HEAT_METADATA_CONF DEFAULT rpc_backend heat.openstack.common.rpc.impl_kombu
|
||||||
|
iniset $HEAT_METADATA_CONF DEFAULT rabbit_password $RABBIT_PASSWORD
|
||||||
|
iniset $HEAT_METADATA_CONF DEFAULT rabbit_host $RABBIT_HOST
|
||||||
|
elif is_service_enabled qpid; then
|
||||||
|
iniset $HEAT_METADATA_CONF DEFAULT rpc_backend heat.openstack.common.rpc.impl_qpid
|
||||||
|
fi
|
||||||
|
|
||||||
|
HEAT_METADATA_PASTE_INI=$HEAT_CONF_DIR/heat-metadata-paste.ini
|
||||||
|
cp $HEAT_DIR/etc/heat-metadata-paste.ini $HEAT_METADATA_PASTE_INI
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
# init_heat() - Initialize database
|
||||||
|
function init_heat() {
|
||||||
|
|
||||||
|
# (re)create heat database
|
||||||
|
mysql -u$MYSQL_USER -p$MYSQL_PASSWORD -e 'DROP DATABASE IF EXISTS heat;'
|
||||||
|
mysql -u$MYSQL_USER -p$MYSQL_PASSWORD -e 'CREATE DATABASE heat CHARACTER SET utf8;'
|
||||||
|
|
||||||
|
$HEAT_DIR/bin/heat-db-setup $os_PACKAGE -r $MYSQL_PASSWORD
|
||||||
|
}
|
||||||
|
|
||||||
|
# install_heat() - Collect source and prepare
|
||||||
|
function install_heat() {
|
||||||
|
git_clone $HEAT_REPO $HEAT_DIR $HEAT_BRANCH
|
||||||
|
}
|
||||||
|
|
||||||
|
# start_heat() - Start running processes, including screen
|
||||||
|
function start_heat() {
|
||||||
|
screen_it h-eng "cd $HEAT_DIR; bin/heat-engine --config-file=$HEAT_CONF_DIR/heat-engine.conf"
|
||||||
|
screen_it h-api "cd $HEAT_DIR; bin/heat-api --config-dir=$HEAT_CONF_DIR/heat-api.conf"
|
||||||
|
screen_it h-meta "cd $HEAT_DIR; bin/heat-metadata --config-dir=$HEAT_CONF_DIR/heat-metadata.conf"
|
||||||
|
}
|
||||||
|
|
||||||
|
# stop_heat() - Stop running processes (non-screen)
|
||||||
|
function stop_heat() {
|
||||||
|
# This function intentionally left blank
|
||||||
|
:
|
||||||
|
}
|
18
stack.sh
18
stack.sh
@ -2,7 +2,7 @@
|
|||||||
|
|
||||||
# ``stack.sh`` is an opinionated OpenStack developer installation. It
|
# ``stack.sh`` is an opinionated OpenStack developer installation. It
|
||||||
# installs and configures various combinations of **Glance**, **Horizon**,
|
# installs and configures various combinations of **Glance**, **Horizon**,
|
||||||
# **Keystone**, **Nova**, **Quantum** and **Swift**
|
# **Keystone**, **Nova**, **Quantum**, **Heat** and **Swift**
|
||||||
|
|
||||||
# This script allows you to specify configuration options of what git
|
# This script allows you to specify configuration options of what git
|
||||||
# repositories to use, enabled services, network configuration and various
|
# repositories to use, enabled services, network configuration and various
|
||||||
@ -241,6 +241,7 @@ sudo chown `whoami` $DATA_DIR
|
|||||||
# Get project function libraries
|
# Get project function libraries
|
||||||
source $TOP_DIR/lib/cinder
|
source $TOP_DIR/lib/cinder
|
||||||
source $TOP_DIR/lib/ceilometer
|
source $TOP_DIR/lib/ceilometer
|
||||||
|
source $TOP_DIR/lib/heat
|
||||||
|
|
||||||
# Set the destination directories for openstack projects
|
# Set the destination directories for openstack projects
|
||||||
NOVA_DIR=$DEST/nova
|
NOVA_DIR=$DEST/nova
|
||||||
@ -788,6 +789,9 @@ if is_service_enabled quantum; then
|
|||||||
# quantum
|
# quantum
|
||||||
git_clone $QUANTUM_REPO $QUANTUM_DIR $QUANTUM_BRANCH
|
git_clone $QUANTUM_REPO $QUANTUM_DIR $QUANTUM_BRANCH
|
||||||
fi
|
fi
|
||||||
|
if is_service_enabled heat; then
|
||||||
|
install_heat
|
||||||
|
fi
|
||||||
if is_service_enabled cinder; then
|
if is_service_enabled cinder; then
|
||||||
install_cinder
|
install_cinder
|
||||||
fi
|
fi
|
||||||
@ -828,6 +832,9 @@ if is_service_enabled quantum; then
|
|||||||
setup_develop $QUANTUM_CLIENT_DIR
|
setup_develop $QUANTUM_CLIENT_DIR
|
||||||
setup_develop $QUANTUM_DIR
|
setup_develop $QUANTUM_DIR
|
||||||
fi
|
fi
|
||||||
|
if is_service_enabled heat; then
|
||||||
|
configure_heat
|
||||||
|
fi
|
||||||
if is_service_enabled cinder; then
|
if is_service_enabled cinder; then
|
||||||
configure_cinder
|
configure_cinder
|
||||||
fi
|
fi
|
||||||
@ -1947,6 +1954,11 @@ if is_service_enabled mysql && is_service_enabled nova; then
|
|||||||
$NOVA_BIN_DIR/nova-manage db sync
|
$NOVA_BIN_DIR/nova-manage db sync
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
# Heat
|
||||||
|
# ------
|
||||||
|
if is_service_enabled heat; then
|
||||||
|
init_heat
|
||||||
|
fi
|
||||||
|
|
||||||
# Launch Services
|
# Launch Services
|
||||||
# ===============
|
# ===============
|
||||||
@ -2144,6 +2156,10 @@ screen_it swift "cd $SWIFT_DIR && $SWIFT_DIR/bin/swift-proxy-server ${SWIFT_CONF
|
|||||||
is_service_enabled swift3 || \
|
is_service_enabled swift3 || \
|
||||||
screen_it n-obj "cd $NOVA_DIR && $NOVA_BIN_DIR/nova-objectstore"
|
screen_it n-obj "cd $NOVA_DIR && $NOVA_BIN_DIR/nova-objectstore"
|
||||||
|
|
||||||
|
# launch heat engine, api and metadata
|
||||||
|
if is_service_enabled heat; then
|
||||||
|
start_heat
|
||||||
|
fi
|
||||||
|
|
||||||
# Install Images
|
# Install Images
|
||||||
# ==============
|
# ==============
|
||||||
|
4
stackrc
4
stackrc
@ -95,6 +95,10 @@ QUANTUM_CLIENT_BRANCH=master
|
|||||||
TEMPEST_REPO=${GIT_BASE}/openstack/tempest.git
|
TEMPEST_REPO=${GIT_BASE}/openstack/tempest.git
|
||||||
TEMPEST_BRANCH=master
|
TEMPEST_BRANCH=master
|
||||||
|
|
||||||
|
# heat service
|
||||||
|
HEAT_REPO=${GIT_BASE}/heat-api/heat.git
|
||||||
|
HEAT_BRANCH=master
|
||||||
|
|
||||||
# Nova hypervisor configuration. We default to libvirt with **kvm** but will
|
# Nova hypervisor configuration. We default to libvirt with **kvm** but will
|
||||||
# drop back to **qemu** if we are unable to load the kvm module. ``stack.sh`` can
|
# drop back to **qemu** if we are unable to load the kvm module. ``stack.sh`` can
|
||||||
# also install an **LXC** or **OpenVZ** based system.
|
# also install an **LXC** or **OpenVZ** based system.
|
||||||
|
Loading…
Reference in New Issue
Block a user