本文由Markdown语法编辑器编辑完成。
1.背景:
近期在处理现场问题,观察服务器时,会遇到某些进程占用较高内存的情况。由于我们的服务,基本上都是以容器的方式在运行,因此就需要找到,到底是哪个容器,占用的内存比较高。
以下是根据htop,查看到的,占内存较高的进程的信息。
在htop中,第一列是进程的id,通过进程id, 一般就可以看到进程的启动方式。进而,希望能够通过进程id, 找到是哪个启动的容器,占用内存较高,从而想办法来调整其内存占用,改善服务器的性能。
2. 具体操作:
2.1 htop按内存排序,查找内存占用较高的进程id
第一列显示的PID: 1249316, 就是目前占用内存最高的进程id.
那么怎么通过这个进程id, 来查找到是哪一个docker服务呢.
可以采用:
cat /proc/1249316/cgroup
这样就会输出docker的id. 比如这里就会输出:
0::/docker/19a3a51e7753133ff504b68ecffee477bdf40fe95f0865c5b922b173a6a0a7bd
然后,我们可以利用docker/后面的这一列数字.取前面的12以内的数字,再grep docker.
docker ps -a |grep -i 19a3a51e77
2.2 通过将所有的容器,按占用内存大小排序后输出
通过向AI提问后,可以通过shell脚本的方式,计算出当前服务器上面所有的容器的内存占用,并且按照内存占用的大小,排序后输出.具体指令是:
docker stats --no-stream --format "{{.MemUsage}}" | awk '{split($1, a, "MiB"); if (a[2] == "") {split($1, a, "GiB"); sum += a[1] * 1024} else {sum += a[1]}} END {print sum " MiB"}'
脚本运行完成后,我们便可以看到,根据内存占用大小排序后的容器的名称,id, 当前占用CPU的百分比,内存占用百分比等参数.
从而就可以来分析,到底是什么原因,占用较高的内存,是否符合预期等.