Support magnum-conductor multiple process workers

Multiple process workers support for magnum-conductor.
Adds new option 'workers' to group [conductor] of magnum.conf.

Change-Id: If4d47769c97f756dbf5f45ac4413df7971731f21
Implements: blueprint magnum-multiple-process-workers
This commit is contained in:
wangbo 2016-12-26 13:50:03 +08:00 committed by Wang Bo
parent a3817530b6
commit c50d869670
4 changed files with 39 additions and 2 deletions

View File

@ -17,6 +17,7 @@
import os import os
import sys import sys
from oslo_concurrency import processutils
from oslo_log import log as logging from oslo_log import log as logging
from oslo_reports import guru_meditation_report as gmr from oslo_reports import guru_meditation_report as gmr
from oslo_service import service from oslo_service import service
@ -55,5 +56,8 @@ def main():
server = rpc_service.Service.create(CONF.conductor.topic, server = rpc_service.Service.create(CONF.conductor.topic,
conductor_id, endpoints, conductor_id, endpoints,
binary='magnum-conductor') binary='magnum-conductor')
launcher = service.launch(CONF, server) workers = CONF.conductor.workers
if not workers:
workers = processutils.get_worker_count()
launcher = service.launch(CONF, server, workers=workers)
launcher.wait() launcher.wait()

View File

@ -24,6 +24,9 @@ conductor_service_opts = [
default=4, default=4,
help=('RPC timeout for the conductor liveness check that is ' help=('RPC timeout for the conductor liveness check that is '
'used for cluster locking.')), 'used for cluster locking.')),
cfg.IntOpt('workers',
help='Number of magnum-conductor processes to fork and run. '
'Default to number of CPUs on the host.')
] ]

View File

@ -263,6 +263,14 @@ extendedKeyUsage = clientAuth
cls.cluster = cls._create_cluster(cls.__name__, cls.cluster = cls._create_cluster(cls.__name__,
cls.cluster_template.uuid) cls.cluster_template.uuid)
if not cls.cluster_template_kwargs.get('tls_disabled', False): if not cls.cluster_template_kwargs.get('tls_disabled', False):
# NOTE (wangbo) with multiple mangum-conductor processes, client
# ca files should be created after completion of cluster ca_cert
cls._wait_on_status(
cls.cluster,
[None, "CREATE_IN_PROGRESS"],
["CREATE_FAILED", "CREATE_COMPLETE"],
timeout=cls.cluster_complete_timeout
)
cls._create_tls_ca_files(cls.config_contents) cls._create_tls_ca_files(cls.config_contents)
@classmethod @classmethod

View File

@ -14,6 +14,8 @@
import mock import mock
from oslo_concurrency import processutils
from magnum.cmd import conductor from magnum.cmd import conductor
from magnum.tests import base from magnum.tests import base
@ -32,5 +34,25 @@ class TestMagnumConductor(base.TestCase):
mock_rpc.Service.create.assert_called_once_with( mock_rpc.Service.create.assert_called_once_with(
base.CONF.conductor.topic, base.CONF.conductor.topic,
mock.ANY, mock.ANY, binary='magnum-conductor') mock.ANY, mock.ANY, binary='magnum-conductor')
mock_launch.assert_called_once_with(base.CONF, server) workers = processutils.get_worker_count()
mock_launch.assert_called_once_with(base.CONF, server,
workers=workers)
launcher.wait.assert_called_once_with()
@mock.patch('oslo_service.service.launch')
@mock.patch.object(conductor, 'rpc_service')
@mock.patch('magnum.common.service.prepare_service')
def test_conductor_config_workers(self, mock_prep, mock_rpc, mock_launch):
fake_workers = 8
self.config(workers=fake_workers, group='conductor')
conductor.main()
server = mock_rpc.Service.create.return_value
launcher = mock_launch.return_value
mock_prep.assert_called_once_with(mock.ANY)
mock_rpc.Service.create.assert_called_once_with(
base.CONF.conductor.topic,
mock.ANY, mock.ANY, binary='magnum-conductor')
mock_launch.assert_called_once_with(base.CONF, server,
workers=fake_workers)
launcher.wait.assert_called_once_with() launcher.wait.assert_called_once_with()