前言
Podcommand
启动命令
在前面的案例中, 一直有一个问题没解决,就是busybox容器一直没有成功运行,那么到底是什么原因导致这个容器故障呢?
原来busybox并不是一个程序,而是类似于一个工具类的集合,kubernetes集群启动管理后,它会自动关闭。解决的办法就是让它一直运行,这就需要使用到command配置。
创建pod-command.yaml文件,内容如下
apiVersion: v1
kind: Pod
metadata:
name: pod-command
namespace: dev
spec:
containers:
- name: nginx
image: nginx:1.17.1
- name: busybox
image: busybox:1.30
command: ["/bin/sh","-c","touch /tmp/hello.txt;while true;do /bin/echo $(date +%T) >> /tmp/hello.txt; sleep 3; done;"]
command,用于在pod中的容器初始化完毕之后运行一个命令。
解释
“/bin/sh”,“-c” 使用sh执行命令
touch /tmp/hello.txt 创建一个hello.txt
while true;do /bin/echo $(date +%T) >> /tmp/hello.txt; sleep 3; done; 每间隔3秒向文件中写入当前时间
#进入到容器中
kubectl exec pod-command -n dev -it -c busybox /bin/sh
#动态查看hello.txt
tail -f /tmp/hello.txt
补充说明
通过上面发现command 已经可以完成启动命令和传递参数的功能,为什么还要提供一个args选项,用于传递参数?
这其实和docker有关系,kubernetes中的command,args两项其实是为了覆盖Dockerfile中ENTRYPOINT的功能
1如果command和args均没有写,那么用Dockerfile的配置
2如果command写了,但args没有写,那么Dockerfile默认的配置会被忽略,执行输入的command
3如果command没写,但args写了,那么Dockerfile中配置的ENTRYPOINT的命令会被执行,使用当前args的参数
4如果command和args都写了,那么Dockerfile的配置被忽略,执行command并追加上args参数