Add support for entrypoint
This adds entrypoint parameter when creating/running container which overwrites the default ENTRYPOINT of the docker image. Change-Id: Ia397176c18be5eb6c246dd4e54ac8054ecf09031
This commit is contained in:
parent
1bf684948f
commit
c49246582a
@ -31,7 +31,7 @@ if not LOG.handlers:
|
|||||||
HEADER_NAME = "OpenStack-API-Version"
|
HEADER_NAME = "OpenStack-API-Version"
|
||||||
SERVICE_TYPE = "container"
|
SERVICE_TYPE = "container"
|
||||||
MIN_API_VERSION = '1.1'
|
MIN_API_VERSION = '1.1'
|
||||||
MAX_API_VERSION = '1.39'
|
MAX_API_VERSION = '1.40'
|
||||||
DEFAULT_API_VERSION = '1.latest'
|
DEFAULT_API_VERSION = '1.latest'
|
||||||
|
|
||||||
_SUBSTITUTIONS = {}
|
_SUBSTITUTIONS = {}
|
||||||
|
@ -18,6 +18,7 @@ import base64
|
|||||||
import binascii
|
import binascii
|
||||||
import os
|
import os
|
||||||
import re
|
import re
|
||||||
|
import shlex
|
||||||
|
|
||||||
from oslo_serialization import jsonutils
|
from oslo_serialization import jsonutils
|
||||||
from oslo_utils import netutils
|
from oslo_utils import netutils
|
||||||
@ -211,6 +212,10 @@ def parse_command(command):
|
|||||||
return " ".join(output)
|
return " ".join(output)
|
||||||
|
|
||||||
|
|
||||||
|
def parse_entrypoint(entrypoint):
|
||||||
|
return shlex.split(entrypoint)
|
||||||
|
|
||||||
|
|
||||||
def parse_mounts(mounts):
|
def parse_mounts(mounts):
|
||||||
err_msg = ("Invalid mounts argument '%s'. mounts arguments must be of "
|
err_msg = ("Invalid mounts argument '%s'. mounts arguments must be of "
|
||||||
"the form --mount source=<volume>,destination=<path>, "
|
"the form --mount source=<volume>,destination=<path>, "
|
||||||
|
@ -220,6 +220,11 @@ class CreateContainer(command.ShowOne):
|
|||||||
help='Requested host to create containers. Admin only by '
|
help='Requested host to create containers. Admin only by '
|
||||||
'default. (supported by --os-container-api-version 1.39 '
|
'default. (supported by --os-container-api-version 1.39 '
|
||||||
'or above')
|
'or above')
|
||||||
|
parser.add_argument(
|
||||||
|
'--entrypoint',
|
||||||
|
metavar='<entrypoint>',
|
||||||
|
help='The entrypoint which overwrites the default ENTRYPOINT '
|
||||||
|
'of the image.')
|
||||||
return parser
|
return parser
|
||||||
|
|
||||||
def take_action(self, parsed_args):
|
def take_action(self, parsed_args):
|
||||||
@ -238,6 +243,7 @@ class CreateContainer(command.ShowOne):
|
|||||||
opts['command'] = parsed_args.command
|
opts['command'] = parsed_args.command
|
||||||
opts['registry'] = parsed_args.registry
|
opts['registry'] = parsed_args.registry
|
||||||
opts['host'] = parsed_args.host
|
opts['host'] = parsed_args.host
|
||||||
|
opts['entrypoint'] = zun_utils.parse_entrypoint(parsed_args.entrypoint)
|
||||||
if parsed_args.security_group:
|
if parsed_args.security_group:
|
||||||
opts['security_groups'] = parsed_args.security_group
|
opts['security_groups'] = parsed_args.security_group
|
||||||
if parsed_args.expose_port:
|
if parsed_args.expose_port:
|
||||||
@ -917,6 +923,11 @@ class RunContainer(command.ShowOne):
|
|||||||
help='Requested host to run containers. Admin only by '
|
help='Requested host to run containers. Admin only by '
|
||||||
'default. (supported by --os-container-api-version 1.39 '
|
'default. (supported by --os-container-api-version 1.39 '
|
||||||
'or above')
|
'or above')
|
||||||
|
parser.add_argument(
|
||||||
|
'--entrypoint',
|
||||||
|
metavar='<entrypoint>',
|
||||||
|
help='The entrypoint which overwrites the default ENTRYPOINT '
|
||||||
|
'of the image.')
|
||||||
return parser
|
return parser
|
||||||
|
|
||||||
def take_action(self, parsed_args):
|
def take_action(self, parsed_args):
|
||||||
@ -935,6 +946,7 @@ class RunContainer(command.ShowOne):
|
|||||||
opts['command'] = parsed_args.command
|
opts['command'] = parsed_args.command
|
||||||
opts['registry'] = parsed_args.registry
|
opts['registry'] = parsed_args.registry
|
||||||
opts['host'] = parsed_args.host
|
opts['host'] = parsed_args.host
|
||||||
|
opts['entrypoint'] = zun_utils.parse_entrypoint(parsed_args.entrypoint)
|
||||||
if parsed_args.security_group:
|
if parsed_args.security_group:
|
||||||
opts['security_groups'] = parsed_args.security_group
|
opts['security_groups'] = parsed_args.security_group
|
||||||
if parsed_args.expose_port:
|
if parsed_args.expose_port:
|
||||||
|
@ -28,6 +28,7 @@ def _get_container_args(**kwargs):
|
|||||||
'mounts': [],
|
'mounts': [],
|
||||||
'nets': [],
|
'nets': [],
|
||||||
'command': [],
|
'command': [],
|
||||||
|
'entrypoint': [],
|
||||||
}
|
}
|
||||||
default_args.update(kwargs)
|
default_args.update(kwargs)
|
||||||
return default_args
|
return default_args
|
||||||
|
@ -27,7 +27,7 @@ CREATION_ATTRIBUTES = ['name', 'image', 'command', 'cpu', 'memory',
|
|||||||
'runtime', 'hostname', 'mounts', 'disk',
|
'runtime', 'hostname', 'mounts', 'disk',
|
||||||
'availability_zone', 'auto_heal', 'privileged',
|
'availability_zone', 'auto_heal', 'privileged',
|
||||||
'exposed_ports', 'healthcheck', 'registry', 'tty',
|
'exposed_ports', 'healthcheck', 'registry', 'tty',
|
||||||
'host']
|
'host', 'entrypoint']
|
||||||
|
|
||||||
|
|
||||||
class Container(base.Resource):
|
class Container(base.Resource):
|
||||||
|
@ -188,6 +188,10 @@ def _show_container(container):
|
|||||||
metavar='<host>',
|
metavar='<host>',
|
||||||
help='Requested host to create containers. Admin only by default.'
|
help='Requested host to create containers. Admin only by default.'
|
||||||
'(Supported by API versions 1.39 or above)')
|
'(Supported by API versions 1.39 or above)')
|
||||||
|
@utils.arg('--entrypoint',
|
||||||
|
metavar='<entrypoint>',
|
||||||
|
help='The entrypoint which overwrites the default ENTRYPOINT '
|
||||||
|
'of the image. (Supported by API versions 1.40 or above)')
|
||||||
def do_create(cs, args):
|
def do_create(cs, args):
|
||||||
"""Create a container."""
|
"""Create a container."""
|
||||||
opts = {}
|
opts = {}
|
||||||
@ -211,6 +215,7 @@ def do_create(cs, args):
|
|||||||
opts['command'] = args.command
|
opts['command'] = args.command
|
||||||
opts['registry'] = args.registry
|
opts['registry'] = args.registry
|
||||||
opts['host'] = args.host
|
opts['host'] = args.host
|
||||||
|
opts['entrypoint'] = zun_utils.parse_entrypoint(args.entrypoint)
|
||||||
if args.healthcheck:
|
if args.healthcheck:
|
||||||
opts['healthcheck'] = zun_utils.parse_health(args.healthcheck)
|
opts['healthcheck'] = zun_utils.parse_health(args.healthcheck)
|
||||||
|
|
||||||
@ -717,6 +722,10 @@ def do_kill(cs, args):
|
|||||||
metavar='<host>',
|
metavar='<host>',
|
||||||
help='Requested host to run containers. Admin only by default.'
|
help='Requested host to run containers. Admin only by default.'
|
||||||
'(Supported by API versions 1.39 or above)')
|
'(Supported by API versions 1.39 or above)')
|
||||||
|
@utils.arg('--entrypoint',
|
||||||
|
metavar='<entrypoint>',
|
||||||
|
help='The entrypoint which overwrites the default ENTRYPOINT '
|
||||||
|
'of the image. (Supported by API versions 1.40 or above)')
|
||||||
def do_run(cs, args):
|
def do_run(cs, args):
|
||||||
"""Run a command in a new container."""
|
"""Run a command in a new container."""
|
||||||
opts = {}
|
opts = {}
|
||||||
@ -740,6 +749,7 @@ def do_run(cs, args):
|
|||||||
opts['command'] = args.command
|
opts['command'] = args.command
|
||||||
opts['registry'] = args.registry
|
opts['registry'] = args.registry
|
||||||
opts['host'] = args.host
|
opts['host'] = args.host
|
||||||
|
opts['entrypoint'] = zun_utils.parse_entrypoint(args.entrypoint)
|
||||||
if args.healthcheck:
|
if args.healthcheck:
|
||||||
opts['healthcheck'] = zun_utils.parse_health(args.healthcheck)
|
opts['healthcheck'] = zun_utils.parse_health(args.healthcheck)
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user