【Kubernetes | 您所在的位置:网站首页 › kubectl查看容器 › 【Kubernetes |
目录
2.5 进入容器(1)使用 bash 访问 Pod 中的容器(2)使用 tsh 访问 Pod 中的容器(3)使用 ksh 访问 Pod 中的容器(4)使用 shell 访问 Pod 中的容器(5)访问同一 Pod 中不同的容器示例① 不使用 -c② 使用 -c 指定访问容器 vmware-nginx 的 bash③ 使用 -c 指定访问容器 vmware-tmcat 的 bash
(6)容器文件的传输① 将物理机的文件复制到容器中② 将容器中的文件复制到物理机中
2.6 Pod 故障排错诊断(1)查看容器日志(2)查看同一 Pod 中不同容器的日志① 查看容器1的日志② 查看容器2的日志
(3)查看 Pod 描述信息示例
(4)查看事件(5)排错小结
关联博客
2.5 进入容器
(1)使用 bash 访问 Pod 中的容器
该命令时最常用的进入容器的命令。 kubectl exec -it vmware-nginx -n 1-pod -- bash参数说明 kubectl exec:在容器中执行命令的关键字。-i:表示将标准输入(stdin)传递给容器。-t:表示 stdin 是一个 TTY。tty是虚拟终端–:-- 后跟命令。退出 bash 时输入:exit。 查看 vmware-nginx 中容器的 /usr目录 kubectl -n 1-pod exec -it vmware-nginx -- ls /usr如果容器中没有安装tsh的话,会出现下面的报错: OCI runtime exec failed: exec failed: unable to start container process: exec: "tsh": executable file not found in $PATH: unknown command terminated with exit code 126 (3)使用 ksh 访问 Pod 中的容器 kubectl exec -it vmware-nginx -n 1-pod -- ksh如果容器中没有安装ksh的话,会出现下面的报错: OCI runtime exec failed: exec failed: unable to start container process: exec: "ksh": executable file not found in $PATH: unknown command terminated with exit code 126 (4)使用 shell 访问 Pod 中的容器 kubectl exec pod1 -it -- sh如果一个 Pod 中包含多个容器,我们需要使用 -c 参数来指定容器名。如果没有指定容器名,则默认为 Pod 中第一个容器。同时命令输出也会提示 Pod 中所有的容器名。 命令语法:kubectl exec -it pod_name -c container_name 示例环境介绍:K8S集群中的名称空间 1-pod 中有名为 vmware-nginx 和 vmware-tmcat 的两个容器。在【(3)创建包含多个容器的 Pod】小节中创建 ① 不使用 -c kubectl exec -it vmware-2c -n 1-pod -- sh有时候我们想要将物理机中的文件或目录传入容器中,或想将容器中的文件或目录传到物理机中。这是需要使用 kubectl cp 命令。 ① 将物理机的文件复制到容器中将 calico.yaml 文件传入到 Pod vmware-nginx的/tmp中。 kubectl cp calico.yaml vmware-nginx:/tmp验证 kubectl exec -it vmware-nginx -- ls /tmp将 Pod vmware-nginx的/usr/share/nginx/html/目录下的两个文件:50x.html和index.html传出到物理机的家目录下。 kubectl cp vmware-nginx:/usr/share/nginx/html/ ~在物理机家目录下列出所有文件进行验证 ls查看 Pod 中容器日志的命令是:kubectl logs 。 此命令在对工作负载和容器故障排错时非常有效。 默认命令语法:kubectl logs pod_name。 kubectl logs vmware-nginx -n 1-pod环境中存在名为 vmware-2c 的 Pod,此 Pod 中包含两个容器,分别是:vmware-nginx 和 vmware-tmcat。 ① 查看容器1的日志 kubectl logs vmware-2c -c vmware-nginx -n 1-pod使用 kubectl describe 命令。此命令会输出指定资源的详细信息。同时如果在 Pod 创建的时候也会记录报错信息。 示例 kubectl describe pod vmware-2c -n 1-podevent 事件记录中命名空间的信息,包括警告和报错信息。 使用 kubectl get events -n namespce_name 或 kubectl get ev -n namespce_name。 kubectl get events -n kube-system在对Pod或容器进行排错时,优先使用 kubectl logs 命令直接查看容器日志。如果遇到容器日志中无报错记录,或无日志情况,再使用 kubectl describe 命令查看 Pod 详细信息,然后使用 kubectl get events命令查看所在命名空间的报错记录。三者结合能快速准确的定位 Pod 或容器的故障发生点,能解决90%的问题。 关联博客关于 Pod 的创建,查询,修改,删除,访问容器以及故障排错。请跳转下面的博文: 【Kubernetes | Pod 系列】Pod 的基本管理(1)——对 Pod 的创建【Kubernetes | Pod 系列】Pod 的基本管理(2)——对 Pod 的查询【Kubernetes | Pod 系列】Pod 的基本管理(3)——对 Pod 的删除与修改【Kubernetes | Pod 系列】Pod 的基本管理(4)——访问容器与故障排错 |
CopyRight 2018-2019 实验室设备网 版权所有 |