Enable WSGI module entrypoint for Ironic
This adds a wsgi entrypoint module which can be used with a wsgi runner, such as uwsgi, to launch Ironic API processes without the need of a separate script. The legacy WSGI script is currently being installed by PBR, and as part of the migration to a pyproject.yaml-compatible PBR, we cannot use the wsgi-scripts plugin anymore, and will be removing the script installed by it in a future Ironic release. The new WSGI script, because it has statements at the module top-level, cannot be autodocumented; we now exclude it. Also we don't treat all warnings as errors in pdf docs builds to allow the use of mock autosummary, starting with including the wsgi module. Co-Authored-By: Doug Goldstein <cardoe@cardoe.com> Change-Id: I584ac6a25c4e6cd9744a609b50d12b434a930dc6
This commit is contained in:
parent
1f740c8a90
commit
3db454f0ea
@ -411,7 +411,7 @@ fi
|
|||||||
# Support entry points installation of console scripts
|
# Support entry points installation of console scripts
|
||||||
IRONIC_BIN_DIR=$(get_python_exec_prefix)
|
IRONIC_BIN_DIR=$(get_python_exec_prefix)
|
||||||
IRONIC_UWSGI_CONF=$IRONIC_CONF_DIR/ironic-uwsgi.ini
|
IRONIC_UWSGI_CONF=$IRONIC_CONF_DIR/ironic-uwsgi.ini
|
||||||
IRONIC_UWSGI=$IRONIC_BIN_DIR/ironic-api-wsgi
|
IRONIC_UWSGI=${IRONIC_UWSGI:-ironic.wsgi:application}
|
||||||
|
|
||||||
# Lets support IPv6 testing!
|
# Lets support IPv6 testing!
|
||||||
IRONIC_IP_VERSION=${IRONIC_IP_VERSION:-${IP_VERSION:-4}}
|
IRONIC_IP_VERSION=${IRONIC_IP_VERSION:-${IP_VERSION:-4}}
|
||||||
@ -1663,7 +1663,7 @@ function configure_ironic {
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
# Adds uWSGI for Ironic API
|
# Adds uWSGI for Ironic API
|
||||||
write_uwsgi_config "$IRONIC_UWSGI_CONF" "$IRONIC_UWSGI" "/baremetal"
|
write_uwsgi_config "$IRONIC_UWSGI_CONF" "$IRONIC_UWSGI" "/baremetal" "" "ironic-api"
|
||||||
|
|
||||||
if [[ "$os_VENDOR" =~ (Debian|Ubuntu) ]]; then
|
if [[ "$os_VENDOR" =~ (Debian|Ubuntu) ]]; then
|
||||||
# The groups change with newer libvirt. Older Ubuntu used
|
# The groups change with newer libvirt. Older Ubuntu used
|
||||||
|
@ -32,7 +32,9 @@ sys.path.insert(0, os.path.join(os.path.abspath('.'), '_exts'))
|
|||||||
|
|
||||||
# Add any Sphinx extension module names here, as strings. They can be
|
# Add any Sphinx extension module names here, as strings. They can be
|
||||||
# extensions coming with Sphinx (named 'sphinx.ext.*') or your custom ones.
|
# extensions coming with Sphinx (named 'sphinx.ext.*') or your custom ones.
|
||||||
extensions = ['sphinx.ext.viewcode',
|
extensions = ['sphinx.ext.autodoc',
|
||||||
|
'sphinx.ext.autosummary',
|
||||||
|
'sphinx.ext.viewcode',
|
||||||
'sphinx.ext.graphviz',
|
'sphinx.ext.graphviz',
|
||||||
'sphinxcontrib.apidoc',
|
'sphinxcontrib.apidoc',
|
||||||
'sphinxcontrib.rsvgconverter',
|
'sphinxcontrib.rsvgconverter',
|
||||||
@ -62,6 +64,10 @@ autodoc_default_options = {
|
|||||||
'special-members': '__call__',
|
'special-members': '__call__',
|
||||||
}
|
}
|
||||||
|
|
||||||
|
autosummary_mock_imports = [
|
||||||
|
'ironic.wsgi',
|
||||||
|
]
|
||||||
|
|
||||||
redfish_interop_source = \
|
redfish_interop_source = \
|
||||||
'../../redfish-interop-profiles/OpenStackIronicProfile.v1_1_0.json'
|
'../../redfish-interop-profiles/OpenStackIronicProfile.v1_1_0.json'
|
||||||
redfish_interop_output_dir = 'admin/drivers/redfish/'
|
redfish_interop_output_dir = 'admin/drivers/redfish/'
|
||||||
|
23
ironic/wsgi/__init__.py
Normal file
23
ironic/wsgi/__init__.py
Normal file
@ -0,0 +1,23 @@
|
|||||||
|
# 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.
|
||||||
|
|
||||||
|
"""WSGI application entry-point for Ironic API."""
|
||||||
|
|
||||||
|
import threading
|
||||||
|
|
||||||
|
from ironic.api import wsgi
|
||||||
|
|
||||||
|
application = None
|
||||||
|
lock = threading.Lock()
|
||||||
|
with lock:
|
||||||
|
if application is None:
|
||||||
|
application = wsgi.initialize_wsgi_app()
|
@ -0,0 +1,18 @@
|
|||||||
|
features:
|
||||||
|
- |
|
||||||
|
A new module, ``ironic.wsgi`` has been enabled as an entrypoint for WSGI
|
||||||
|
runners. For example, if using uWSGI then now instead of:
|
||||||
|
|
||||||
|
.. code-block:: ini
|
||||||
|
|
||||||
|
[uwsgi]
|
||||||
|
wsgi-file = /bin/ironic-api-wsgi
|
||||||
|
|
||||||
|
You can now use:
|
||||||
|
|
||||||
|
.. code-block:: ini
|
||||||
|
|
||||||
|
[uwsgi]
|
||||||
|
module = ironic.wsgi:application
|
||||||
|
|
||||||
|
Legacy installed wsgi scripts will be removed in a future version of Ironic.
|
2
tox.ini
2
tox.ini
@ -100,7 +100,7 @@ commands = sphinx-build -b html doc/source doc/build/html
|
|||||||
allowlist_externals = make
|
allowlist_externals = make
|
||||||
deps = {[testenv:docs]deps}
|
deps = {[testenv:docs]deps}
|
||||||
commands =
|
commands =
|
||||||
sphinx-build -W -b latex doc/source doc/build/pdf
|
sphinx-build -b latex doc/source doc/build/pdf
|
||||||
make -C doc/build/pdf
|
make -C doc/build/pdf
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user