容器-汇总所有环境下的日志排查问题

​ 日常工作中经常需要排查问题,对于容器环境docker/containerd以及kubernetes环境都会有,所以这里汇总一下各种容器环境下的日志定位方便排查问题。

​ 日志分为控制台日志以及存储日志,存储日志那就看容器中的服务自身的读写哪个文件了,所以本文这里主要针对控制台的输出日志。

​ 容器引擎主要用到的是docker/containerd以及kubernetes,所以只整理这三种。

1. docker

查找容器

复制代码
#docker ps -a|grep myService

a. 查看容器标准输入输出控制台日志

复制代码
#docker logs myService

b. 查找控制台日志存储位置

复制代码
#docker inspect myService|grep LogPath
        "LogPath": "/data/docker/containers/479cb09a433fa67cc8c448b76cf731e3f4d986763bf16e5c47ea9590067723f5/479cb09a433fa67cc8c448b76cf731e3f4d986763bf16e5c47ea9590067723f5-json.log",
2. containerd

containerd的client工具主要使用的是 ctr和nerdctl,ctr 是containerd的官方client,nerdctl是containerd的类docker client,和使用docker一样

复制代码
#ctr container ls 
#ctr -n k8s.io container ls

#nerdctl ps -a
#nerdctl -n k8s.io ps -a

因为在ctr run的时候如果未指定 --log-uri的情况下默认没有控制台日志,所以没法像docker logs一样查看容器日志。当然如果指定了--log-uri则看容器LogPath即可。

3. kubernetes

因为日志是kubelet写的,所以和具体运行时无关,pod的日志在kubernetes源码中变量 podLogsRootDirectory 控制的,默认存储到了/var/log/pods下面,所以在该目录下查找即可

复制代码
#kubectl --kubeconfig /root/.kube/config-test -n my-ns logs agent-8rc8w 

# ll /var/log/pods/
total 92
drwxr-xr-x 3 root root 4096 Dec  4 20:52 cert-manager_cert-manager-webhook-59f9c4db6b-7m6hv_bc48d66a-8a34-48c7-bc58-8d964d744088
drwxr-xr-x 3 root root 4096 Dec  4 20:59 ingress-nginx_ingress-nginx-controller-fkgkd_6dd070cc-d072-4fd9-9b75-4b40d38115f2
drwxr-xr-x 3 root root 4096 Dec  4 21:01 kata-system_kata-deploy-mrkv4_82e51388-81ed-47a4-a300-5c25e583990e
相关推荐
江公望8 小时前
Ubuntu htop命令,10分钟讲清楚
linux·服务器
哎呦,帅小伙哦8 小时前
Linux 时间:从原子钟到 clock_gettime 的每一面
linux·运维·服务器
张小姐的猫8 小时前
【Linux】多线程 —— 线程互斥
linux·运维·服务器·c++
CodeMartain9 小时前
Dify Windows 原生部署(无 Docker、纯本地)
运维·docker·容器
YuanDaima20489 小时前
Linux 进阶运维与 AI 环境实战:进程管理、网络排错与 GPU 监控
linux·运维·服务器·网络·人工智能
牛奶咖啡1310 小时前
k8s容器编排技术实践——使用containerd作为容器运行时部署k8s集群
kubernetes·k8s的安装部署·开启系统的ipvs支持·安装containerd·containerd配置加速器·安装k8s的工具·安装calico网络插件
万里侯10 小时前
云原生数据备份与恢复:保障数据安全的最佳实践
微服务·容器·k8s
lolo大魔王10 小时前
Linux 数据文件处理实战:排序、搜索、压缩、归档一站式详解
linux·运维·服务器
llrraa201011 小时前
配置docker国内镜像源
运维·docker·容器
starvapour11 小时前
Ubuntu切换到Fcitx5中文输入法
linux·运维·ubuntu