Source code for ironic.command.networking
#
# 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.
"""
The Ironic Networking Service
"""
import sys
from oslo_config import cfg
from oslo_log import log
from oslo_service import service
from ironic.command import utils as command_utils
from ironic.common import service as ironic_service
from ironic.networking import rpc_service
CONF = cfg.CONF
LOG = log.getLogger(__name__)
[docs]
def issue_startup_warnings(conf):
"""Issue any startup warnings for the networking service."""
# Add any networking-specific startup warnings here
LOG.info("Starting Ironic Networking Service")
[docs]
def main():
# NOTE(alegacy): Safeguard to prevent 'ironic.networking.manager'
# from being imported prior to the configuration options being loaded.
assert 'ironic.networking.manager' not in sys.modules
# Parse config file and command line options, then start logging
ironic_service.prepare_service('ironic_networking', sys.argv)
ironic_service.ensure_rpc_transport(CONF)
mgr = rpc_service.NetworkingRPCService(CONF.host,
'ironic.networking.manager',
'NetworkingManager')
issue_startup_warnings(CONF)
launcher = service.launch(CONF, mgr, restart_method='mutate')
# Set override signals.
command_utils.handle_signal()
# Start the processes!
sys.exit(launcher.wait())
if __name__ == '__main__':
sys.exit(main())