为容器设置启动时要执行的命令和参数

    你必须拥有一个 Kubernetes 的集群,同时你的 Kubernetes 集群必须带有 kubectl 命令行工具。 如果你还没有集群,你可以通过 构建一 个你自己的集群,或者你可以使用下面任意一个 Kubernetes 工具构建:

    要获知版本信息,请输入 .

    创建 Pod 时设置命令及参数

    创建 Pod 时,可以为其下的容器设置启动时要执行的命令及其参数。如果要设置命令,就填写在配置文件的 command 字段下,如果要设置命令的参数,就填写在配置文件的 args 字段下。一旦 Pod 创建完成,该命令及其参数就无法再进行更改了。

    如果在配置文件中设置了容器启动时要执行的命令及其参数,那么容器镜像中自带的命令与参数将会被覆盖而不再执行。如果配置文件中只是设置了参数,却没有设置其对应的命令,那么容器镜像中自带的命令会使用该新参数作为其执行时的参数。

    本示例中,将创建一个只包含单个容器的 Pod。在 Pod 配置文件中设置了一个命令与两个参数:

      1. kubectl apply -f https://k8s.io/examples/pods/commands.yaml
    1. 获取正在运行的 Pods:

      查询结果显示在 command-demo 这个 Pod 下运行的容器已经启动完成。

    2. 如果要获取容器启动时执行命令的输出结果,可以通过 Pod 的日志进行查看:

      1. kubectl logs command-demo

      日志中显示了 HOSTNAME 与 KUBERNETES_PORT 这两个环境变量的值:

    在上面的示例中,我们直接将一串字符作为命令的参数。除此之外,我们还可以将环境变量作为命令的参数。

    1. env:
    2. - name: MESSAGE
    3. command: ["/bin/echo"]
    4. args: ["$(MESSAGE)"]

    这意味着你可以将那些用来设置环境变量的方法应用于设置命令的参数,其中包括了 ConfigMaps 与 。

    说明: 环境变量需要加上括号,类似于 。这是在 commandargs 字段使用变量的格式要求。

    在 Shell 来执行命令

    下表给出了 Docker 与 Kubernetes 中对应的字段名称。

    如果要覆盖默认的 Entrypoint 与 Cmd,需要遵循如下规则:

    • 如果在容器配置中没有设置 command 或者 args,那么将使用 Docker 镜像自带的命令及其参数。

    • 如果在容器配置中只设置了 command 但是没有设置 args,那么容器启动时只会执行该命令, Docker 镜像中自带的命令及其参数会被忽略。

    • 如果在容器配置中只设置了 args,那么 Docker 镜像中自带的命令会使用该新参数作为其执行时的参数。

    • 如果在容器配置中同时设置了 commandargs,那么 Docker 镜像中自带的命令及其参数会被忽略。 容器启动时只会执行配置中设置的命令,并使用配置中设置的参数作为命令的参数。

    下面是一些例子:

    镜像 Entrypoint镜像 Cmd容器 command容器 args命令执行
    [/ep-1][foo bar]<not set><not set>[ep-1 foo bar]
    [foo bar][/ep-2]<not set>[ep-2]
    [/ep-1][foo bar]<not set>[zoo boo][ep-1 zoo boo]
    [/ep-1][foo bar][/ep-2][zoo boo][ep-2 zoo boo]

    接下来