fix container run defect

Some problems were found in the development of enterprise projects:

1.After repairing the container operation, the return parameter does not include the time parameter. It is necessary to judge whether to restart and obtain the running time in the business development. Compared with nova, the return info of the VM also contains the above information.

2.When creating a container, if a custom security group created with neutron is also associated, the expose_ports parameter is also given, which will cause the custom security group parameters to be overwritten, which is very important for the container to increase the exposure range of ports. Important, but it is currently a failure.

Change-Id: I1f5c2ddc835d91c14ae8936c0fb7f79d418ba804
This commit is contained in:
ycj 2021-10-26 15:03:57 +08:00 committed by yangchangjia
parent 7ed094696b
commit a053176dfe
2 changed files with 12 additions and 9 deletions

View File

@ -52,6 +52,8 @@ _basic_keys = (
'cpu_policy', 'cpu_policy',
'registry_id', 'registry_id',
'entrypoint', 'entrypoint',
'created_at',
'updated_at',
) )

View File

@ -39,7 +39,6 @@ from zun.image import driver as img_driver
from zun.network import network as zun_network from zun.network import network as zun_network
from zun import objects from zun import objects
CONF = zun.conf.CONF CONF = zun.conf.CONF
LOG = logging.getLogger(__name__) LOG = logging.getLogger(__name__)
ATTACH_FLAG = "/attach/ws?logs=0&stream=1&stdin=1&stdout=1&stderr=1" ATTACH_FLAG = "/attach/ws?logs=0&stream=1&stdin=1&stdout=1&stderr=1"
@ -86,7 +85,6 @@ def handle_not_found(e, context, container, do_not_raise=False):
def wrap_docker_error(function): def wrap_docker_error(function):
@functools.wraps(function) @functools.wraps(function)
def decorated_function(*args, **kwargs): def decorated_function(*args, **kwargs):
context = args[1] context = args[1]
@ -382,7 +380,10 @@ class DockerDriver(driver.BaseDriver, driver.ContainerDriver,
secgroup_id = neutron_api.create_security_group({'security_group': { secgroup_id = neutron_api.create_security_group({'security_group': {
"name": secgroup_name}})['security_group']['id'] "name": secgroup_name}})['security_group']['id']
neutron_api.expose_ports(secgroup_id, exposed_ports) neutron_api.expose_ports(secgroup_id, exposed_ports)
container.security_groups = [secgroup_id] if container.security_groups:
container.security_groups.append(secgroup_id)
else:
container.security_groups = [secgroup_id]
# process kwargs on creating the docker container # process kwargs on creating the docker container
ports = [] ports = []
for port in exposed_ports: for port in exposed_ports:
@ -667,8 +668,8 @@ class DockerDriver(driver.BaseDriver, driver.ContainerDriver,
container.status = status container.status = status
status_detail = self.format_status_detail( status_detail = self.format_status_detail(
state.get('FinishedAt')) state.get('FinishedAt'))
container.status_detail = "Exited({}) {} ago " \ container.status_detail = "Exited({}) {} ago (error)".format(
"(error)".format(state.get('ExitCode'), status_detail) state.get('ExitCode'), status_detail)
elif state.get('Paused'): elif state.get('Paused'):
container.status = consts.PAUSED container.status = consts.PAUSED
status_detail = self.format_status_detail( status_detail = self.format_status_detail(
@ -695,8 +696,8 @@ class DockerDriver(driver.BaseDriver, driver.ContainerDriver,
container.status = consts.CREATED container.status = consts.CREATED
container.status_detail = "Created" container.status_detail = "Created"
elif (started_at == "" and elif (started_at == "" and
container.status in (consts.CREATED, consts.RESTARTING, container.status in (consts.CREATED, consts.RESTARTING,
consts.ERROR, consts.REBUILDING)): consts.ERROR, consts.REBUILDING)):
pass pass
elif started_at != "" and finished_at == "": elif started_at != "" and finished_at == "":
LOG.warning('Receive unexpected state from docker: %s', LOG.warning('Receive unexpected state from docker: %s',
@ -715,8 +716,8 @@ class DockerDriver(driver.BaseDriver, driver.ContainerDriver,
if state == 'created' and container.status == consts.CREATING: if state == 'created' and container.status == consts.CREATING:
container.status = consts.CREATED container.status = consts.CREATED
elif (state == 'created' and elif (state == 'created' and
container.status in (consts.CREATED, consts.RESTARTING, container.status in (consts.CREATED, consts.RESTARTING,
consts.ERROR, consts.REBUILDING)): consts.ERROR, consts.REBUILDING)):
pass pass
elif state == 'paused': elif state == 'paused':
container.status = consts.PAUSED container.status = consts.PAUSED