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:
parent
7ed094696b
commit
a053176dfe
@ -52,6 +52,8 @@ _basic_keys = (
|
|||||||
'cpu_policy',
|
'cpu_policy',
|
||||||
'registry_id',
|
'registry_id',
|
||||||
'entrypoint',
|
'entrypoint',
|
||||||
|
'created_at',
|
||||||
|
'updated_at',
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
|
@ -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
|
||||||
|
Loading…
Reference in New Issue
Block a user