Source code for ironic.common.service
# -*- encoding: utf-8 -*-
#
# Copyright © 2012 eNovance <licensing@enovance.com>
#
# 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.
from oslo_log import log
try:
from oslo_reports import guru_meditation_report as gmr
from oslo_reports import opts as gmr_opts
except ImportError:
gmr = None
from oslo_service import service
from ironic.common import config
from ironic.common import profiler
from ironic.conf import CONF
from ironic.conf import opts
from ironic import objects
from ironic import version
LOG = log.getLogger(__name__)
[docs]
def prepare_command(argv=None):
"""Prepare any Ironic command for execution.
Sets up configuration and logging, registers objects.
"""
argv = [] if argv is None else argv
log.register_options(CONF)
opts.update_opt_defaults()
config.parse_args(argv)
# NOTE(vdrok): We need to setup logging after argv was parsed, otherwise
# it does not properly parse the options from config file and uses defaults
# from oslo_log
log.setup(CONF, 'ironic')
objects.register_all()
[docs]
def prepare_service(name, argv=None, conf=CONF):
"""Prepare an Ironic service executable.
In addition to what `prepare_command` does, set up guru meditation
reporting and profiling.
"""
prepare_command(argv)
if gmr is not None:
gmr_opts.set_defaults(CONF)
gmr.TextGuruMeditation.setup_autorun(version, conf=CONF)
else:
LOG.debug('Guru meditation reporting is disabled '
'because oslo.reports is not installed')
profiler.setup(name, CONF.host)
[docs]
def process_launcher():
return service.ProcessLauncher(CONF, restart_method='mutate')
[docs]
def ensure_rpc_transport(conf=CONF):
# Only the combined ironic executable can use rpc_transport = none
if conf.rpc_transport == 'none':
raise RuntimeError("This service is not designed to work with "
"rpc_transport = none. Please use the combined "
"ironic executable or another RPC transport.")