此页展示了如何给运行在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"]