Support running api under uWSGI
This change add the support to run mogan-api server under uWSGI Implements: bp support-uwsgi Change-Id: I561028f39092b0b7aca5d5216dde36636be70b66
This commit is contained in:
parent
b18b46370f
commit
80234fadce
@ -14,13 +14,6 @@ set -o xtrace
|
|||||||
# Defaults
|
# Defaults
|
||||||
# --------
|
# --------
|
||||||
|
|
||||||
# Support entry points installation of console scripts
|
|
||||||
if [[ -d ${MOGAN_DIR}/bin ]]; then
|
|
||||||
MOGAN_BIN_DIR=${MOGAN_DIR}/bin
|
|
||||||
else
|
|
||||||
MOGAN_BIN_DIR=$(get_python_exec_prefix)
|
|
||||||
fi
|
|
||||||
|
|
||||||
# create_mogan_accounts - Set up common required mogan accounts
|
# create_mogan_accounts - Set up common required mogan accounts
|
||||||
#
|
#
|
||||||
# Project User Roles
|
# Project User Roles
|
||||||
@ -31,9 +24,9 @@ function create_mogan_accounts {
|
|||||||
get_or_create_service "mogan" "baremetal_compute" "Baremetal Compute"
|
get_or_create_service "mogan" "baremetal_compute" "Baremetal Compute"
|
||||||
get_or_create_endpoint "baremetal_compute" \
|
get_or_create_endpoint "baremetal_compute" \
|
||||||
"$REGION_NAME" \
|
"$REGION_NAME" \
|
||||||
"${MOGAN_SERVICE_PROTOCOL}://${MOGAN_SERVICE_HOST}:${MOGAN_SERVICE_PORT}/v1" \
|
"${MOGAN_SERVICE_PROTOCOL}://${MOGAN_SERVICE_HOST}/baremetal_compute/v1" \
|
||||||
"${MOGAN_SERVICE_PROTOCOL}://${MOGAN_SERVICE_HOST}:${MOGAN_SERVICE_PORT}/v1" \
|
"${MOGAN_SERVICE_PROTOCOL}://${MOGAN_SERVICE_HOST}/baremetal_compute/v1" \
|
||||||
"${MOGAN_SERVICE_PROTOCOL}://${MOGAN_SERVICE_HOST}:${MOGAN_SERVICE_PORT}/v1"
|
"${MOGAN_SERVICE_PROTOCOL}://${MOGAN_SERVICE_HOST}/baremetal_compute/v1"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -119,6 +112,9 @@ function configure_mogan {
|
|||||||
if [ "$LOG_COLOR" == "True" ] && [ "$SYSLOG" == "False" ]; then
|
if [ "$LOG_COLOR" == "True" ] && [ "$SYSLOG" == "False" ]; then
|
||||||
setup_colorized_logging ${MOGAN_CONF_FILE} DEFAULT tenant user
|
setup_colorized_logging ${MOGAN_CONF_FILE} DEFAULT tenant user
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
# uWSGI configuration
|
||||||
|
write_uwsgi_config "$MOGAN_UWSGI_CONF" "$MOGAN_UWSGI_APP" "/baremetal_compute"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -139,6 +135,7 @@ function install_mogan {
|
|||||||
die $LINENO "$srv should be enabled for Mogan."
|
die $LINENO "$srv should be enabled for Mogan."
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
|
pip_install uwsgi
|
||||||
|
|
||||||
setup_develop ${MOGAN_DIR}
|
setup_develop ${MOGAN_DIR}
|
||||||
}
|
}
|
||||||
@ -155,8 +152,8 @@ function install_mogan_pythonclient {
|
|||||||
function start_mogan {
|
function start_mogan {
|
||||||
if is_service_enabled mogan-api && is_service_enabled mogan-engine && is_service_enabled mogan-scheduler; then
|
if is_service_enabled mogan-api && is_service_enabled mogan-engine && is_service_enabled mogan-scheduler; then
|
||||||
echo_summary "Installing all mogan services in separate processes"
|
echo_summary "Installing all mogan services in separate processes"
|
||||||
run_process mogan-api "${MOGAN_BIN_DIR}/mogan-api --config-file ${MOGAN_CONF_DIR}/mogan.conf"
|
run_process mogan-api "$MOGAN_BIN_DIR/uwsgi --ini $MOGAN_UWSGI_CONF"
|
||||||
if ! wait_for_service ${SERVICE_TIMEOUT} ${MOGAN_SERVICE_PROTOCOL}://${MOGAN_SERVICE_HOST}:${MOGAN_SERVICE_PORT}; then
|
if ! wait_for_service ${SERVICE_TIMEOUT} ${MOGAN_SERVICE_PROTOCOL}://${MOGAN_SERVICE_HOST}/baremetal_compute; then
|
||||||
die $LINENO "mogan-api did not start"
|
die $LINENO "mogan-api did not start"
|
||||||
fi
|
fi
|
||||||
run_process mogan-engine "${MOGAN_BIN_DIR}/mogan-engine --config-file ${MOGAN_CONF_DIR}/mogan.conf"
|
run_process mogan-engine "${MOGAN_BIN_DIR}/mogan-engine --config-file ${MOGAN_CONF_DIR}/mogan.conf"
|
||||||
@ -175,6 +172,7 @@ function stop_mogan {
|
|||||||
for serv in mogan-api mogan-engine mogan-scheduler mogan-consoleauth mogan-shellinaboxproxy; do
|
for serv in mogan-api mogan-engine mogan-scheduler mogan-consoleauth mogan-shellinaboxproxy; do
|
||||||
stop_process $serv
|
stop_process $serv
|
||||||
done
|
done
|
||||||
|
remove_uwsgi_config "$MOGAN_UWSGI_CONF" "$MOGAN_UWSGI_APP"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -23,7 +23,15 @@ MOGAN_CONF_FILE=${MOGAN_CONF_DIR}/mogan.conf
|
|||||||
MOGAN_DEBUG=${MOGAN_DEBUG:-True}
|
MOGAN_DEBUG=${MOGAN_DEBUG:-True}
|
||||||
|
|
||||||
MOGAN_SERVICE_HOST=${MOGAN_SERVICE_HOST:-$SERVICE_HOST}
|
MOGAN_SERVICE_HOST=${MOGAN_SERVICE_HOST:-$SERVICE_HOST}
|
||||||
MOGAN_SERVICE_PORT=${MOGAN_SERVICE_PORT:-6688}
|
|
||||||
MOGAN_SERVICE_PROTOCOL=${MOGAN_SERVICE_PROTOCOL:-$SERVICE_PROTOCOL}
|
MOGAN_SERVICE_PROTOCOL=${MOGAN_SERVICE_PROTOCOL:-$SERVICE_PROTOCOL}
|
||||||
|
|
||||||
MOGAN_ADMIN_USER=${MOGAN_ADMIN_USER:-mogan}
|
MOGAN_ADMIN_USER=${MOGAN_ADMIN_USER:-mogan}
|
||||||
|
|
||||||
|
if [[ -d ${MOGAN_DIR}/bin ]]; then
|
||||||
|
MOGAN_BIN_DIR=${MOGAN_DIR}/bin
|
||||||
|
else
|
||||||
|
MOGAN_BIN_DIR=$(get_python_exec_prefix)
|
||||||
|
fi
|
||||||
|
|
||||||
|
MOGAN_UWSGI_CONF=$MOGAN_CONF_DIR/mogan-uwsgi.ini
|
||||||
|
MOGAN_UWSGI_APP=$MOGAN_BIN_DIR/mogan-api-wsgi
|
||||||
|
@ -54,7 +54,7 @@ project.
|
|||||||
Setting Up Your Development Environment <dev/dev-quickstart>
|
Setting Up Your Development Environment <dev/dev-quickstart>
|
||||||
|
|
||||||
Advanced testing and guides
|
Advanced testing and guides
|
||||||
----------------------------
|
---------------------------
|
||||||
|
|
||||||
.. toctree::
|
.. toctree::
|
||||||
:maxdepth: 1
|
:maxdepth: 1
|
||||||
@ -103,3 +103,11 @@ Running tests of Mogan
|
|||||||
:maxdepth: 1
|
:maxdepth: 1
|
||||||
|
|
||||||
dev/testing
|
dev/testing
|
||||||
|
|
||||||
|
Installation and Setup
|
||||||
|
======================
|
||||||
|
|
||||||
|
.. toctree::
|
||||||
|
:maxdepth: 1
|
||||||
|
|
||||||
|
installation/uwsgi
|
||||||
|
66
doc/source/installation/uwsgi.rst
Normal file
66
doc/source/installation/uwsgi.rst
Normal file
@ -0,0 +1,66 @@
|
|||||||
|
..
|
||||||
|
Copyright (c) 2017 Intel Corporation
|
||||||
|
All Rights Reserved.
|
||||||
|
|
||||||
|
Licensed under the Apache License, Version 2.0 (the "License"); you may
|
||||||
|
not use this file except in compliance with the License. You may obtain
|
||||||
|
a copy of the License at
|
||||||
|
|
||||||
|
http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
|
||||||
|
Unless required by applicable law or agreed to in writing, software
|
||||||
|
distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
||||||
|
WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
||||||
|
License for the specific language governing permissions and limitations
|
||||||
|
under the License.
|
||||||
|
|
||||||
|
|
||||||
|
Running Mogan API using uWSGI
|
||||||
|
=============================
|
||||||
|
The recommended way to deploy Mogan is have a web server such as Apache
|
||||||
|
or nginx to handle http requests and proxy these requests to Mogan WSGI
|
||||||
|
app running in uWSGI. Mogan comes with some configuration templates on
|
||||||
|
how to deploy the api service with Apache and uWSGI.
|
||||||
|
|
||||||
|
app.wsgi
|
||||||
|
********
|
||||||
|
The ``mogan/api/app.wsgi`` file contains a WSGI application of
|
||||||
|
Mogan API service. This file is installed with Mogan application
|
||||||
|
code.
|
||||||
|
|
||||||
|
mogan-uwsgi.ini.sample
|
||||||
|
**********************
|
||||||
|
The ``mogan/etc/mogan-uwsgi.ini.sample`` file is a sample
|
||||||
|
configuration file for uWSGI server. Update the file to match your
|
||||||
|
system configuration.
|
||||||
|
|
||||||
|
Steps to use these sample configuration files:
|
||||||
|
|
||||||
|
1. Enable mod_proxy_uwsgi module
|
||||||
|
|
||||||
|
* On Ubuntu install required uwsgi package
|
||||||
|
``sudo apt-get install libapache2-mod-proxy-uwsgi``; enable using
|
||||||
|
``sudo a2enmod proxy``, ``sudo a2enmod proxy_uwsgi``.
|
||||||
|
* On Fedora the required package is mod_proxy_uwsgi; enable by creating a file
|
||||||
|
``/etc/httpd/conf.modules.d/11-proxy_uwsgi.conf`` containing
|
||||||
|
``LoadModule proxy_uwsgi_module modules/mod_proxy_uwsgi.so``
|
||||||
|
|
||||||
|
2. On deb-based systems copy or symlink the file to
|
||||||
|
``/etc/apache2/sites-available/mogan.conf``. For rpm-based systems the file should go into
|
||||||
|
``/etc/httpd/conf.d/mogan.conf``.
|
||||||
|
|
||||||
|
3. Enable Mogan site. On deb-based systems::
|
||||||
|
|
||||||
|
$ a2ensite mogan
|
||||||
|
$ service apache2 reload
|
||||||
|
|
||||||
|
On rpm-based systems::
|
||||||
|
|
||||||
|
$ service httpd reload
|
||||||
|
|
||||||
|
4. Copy mogan/etc/mogan-uwsgi.ini.sample to /etc/mogan/mogan-uwsgi.ini.
|
||||||
|
|
||||||
|
5. Start Mogan api using uWSGI::
|
||||||
|
|
||||||
|
$ sudo pip install uwsgi
|
||||||
|
$ uwsgi /etc/mogan/mogan-uwsgi.ini
|
25
etc/mogan-uwsgi.ini.sample
Normal file
25
etc/mogan-uwsgi.ini.sample
Normal file
@ -0,0 +1,25 @@
|
|||||||
|
[uwsgi]
|
||||||
|
wsgi-file = /usr/local/bin/mogan-api-wsgi
|
||||||
|
|
||||||
|
chmod-socket = 666
|
||||||
|
|
||||||
|
socket = /var/run/uwsgi/mogan-api-wsgi.socket
|
||||||
|
|
||||||
|
# Override the default size for headers from the 4k default.
|
||||||
|
buffer-size = 65535
|
||||||
|
|
||||||
|
# This is running standalone
|
||||||
|
master = true
|
||||||
|
|
||||||
|
enable-threads = true
|
||||||
|
|
||||||
|
# Tune this to your environment.
|
||||||
|
processes = 4
|
||||||
|
|
||||||
|
# uwsgi recommends this to prevent thundering herd on accept.
|
||||||
|
thunder-lock = true
|
||||||
|
|
||||||
|
plugins = python
|
||||||
|
|
||||||
|
# This ensures that file descriptors aren't shared between Searchlight processes.
|
||||||
|
lazy-apps = true
|
@ -12,6 +12,7 @@
|
|||||||
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
||||||
# License for the specific language governing permissions and limitations
|
# License for the specific language governing permissions and limitations
|
||||||
# under the License.
|
# under the License.
|
||||||
|
import sys
|
||||||
|
|
||||||
from oslo_config import cfg
|
from oslo_config import cfg
|
||||||
import pecan
|
import pecan
|
||||||
@ -29,6 +30,10 @@ def get_pecan_config():
|
|||||||
|
|
||||||
|
|
||||||
def setup_app(pecan_config=None, extra_hooks=None):
|
def setup_app(pecan_config=None, extra_hooks=None):
|
||||||
|
if not pecan_config:
|
||||||
|
pecan_config = get_pecan_config()
|
||||||
|
pecan.configuration.set_config(dict(pecan_config), overwrite=True)
|
||||||
|
|
||||||
app_hooks = [hooks.ConfigHook(),
|
app_hooks = [hooks.ConfigHook(),
|
||||||
hooks.DBHook(),
|
hooks.DBHook(),
|
||||||
hooks.EngineAPIHook(),
|
hooks.EngineAPIHook(),
|
||||||
@ -38,11 +43,6 @@ def setup_app(pecan_config=None, extra_hooks=None):
|
|||||||
if extra_hooks:
|
if extra_hooks:
|
||||||
app_hooks.extend(extra_hooks)
|
app_hooks.extend(extra_hooks)
|
||||||
|
|
||||||
if not pecan_config:
|
|
||||||
pecan_config = get_pecan_config()
|
|
||||||
|
|
||||||
pecan.configuration.set_config(dict(pecan_config), overwrite=True)
|
|
||||||
|
|
||||||
app = pecan.make_app(
|
app = pecan.make_app(
|
||||||
pecan_config.app.root,
|
pecan_config.app.root,
|
||||||
static_root=pecan_config.app.static_root,
|
static_root=pecan_config.app.static_root,
|
||||||
@ -66,3 +66,9 @@ class VersionSelectorApplication(object):
|
|||||||
|
|
||||||
def __call__(self, environ, start_response):
|
def __call__(self, environ, start_response):
|
||||||
return self.v1(environ, start_response)
|
return self.v1(environ, start_response)
|
||||||
|
|
||||||
|
|
||||||
|
def build_wsgi_app():
|
||||||
|
from mogan.common import service as mogan_service
|
||||||
|
mogan_service.prepare_service(sys.argv)
|
||||||
|
return setup_app()
|
||||||
|
21
mogan/api/app.wsgi
Normal file
21
mogan/api/app.wsgi
Normal file
@ -0,0 +1,21 @@
|
|||||||
|
# -*- mode: python -*-
|
||||||
|
#
|
||||||
|
# Licensed under the Apache License, Version 2.0 (the "License"); you may
|
||||||
|
# not use this file except in compliance with the License. You may obtain
|
||||||
|
# a copy of the License at
|
||||||
|
#
|
||||||
|
# http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
#
|
||||||
|
# Unless required by applicable law or agreed to in writing, software
|
||||||
|
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
||||||
|
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
||||||
|
# License for the specific language governing permissions and limitations
|
||||||
|
# under the License.
|
||||||
|
"""Use this file for deploying the API under uwsgi.
|
||||||
|
|
||||||
|
See http://pecan.readthedocs.org/en/latest/deployment.html for details.
|
||||||
|
"""
|
||||||
|
|
||||||
|
from mogan.api import app
|
||||||
|
|
||||||
|
application = app.build_wsgi_app()
|
@ -30,6 +30,8 @@ oslo.config.opts =
|
|||||||
oslo.policy.policies =
|
oslo.policy.policies =
|
||||||
mogan.api = mogan.common.policy:list_policies
|
mogan.api = mogan.common.policy:list_policies
|
||||||
|
|
||||||
|
wsgi_scripts =
|
||||||
|
mogan-api-wsgi = mogan.api.app:build_wsgi_app
|
||||||
console_scripts =
|
console_scripts =
|
||||||
mogan-api = mogan.cmd.api:main
|
mogan-api = mogan.cmd.api:main
|
||||||
mogan-dbsync = mogan.cmd.dbsync:main
|
mogan-dbsync = mogan.cmd.dbsync:main
|
||||||
|
Loading…
Reference in New Issue
Block a user