咱们把应用部署到Docker里面以后,有什么办法查看这个应用占用了多少内存呢?docker
docker自己提供了一个命令让咱们能够直接看到当前时间全部容易占用的状况。ui
docker stats --no-stream
从上面来看,这几个应用用的内存加起来已是将近12G了。code
可是,这个时候看到机器使用的内存还不到2G。orm
第一反应就是,docker 这个统计太离谱,太坑人了。blog
查了一番资料事后,实际上是计算的问题,也不能说那个是错的。进程
注: 这里的 docker 版本是
Docker version 20.10.2, build 2291f61
内存
通常来讲应用对内存的占用,这个指标实际上是十分重要的,否则内存泄漏都难以发现。部署
若是咱们想要看到应用比较真实的内存要怎么作呢?it
其实能够分红两个步骤io
/proc/pid/status
去看 VmRSS
的值docker inspect
命令能够看到当前容器的一些信息,里面也包含了咱们要找的这个 Pid。
docker inspect -f '{{.State.Pid}}' 容器ID
这个时候就找到了对应的Pid了。
ps
看了一下这个Pid确实是应用的。
这个时候第一步就完成了。
有了 Pid 以后,要查内存就比较容易了。
直接 cat /proc/pid/status
就能看到了。
虽然说这样能找到某个应用具体的内存,可是每次都这样去操做一遍也是挺麻烦的。
并且这样操做一次只能查一个应用,想看多个应用还要分屡次。
既然有了上面的步骤,那么咱们就能够把这个整理成一个脚本,每次执行一下这个脚本就能够了。
# 找出全部运行的容器 idNames=`docker ps --format "{{.ID}}|{{.Names}},"` # 按,号分隔 OLD_IFS="$IFS" IFS="," arr=($idNames) IFS="$OLD_IFS" # 输出 Title printf "%-15s %-30s %-15s\n" Id Name Mem # 遍历全部容器 for item in ${arr[@]} do # 容器ID和容器名字 按 | 分隔 OLD_IFS="$IFS" IFS="|" array=($item) IFS="$OLD_IFS" # 当前容器的Pid pid=`docker inspect -f '{{.State.Pid}}' ${array[0]}` # 当前容器的内存 mem=$(cat /proc/$pid/status|grep -e VmRSS| awk '{print $2}') # 输出结果 printf "%-15s %-30s %-15s\n" ${array[0]} ${array[1]} $[$mem / 1024]M done
执行上面的脚本后,就能够看到当前正在运行的容器的内存占用状况了。
如今看上去,占用大概是1G多,加上其余的内存占用,这个值看上去就和 free
看到的不到2G的使用内存比较接近了。