openstack-ironic/ironic/command/singleprocess.py
Allain Legacy b8f3318ca6 Add standalone networking service for ironic
Implements the foundational infrastructure for a new standalone
networking service that can operate independently of the main ironic
conductor. This commit establishes the service skeleton with:

- RPC API layer with oslo.messaging integration for remote calls
- Public API interface for conductor/API to interact with the service
- RPC service implementation for handling network requests
- Stub networking manager with method signatures (implementation
  added in subsequent commit)
- Service entry point (ironic-networking command) for deployment
- Configuration options for service behavior and networking backend
- Infrastructure and packaging changes for the new service

The manager includes stub implementations that raise NetworkError,
with the full implementation of network operations, driver framework
and switch drivers are added in subsequence commits.

Related-Bug: 2113769
Assisted-by: Claude/sonnet-4.5
Change-Id: I351c7afe96cbcebd6b2e2bb5f0b4f17b5d804ceb
Signed-off-by: Allain Legacy <alegacy@redhat.com>
2025-11-27 11:39:59 -05:00

69 lines
2.8 KiB
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.
import sys
from oslo_config import cfg
from oslo_log import log
from ironic.command import conductor as conductor_cmd
from ironic.command import utils
from ironic.common import service as ironic_service
from ironic.conductor import rpc_service
from ironic.console import novncproxy_service
CONF = cfg.CONF
LOG = log.getLogger(__name__)
def main():
# NOTE(lucasagomes): Safeguard to prevent 'ironic.conductor.manager'
# from being imported prior to the configuration options being loaded.
# If this happened, the periodic decorators would always use the
# default values of the options instead of the configured ones. For
# more information see: https://bugs.launchpad.net/ironic/+bug/1562258
# and https://bugs.launchpad.net/ironic/+bug/1279774.
assert 'ironic.conductor.manager' not in sys.modules
assert 'ironic.networking.manager' not in sys.modules
# Parse config file and command line options, then start logging
ironic_service.prepare_service('ironic', sys.argv)
# The VNC proxy has to be run in the parent process (no_fork=True) for
# signal handling, otherwise forking is fine (no_fork=False, default).
launcher = ironic_service.process_launcher(no_fork=CONF.vnc.enabled)
mgr = rpc_service.RPCService(CONF.host,
'ironic.conductor.manager',
'ConductorManager',
embed_api=True)
conductor_cmd.issue_startup_warnings(CONF)
launcher.launch_service(mgr)
# NOTE(TheJulia): By default, vnc is disabled, and depending on that
# overall process behavior will change. i.e. we're not going to force
# single process which breaks systemd process launch detection.
# Which is because you cannot directly invoke multiple services
# with different launchers.
if CONF.vnc.enabled:
# Build and start the websocket proxy
# NOTE(TheJulia): Single-process doesn't really *need*
# the vnc proxy per stevebaker.
novncproxy = novncproxy_service.NoVNCProxyService()
launcher.launch_service(novncproxy)
# Register our signal overrides before launching the processes
utils.handle_signal()
# Start the processes!
sys.exit(launcher.wait())