Skip to content

Major bugrisk: Use arguments JSON notation for CMD and ENTRYPOINT arguments #877

@philipjonsen

Description

@philipjonsen

DESCRIPTION

When using the plain text version of passing arguments, signals from the OS are not correctly passed to the executables, which is in the majority of the cases what you would expect.

These points shall always be taken care of:

CMD should almost always be used in the form of CMD [“executable”, “param1”, “param2”…]
The shell form prevents any CMD or run command line arguments from being used, but has the disadvantage that your ENTRYPOINT will be started as a subcommand of /bin/sh -c, which does not pass signals. This means that the executable will not be the container’s PID 1 - and will not receive Unix signals - so your executable will not receive a SIGTERM from docker stop .
Read more about these best practices here.

BAD PRACTICE:

FROM debian:buster
ENTRYPOINT s3cmd
FROM debian:buster
CMD my-service server

RECOMMENDED:

FROM debian:buster
CMD ["my-service", "server"]

Note

Docker CMD does not process $ENVIRONMENT_VARIABLEs, that’s a side-effect of using sh -c as the default entry-point. Using the JSON notation means that you have to figure out how to handle environment variables yourself.
The CMD exec form is parsed as a JSON array, so you MUST use double quotes (") instead of single quote ('). See https://docs.docker.com/v17.09/engine/reference/builder/#cmd for more info.

Use arguments JSON notation for CMD and ENTRYPOINT arguments is found here: hive/blob/master/hiveproxy/Dockerfile#L19-L19

Metadata

Metadata

Assignees

No one assigned

    Labels

    No labels
    No labels

    Type

    No type

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions