Kubernetes 配置Pod和容器(二)定义容器命令行和参数

此页展示了如何给运行在Kubernetes Pod中的容器定义命令行和参数。

开始之前

必须有一个Kubernets集群,和一个能和集群沟通的kubectl命令行工具。如果你还没有集群,你可以用Minikube建立一个集群。

新建Pod的时候定义命令行和参数

创建Pod的时候,可以为运行在里面的容器定义一个命令行和参数。定义一个命令行,在配置文件中包含command字段。给这个命令行定义参数包含一个args字段在配置文件中。当Pod创建之后该命令行和参数是不可以修改的。

如果在配置文件中定义了命令行和参数,将覆盖容器镜像提供的默认参数。如果定义了参数但是没有定义命令行,那么参数将和默认的命令行一起使用。更多详细信息可以参考Commands and Capabilities。

在本次练习中,创建一个运行一个容器的Pod。下面Pod的配置文件定义了一个命令行和两个参数。

apiVersion: v1
kind: Pod
metadata:
  name: command-demo
  labels:
    purpose: demonstrate-command
spec:
  containers:
  - name: command-demo-container
    image: debian
    command: ["printenv"]
    args: ["HOSTNAME", "KUBERNETES_PORT"]

1.创建Pod基于YAML配置文件:

kubectl create -f http://k8s.io/docs/tasks/configure-pod-container/commands.yaml

2.获取运行中的Pod列表:

kubectl get pods

输出显示在command-demo Pod中运行的容器已完成。

3.查看命令行在容器里面的输出,可以查看Pod的日志:

kubectl logs command-demo

输出展示了HOSTNAME,KUBERNETES_ROOT的环境变量的值:

 command-demo
 tcp://10.3.240.1:443

使用环境变量定义命令行参数

在前面的例子中,直接通过字符串定义了命令行参数。作为直接用字符串替代方法,你可以用环境变量定义参数:

env:
- name: MESSAGE
  value: "hello world"
command: ["/bin/echo"]
args: ["$(MESSAGE)"]

这意味着你可以使用可用于定义环境变量的任何技术来定义Pod的参数,包括ConfigMaps 和 Secrets。

注意:环境变量呈现在括号中,"$(VAR)"。这是在command或args字段中扩展变量所必须的。

在shell中运行命令行

在一些情况,你需要在shell中运行你的命令。例如:你的命令可能是由多个命令组合在一起,或者是一个shell脚本。要在shell中运行你的命令,可以这样包装它:

command: ["/bin/sh"]
args: ["-c", "while true; do echo hello; sleep 10;done"]

你可能感兴趣的:(Kubernetes 配置Pod和容器(二)定义容器命令行和参数)