获取正在运行容器的 Shell

    你必须拥有一个 Kubernetes 的集群,同时你的 Kubernetes 集群必须带有 kubectl 命令行工具。 建议在至少有两个节点的集群上运行本教程,且这些节点不作为控制平面主机。 如果你还没有集群,你可以通过 构建一个你自己的集群,或者你可以使用下面任意一个 Kubernetes 工具构建:

    获取容器的 Shell

    在本练习中,你将创建包含一个容器的 Pod。容器运行 nginx 镜像。下面是 Pod 的配置文件:

    创建 Pod:

    1. kubectl apply -f https://k8s.io/examples/application/shell-demo.yaml

    检查容器是否运行正常:

    1. kubectl get pod shell-demo

    获取正在运行容器的 Shell:

    1. kubectl exec --stdin --tty shell-demo -- /bin/bash

    双破折号 “—“ 用于将要传递给命令的参数与 kubectl 的参数分开。

    在 shell 中,打印根目录:

    在 shell 中,实验其他命令。下面是一些示例:

    1. ls /
    2. cat /proc/mounts
    3. cat /proc/1/maps
    4. apt-get update
    5. apt-get install -y tcpdump
    6. tcpdump
    7. apt-get install -y lsof
    8. lsof
    9. ps aux
    10. ps aux | grep nginx

    再看一下 Pod 的配置文件。该 Pod 有个 emptyDir 卷,容器将该卷挂载到了 /usr/share/nginx/html

    在 shell 中,在 /usr/share/nginx/html 目录创建一个 index.html 文件:

    1. echo 'Hello shell demo' > /usr/share/nginx/html/index.html

    在 shell 中,向 nginx 服务器发送 GET 请求:

    1. # 在容器内运行如下命令
    2. apt-get update
    3. apt-get install curl
    4. curl http://localhost/

    当用完 shell 后,输入 exit 退出。

    1. exit # 快速退出容器内的 Shell

    在容器中运行单个命令

    在普通的命令窗口(而不是 shell)中,打印环境运行容器中的变量:

    1. kubectl exec shell-demo env

    实验运行其他命令。下面是一些示例:

    1. kubectl exec shell-demo -- ps aux
    2. kubectl exec shell-demo -- ls /
    3. kubectl exec shell-demo -- cat /proc/1/mounts

    如果 Pod 有多个容器,--container 或者 -c 可以在 kubectl exec 命令中指定容器。 例如,你有个名为 my-pod 的 Pod,该 Pod 有两个容器分别为 main-apphealper-app。 下面的命令将会打开一个 shell 访问 main-app 容器。

    说明:

    短的命令参数 -i-t 与长的命令参数 --stdin 和 作用相同。

    接下来