Merge "restart the containers after the host reboot"

This commit is contained in:
Zuul 2018-01-31 07:11:59 +00:00 committed by Gerrit Code Review
commit 5a776a2a33
3 changed files with 43 additions and 1 deletions

View File

@ -49,10 +49,29 @@ class Manager(periodic_task.PeriodicTasks):
else: else:
self.use_sandbox = False self.use_sandbox = False
def restore_running_container(self, context, container, db_container):
if (container.status == consts.RUNNING and
db_container.status == consts.STOPPED):
try:
self.container_reboot(context, container, 10)
except Exception:
LOG.exception("Failed to complete a restart for container %s",
container.uuid)
def init_containers(self, context): def init_containers(self, context):
containers = objects.Container.list_by_host(context, self.host) containers = objects.Container.list_by_host(context, self.host)
db_containers = self.driver.list(context)
db_container_map = {container.container_id: container
for container in db_containers
if container.container_id is not None}
for container in containers: for container in containers:
self._init_container(context, container) self._init_container(context, container)
if CONF.compute.resume_container_state and \
container.container_id is not None:
db_container = db_container_map[container.container_id]
self.restore_running_container(context,
container,
db_container)
def _init_container(self, context, container): def _init_container(self, context, container):
'''Initialize this container during zun-compute init.''' '''Initialize this container during zun-compute init.'''

View File

@ -15,6 +15,14 @@
from oslo_config import cfg from oslo_config import cfg
compute_opts = [
cfg.BoolOpt(
'resume_container_state',
default=True,
help='restart the containers which are running'
'before the host reboots.'),
]
service_opts = [ service_opts = [
cfg.StrOpt( cfg.StrOpt(
'topic', 'topic',
@ -47,7 +55,7 @@ Possible values:
opt_group = cfg.OptGroup( opt_group = cfg.OptGroup(
name='compute', title='Options for the zun-compute service') name='compute', title='Options for the zun-compute service')
ALL_OPTS = (service_opts + db_opts) ALL_OPTS = (service_opts + db_opts + compute_opts)
def register_opts(conf): def register_opts(conf):

View File

@ -110,6 +110,21 @@ class TestManager(base.TestCase):
mock_container_start.assert_called_once_with(self.context, mock_container_start.assert_called_once_with(self.context,
container) container)
@mock.patch.object(manager.Manager, 'container_reboot')
@mock.patch.object(Container, 'save')
def test_container_reboot_after_host_reboot(self, mock_save,
mock_container_reboot):
container_1 = Container(self.context, **utils.get_test_container())
container_2 = Container(self.context, **utils.get_test_container())
container_1.status = consts.RUNNING
container_2.status = consts.STOPPED
self.compute_manager.restore_running_container(self.context,
container_1,
container_2)
mock_container_reboot.assert_called_once_with(self.context,
container_1,
10)
@mock.patch.object(Container, 'save') @mock.patch.object(Container, 'save')
def test_init_container_retries_start_already(self, mock_save): def test_init_container_retries_start_already(self, mock_save):
container = Container(self.context, **utils.get_test_container()) container = Container(self.context, **utils.get_test_container())