如何获取在Docker容器中运行的进程的内存使用情况?

时间:2017-04-24 12:24:45

标签: linux docker asp.net-core dockerfile docker-machine

我创建了85个容器,所有容器在我的Linux机器上运行相同的.NET核心应用程序映像。 我对所有容器的REST调用是相同的,但每个容器使用的内存是不同的。

这是我不理解的。为什么内存的使用方式不同,因为所有容器都运行相同的映像,而且REST调用也一样?

我可以通过以下方式获取容器使用的内存:

  1. docker stats

    CONTAINER- 7827fe8127eb
    
    CPU - 0.00%
    
    MEM USAGE / LIMIT - 67.1MiB / 7.666GiB
    
    MEM % - 0.85%
    
    NET I/O - 76.4kB / 6.19kB
    
    BLOCK I/O - 42.7MB / 0B
    

    从上面的统计数据我知道,我的容器使用的内存是67.1 MB。

  2. 然后我进入容器,并试图找出这些进程使用的正在运行的进程和内存。

    docker exec -i -t 7827fe8127eb /bin/bash
    top
    

    Enter image description here

    现在从“docker stats”获得的统计信息表示容器内存为67 MB,但dotnet进程使用的内存是多少?

    "RES"列值是否提供进程内存? 由于RES大小为92.70 MB,大于容器内存。

  3. 我使用Docker引擎API来获取容器统计信息。但我不知道究竟哪个属性指定了容器内存。

    "memory_stats": {
        "usage": 72302592,
        "max_usage": 84365312,
        "stats": {
            "active_anon": 47865856,
            "active_file": 6664192,
            "cache": 24477696,
            "dirty": 4096,
            "hierarchical_memory_limit": 9223372036854772000,
            "inactive_anon": 8450048,
            "inactive_file": 9318400,
            "mapped_file": 16236544,
            "pgfault": 118960,
            "pgmajfault": 104,
            "pgpgin": 120339,
            "pgpgout": 105242,
            "rss": 47824896,
            "rss_huge": 8388608,
            "total_active_anon": 47865856,
            "total_active_file": 6664192,
            "total_cache": 24477696,
            "total_dirty": 4096,
            "total_inactive_anon": 8450048,
            "total_inactive_file": 9318400,
            "total_mapped_file": 16236544,
            "total_pgfault": 118960,
            "total_pgmajfault": 104,
            "total_pgpgin": 120339,
            "total_pgpgout": 105242,
            "total_rss": 47824896,
            "total_rss_huge": 8388608,
            "total_unevictable": 4096,
            "total_writeback": 0,
            "unevictable": 4096,
            "writeback": 0
        },
        "limit": 8231383040
    },
    
  4. 我无法找到,这里也是67.1 MB。

    首先,为什么每个容器使用的内存不同,因为它们运行相同的图像,并且执行的REST操作也是一样的?

    有些容器的使用量高达93 MB,那么哪个容器进程实际上占用了最大内存?

1 个答案:

答案 0 :(得分:1)

如果每个泊坞广告像往常一样挂载/proc/(请参阅proc(5) ...),您可以使用它(例如,运行pmap(1)等...)

相关问题