【Kubernetes | Pod 系列】Pod 的基本管理(4)——访问容器与故障排错

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

在这里插入图片描述

(2)使用 tsh 访问 Pod 中的容器

kubectl exec -it pod1 -- tsh

如果容器中没有安装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

在这里插入图片描述

(5)访问同一 Pod 中不同的容器

如果一个 Pod 中包含多个容器,我们需要使用 -c 参数来指定容器名。如果没有指定容器名,则默认为 Pod 中第一个容器。同时命令输出也会提示 Pod 中所有的容器名。

命令语法:kubectl exec -it pod_name -c container_name

示例

环境介绍:K8S集群中的名称空间 1-pod 中有名为 vmware-nginxvmware-tmcat 的两个容器。在【(3)创建包含多个容器的 Pod】小节中创建

① 不使用 -c
kubectl exec -it vmware-2c -n 1-pod -- sh

在这里插入图片描述

② 使用 -c 指定访问容器 vmware-nginx 的 bash
kubectl exec -it vmware-2c -c vmware-nginx -n 1-pod -- bash

在这里插入图片描述

③ 使用 -c 指定访问容器 vmware-tmcat 的 bash
kubectl exec -it vmware-2c -c vmware-tmcat -n 1-pod -- bash

在这里插入图片描述

(6)容器文件的传输

有时候我们想要将物理机中的文件或目录传入容器中,或想将容器中的文件或目录传到物理机中。这是需要使用 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.htmlindex.html传出到物理机的家目录下。

kubectl cp vmware-nginx:/usr/share/nginx/html/ ~

在物理机家目录下列出所有文件进行验证

ls

在这里插入图片描述

2.6 Pod 故障排错诊断

(1)查看容器日志

查看 Pod 中容器日志的命令是:kubectl logs

此命令在对工作负载和容器故障排错时非常有效。

默认命令语法:kubectl logs pod_name

kubectl logs vmware-nginx -n 1-pod

在这里插入图片描述

(2)查看同一 Pod 中不同容器的日志

环境中存在名为 vmware-2c 的 Pod,此 Pod 中包含两个容器,分别是:vmware-nginxvmware-tmcat

① 查看容器1的日志
kubectl logs vmware-2c -c vmware-nginx -n 1-pod

在这里插入图片描述

② 查看容器2的日志
kubectl logs vmware-2c -c vmware-tmcat -n 1-pod

在这里插入图片描述

(3)查看 Pod 描述信息

使用 kubectl describe 命令。此命令会输出指定资源的详细信息。同时如果在 Pod 创建的时候也会记录报错信息。

示例
kubectl describe pod vmware-2c -n 1-pod

在这里插入图片描述

(4)查看事件

event 事件记录中命名空间的信息,包括警告和报错信息。

使用 kubectl get events -n namespce_namekubectl get ev -n namespce_name

kubectl get events -n kube-system

在这里插入图片描述

(5)排错小结

在对Pod或容器进行排错时,优先使用 kubectl logs 命令直接查看容器日志。如果遇到容器日志中无报错记录,或无日志情况,再使用 kubectl describe 命令查看 Pod 详细信息,然后使用 kubectl get events命令查看所在命名空间的报错记录。三者结合能快速准确的定位 Pod 或容器的故障发生点,能解决90%的问题。

关联博客

关于 Pod 的创建,查询,修改,删除,访问容器以及故障排错。请跳转下面的博文:

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

NOWSHUT

给点饭钱谢谢,我会努力更新!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值