zoukankan      html  css  js  c++  java
  • Docker查看应用的实际内存

    前言

    我们把应用部署到Docker里面之后,有什么办法查看这个应用占用了多少内存呢?

    docker本身提供了一个命令让我们可以直接看到当前时间所有容易占用的情况。

    docker stats --no-stream
    

    从上面来看,这几个应用用的内存加起来已经是将近12G了。

    但是,这个时候看到机器使用的内存还不到2G。

    第一反应就是,docker 这个统计太离谱,太坑人了。

    查了一番资料过后,其实是计算的问题,也不能说那个是错的。

    注: 这里的 docker 版本是 Docker version 20.10.2, build 2291f61

    一般来说应用对内存的占用,这个指标其实是十分重要的,不然内存泄漏都难以发现。

    如果我们想要看到应用比较真实的内存要怎么做呢?

    处理方案

    其实可以分成两个步骤

    1. 找到应用的真实进程Id(宿主机里面的)
    2. 从宿主机的 /proc/pid/status 去看 VmRSS 的值

    找 Pid

    docker inspect 命令可以看到当前容器的一些信息,里面也包含了我们要找的这个 Pid。

    docker inspect -f '{{.State.Pid}}' 容器ID
    

    这个时候就找到了对应的Pid了。

    ps 看了一下这个Pid确实是应用的。

    这个时候第一步就完成了。

    查 VmRSS

    有了 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
    " 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
    " ${array[0]} ${array[1]} $[$mem / 1024]M
    done	
    

    执行上面的脚本后,就可以看到当前正在运行的容器的内存占用情况了。

    现在看上去,占用大概是1G多,加上其他的内存占用,这个值看上去就和 free 看到的不到2G的使用内存比较接近了。

    如果您认为这篇文章还不错或者有所收获,可以点击右下角的【推荐】按钮,因为你的支持是我继续写作,分享的最大动力!
    声明: 本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。如果您发现博客中出现了错误,或者有更好的建议、想法,请及时与我联系!!如果想找我私下交流,可以私信或者加我微信。
  • 相关阅读:
    Hibernate缓存机制
    如何建立索引
    数据库索引及基本优化入门
    索引优化-2
    索引优化-1
    Linux基本命令参数
    Spring 依赖注入(控制反转)介绍
    Linux的软连接和硬连接
    聚簇索引(Clustered Index)和非聚簇索引 (Non- Clustered Index)
    常见和链表相关的算法
  • 原文地址:https://www.cnblogs.com/catcher1994/p/14358651.html
Copyright © 2011-2022 走看看