Revert "Cleanup code duplication in cinder.cmd.backup module"
This reverts commit f6c60d1d9c79a8048df7cc63fddb2b081eac430f. The original patch referred as duplicated code the part where the service uses a single process when there is no additional processes requested (backup_workers == 1), which is the default. That code made the cinder-backup service always run as a child process even when there was only going to be 1 process. This adds 30MB of extra RAM consumption by the service, which amounts to a 30% unnecessary memory increase when not doing operations after applying changes from Ic9030d01468b3189350f83b04a8d1d346c489d3c. Change-Id: I43a20c8687f12bc52b014611cc6977c4c3ca212c
This commit is contained in:
parent
3dfc519301
commit
5c7fd3a70b
@ -82,7 +82,7 @@ def _launch_backup_process(launcher, num_process, _semaphore):
|
||||
server = service.Service.create(binary='cinder-backup',
|
||||
coordination=True,
|
||||
service_name='backup',
|
||||
process_number=num_process,
|
||||
process_number=num_process + 1,
|
||||
semaphore=_semaphore)
|
||||
except Exception:
|
||||
LOG.exception('Backup service %s failed to start.', CONF.host)
|
||||
@ -113,10 +113,20 @@ def main():
|
||||
semaphore = utils.semaphore_factory(CONF.backup_max_operations,
|
||||
CONF.backup_workers)
|
||||
|
||||
LOG.info('Backup running with %s processes.', CONF.backup_workers)
|
||||
launcher = service.get_launcher()
|
||||
if CONF.backup_workers > 1:
|
||||
LOG.info('Backup running with %s processes.', CONF.backup_workers)
|
||||
launcher = service.get_launcher()
|
||||
|
||||
for i in range(1, CONF.backup_workers + 1):
|
||||
_launch_backup_process(launcher, i, semaphore)
|
||||
for i in range(CONF.backup_workers):
|
||||
_launch_backup_process(launcher, i, semaphore)
|
||||
|
||||
launcher.wait()
|
||||
launcher.wait()
|
||||
else:
|
||||
LOG.info('Backup running in single process mode.')
|
||||
server = service.Service.create(binary='cinder-backup',
|
||||
coordination=True,
|
||||
service_name='backup',
|
||||
process_number=1,
|
||||
semaphore=semaphore)
|
||||
service.serve(server)
|
||||
service.wait()
|
||||
|
@ -97,6 +97,30 @@ class TestCinderBackupCmd(test.TestCase):
|
||||
super(TestCinderBackupCmd, self).setUp()
|
||||
sys.argv = ['cinder-backup']
|
||||
|
||||
@mock.patch('cinder.utils.semaphore_factory')
|
||||
@mock.patch('cinder.cmd.backup._launch_backup_process')
|
||||
@mock.patch('cinder.service.wait')
|
||||
@mock.patch('cinder.service.serve')
|
||||
@mock.patch('cinder.service.Service.create')
|
||||
@mock.patch('cinder.utils.monkey_patch')
|
||||
@mock.patch('oslo_log.log.setup')
|
||||
def test_main(self, log_setup, monkey_patch, service_create, service_serve,
|
||||
service_wait, launch_mock, mock_semaphore):
|
||||
server = service_create.return_value
|
||||
|
||||
cinder_backup.main()
|
||||
|
||||
self.assertEqual('cinder', CONF.project)
|
||||
self.assertEqual(CONF.version, version.version_string())
|
||||
log_setup.assert_called_once_with(CONF, "cinder")
|
||||
monkey_patch.assert_called_once_with()
|
||||
service_create.assert_called_once_with(
|
||||
binary='cinder-backup', coordination=True, service_name='backup',
|
||||
process_number=1, semaphore=mock_semaphore.return_value)
|
||||
service_serve.assert_called_once_with(server)
|
||||
service_wait.assert_called_once_with()
|
||||
launch_mock.assert_not_called()
|
||||
|
||||
@mock.patch('cinder.utils.Semaphore')
|
||||
@mock.patch('cinder.service.get_launcher')
|
||||
@mock.patch('cinder.service.Service.create')
|
||||
|
Loading…
x
Reference in New Issue
Block a user