bug fix: deploy every cyborg components correctly
Different components need different config. Change-Id: Id73cd0dd7eb2abc2d411cc3d5abbbd4e3df58f0f
This commit is contained in:
parent
179bcd1711
commit
34f8c6a147
@ -62,17 +62,22 @@ else
|
|||||||
CYBORG_API_URL="$CYBORG_SERVICE_PROTOCOL://$CYBORG_SERVICE_HOST:$CYBORG_SERVICE_PORT"
|
CYBORG_API_URL="$CYBORG_SERVICE_PROTOCOL://$CYBORG_SERVICE_HOST:$CYBORG_SERVICE_PORT"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# install_cyborg() - Install the things!
|
function install_cyborg_in_controller {
|
||||||
function install_cyborg {
|
if is_service_enabled cyborg-api; then
|
||||||
# make sure all needed service were enabled
|
|
||||||
local req_services="key"
|
local req_services="key"
|
||||||
req_services+=" nova glance neutron"
|
req_services+=" placement"
|
||||||
for srv in $req_services; do
|
for srv in $req_services; do
|
||||||
if ! is_service_enabled "$srv"; then
|
if ! is_service_enabled "$srv"; then
|
||||||
die $LINENO "$srv should be enabled for Cyborg."
|
die $LINENO "$srv should be enabled for Cyborg."
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
# install_cyborg() - Install the things!
|
||||||
|
function install_cyborg {
|
||||||
|
# make sure all needed services are enabled
|
||||||
|
install_cyborg_in_controller
|
||||||
setup_develop $CYBORG_DIR
|
setup_develop $CYBORG_DIR
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -116,6 +121,7 @@ function configure_cyborg_dirs {
|
|||||||
# ------------------------------
|
# ------------------------------
|
||||||
# service cyborg admin
|
# service cyborg admin
|
||||||
function create_cyborg_accounts {
|
function create_cyborg_accounts {
|
||||||
|
if is_service_enabled cyborg-api; then
|
||||||
create_service_user "cyborg" "admin"
|
create_service_user "cyborg" "admin"
|
||||||
get_or_create_service "cyborg" "accelerator" "Cyborg Accelerators Service"
|
get_or_create_service "cyborg" "accelerator" "Cyborg Accelerators Service"
|
||||||
get_or_create_endpoint "cyborg" \
|
get_or_create_endpoint "cyborg" \
|
||||||
@ -123,6 +129,7 @@ function create_cyborg_accounts {
|
|||||||
"$CYBORG_API_URL/v1" \
|
"$CYBORG_API_URL/v1" \
|
||||||
"$CYBORG_API_URL/v1" \
|
"$CYBORG_API_URL/v1" \
|
||||||
"$CYBORG_API_URL/v1"
|
"$CYBORG_API_URL/v1"
|
||||||
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -261,12 +268,14 @@ function create_cyborg_cache_dir {
|
|||||||
|
|
||||||
# init_cyborg() - Initialize databases, etc.
|
# init_cyborg() - Initialize databases, etc.
|
||||||
function init_cyborg {
|
function init_cyborg {
|
||||||
|
if is_service_enabled cyborg-api; then
|
||||||
# (re)create Cyborg database
|
# (re)create Cyborg database
|
||||||
recreate_database cyborg utf8
|
recreate_database cyborg utf8
|
||||||
|
|
||||||
# Migrate cyborg database
|
# Migrate cyborg database
|
||||||
$CYBORG_BIN_DIR/cyborg-dbsync --config-file ${CYBORG_CONF_FILE} upgrade
|
$CYBORG_BIN_DIR/cyborg-dbsync --config-file ${CYBORG_CONF_FILE} upgrade
|
||||||
create_cyborg_cache_dir
|
create_cyborg_cache_dir
|
||||||
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -8,9 +8,9 @@ echo_summary "cyborg devstack plugin.sh called: $1/$2"
|
|||||||
source $DEST/cyborg/devstack/lib/cyborg
|
source $DEST/cyborg/devstack/lib/cyborg
|
||||||
source $DEST/cyborg/devstack/lib/opae
|
source $DEST/cyborg/devstack/lib/opae
|
||||||
|
|
||||||
if is_service_enabled cyborg-api cyborg-cond; then
|
|
||||||
if [[ "$1" == "stack" ]]; then
|
function pre_install_agent {
|
||||||
if [[ "$2" == "pre-install" ]]; then
|
if is_service_enabled cyborg-agent; then
|
||||||
# stack/pre-install - Called after (OS) setup is complete and before
|
# stack/pre-install - Called after (OS) setup is complete and before
|
||||||
# project source is installed
|
# project source is installed
|
||||||
echo_summary "Installing additional Cyborg packages"
|
echo_summary "Installing additional Cyborg packages"
|
||||||
@ -19,17 +19,41 @@ if is_service_enabled cyborg-api cyborg-cond; then
|
|||||||
elif [[ "$OPAE_INSTALL_ENABLE" == "True" ]]; then
|
elif [[ "$OPAE_INSTALL_ENABLE" == "True" ]]; then
|
||||||
echo "WARNING: Failed to install additional Cyborg packages"
|
echo "WARNING: Failed to install additional Cyborg packages"
|
||||||
fi
|
fi
|
||||||
elif [[ "$2" == "install" ]]; then
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function install_agent {
|
||||||
|
if is_service_enabled cyborg-agent; then
|
||||||
# stack/install - Called after the layer 1 and 2 projects source and
|
# stack/install - Called after the layer 1 and 2 projects source and
|
||||||
# their dependencies have been installed
|
# their dependencies have been installed
|
||||||
echo_summary "Installing Cyborg"
|
echo_summary "Installing Cyborg"
|
||||||
if ! is_service_enabled nova; then
|
if ! is_service_enabled n-cpu; then
|
||||||
source $RC_DIR/lib/nova_plugins/functions-libvirt
|
source $RC_DIR/lib/nova_plugins/functions-libvirt
|
||||||
install_libvirt
|
install_libvirt
|
||||||
fi
|
fi
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function cleanup_agent {
|
||||||
|
if is_service_enabled cyborg-agent; then
|
||||||
|
if [[ "$OPAE_INSTALL_ENABLE" == "True" ]]; then
|
||||||
|
uninstall_opae_packages
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
if is_service_enabled cyborg-api cyborg-cond || is_service_enabled cyborg-agent; then
|
||||||
|
if [[ "$1" == "stack" ]]; then
|
||||||
|
if [[ "$2" == "pre-install" ]]; then
|
||||||
|
pre_install_agent
|
||||||
|
elif [[ "$2" == "install" ]]; then
|
||||||
|
install_agent
|
||||||
install_cyborg
|
install_cyborg
|
||||||
elif [[ "$2" == "post-config" ]]; then
|
elif [[ "$2" == "post-config" ]]; then
|
||||||
# stack/post-config - Called after the layer 1 and 2 services have been
|
# stack/post-config - Called after the layer 0 and 2 services have been
|
||||||
# configured. All configuration files for enabled services should exist
|
# configured. All configuration files for enabled services should exist
|
||||||
# at this point.
|
# at this point.
|
||||||
echo_summary "Configuring Cyborg"
|
echo_summary "Configuring Cyborg"
|
||||||
@ -56,8 +80,6 @@ if is_service_enabled cyborg-api cyborg-cond; then
|
|||||||
# clean - Called by clean.sh before other services are cleaned, but after
|
# clean - Called by clean.sh before other services are cleaned, but after
|
||||||
# unstack.sh has been called.
|
# unstack.sh has been called.
|
||||||
cleanup_cyborg
|
cleanup_cyborg
|
||||||
if [[ "$OPAE_INSTALL_ENABLE" == "True" ]]; then
|
cleanup_agent
|
||||||
uninstall_opae_packages
|
|
||||||
fi
|
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
@ -142,6 +142,35 @@ Disable OPAE install
|
|||||||
If you do not want to try Intel FPGA, you can disable OPAE install. Then you
|
If you do not want to try Intel FPGA, you can disable OPAE install. Then you
|
||||||
do not depend on specific OS verson.
|
do not depend on specific OS verson.
|
||||||
|
|
||||||
|
Multi-Node Lab
|
||||||
|
--------------
|
||||||
|
If you want to setup an OpenStack with cyborg in a realistic test configuration
|
||||||
|
with multiple physical servers. Please ref [#MultiNodeLab]_.
|
||||||
|
|
||||||
|
Cluster Controller
|
||||||
|
>>>>>>>>>>>>>>>>>>
|
||||||
|
|
||||||
|
::
|
||||||
|
|
||||||
|
disable_service cyborg-agent
|
||||||
|
|
||||||
|
Compute Nodes
|
||||||
|
>>>>>>>>>>>>>
|
||||||
|
|
||||||
|
::
|
||||||
|
|
||||||
|
enable_service cyborg-agent
|
||||||
|
disable_service cyborg-api
|
||||||
|
disable_service cyborg-cond
|
||||||
|
|
||||||
|
- If you do not want to setup cyborg-agent on controller, you can disable it.
|
||||||
|
- You do not need to enable cyborg-api and cyborg-cond on compute nodes.
|
||||||
|
|
||||||
|
Cell V2 Deployment
|
||||||
|
>>>>>>>>>>>>>>>>>>
|
||||||
|
|
||||||
|
Compute node services must be mapped to a cell before they can be used.
|
||||||
|
Cell V2 deployment, please ref [#CellV2]_.
|
||||||
|
|
||||||
Run DevStack
|
Run DevStack
|
||||||
------------
|
------------
|
||||||
@ -170,3 +199,11 @@ Horizon
|
|||||||
|
|
||||||
You can access horizon to experience the web interface to OpenStack, and manage
|
You can access horizon to experience the web interface to OpenStack, and manage
|
||||||
vms, networks, volumes, and images from there.
|
vms, networks, volumes, and images from there.
|
||||||
|
|
||||||
|
References
|
||||||
|
==========
|
||||||
|
|
||||||
|
.. [#MultiNodeLab] `Openstack Multi-Node Lab Setup
|
||||||
|
<https://docs.openstack.org/devstack/latest/guides/multinode-lab.html>`_
|
||||||
|
.. [#CellV2] `Openstack Cell V2 Deployment Guide
|
||||||
|
<https://docs.openstack.org/nova/latest/user/cells.html>`_
|
||||||
|
Loading…
Reference in New Issue
Block a user