点击上方“小强的进阶之路”,选择“星标”公众号 优质文章,及时送达 预计阅读时间: 18分钟 写在前面 本文主要分析 Linux 系统内存统计的一些指标以及进程角度内存使用监控的一些方法。...Linux 的内存管理从物理内存管理到虚拟内存管理涉及的概念和统计项实在太多,本文从实用和系统运维的角度出发,只列举一些最实用的统计。...首先明确一点,内核目前并没有绝对精确的统计所有的内存使用量,比如alloc_pages接口申请的内存不一定被统计在内(除非所有调用 alloc_pages 的代码主动进行统计,如果某些不讲究的驱动程序没有主动统计的话统计值就肯定对不上了...、SHM_LOCK的共享内存页(也统计在Mlocked中)、和Ramfs等 Mlocked — mlock() 系统调用锁定的内存大小 共享内存在 Linux 中细分的话可以分为以下几种: SystemV...共享内存、可执行程序的文件、动态库、mmap的文件等都统计在这里 Shmem — 共享内存的大小,包括Shared Memory、tmpfs和devtmpfs 注意 Linux 的内存是真正使用时才分配的
在Linux内核,对于进程的内存使用与Cgroup的内存使用统计有一些相同和不同的地方。...进程的内存统计 一般来说,进程使用的内存主要有以下几种情况: (1)用户空间的匿名映射页(Anonymous pages in User Mode address spaces),比如调用malloc分配的内存...与进程内存统计相关的几个文件: /proc/[pid]/stat (23) vsize %lu Virtual memory size in bytes. (24) rss %ld...2.6) data (6) data + stack dt (7) dirty pages (unused in Linux 2.6) 见函数proc_pid_statm...page, vma, address); } else { inc_mm_counter(mm, file_rss); page_add_file_rmap(page); cgroup 的内存统计
smem是一个工具,可以提供大量关于 Linux 系统内存使用情况的报告。与现有工具不同,smem 可以报告比例集大小 (PSS),它更有意义地表示虚拟内存系统中库和应用程序使用的内存量。...由于大部分物理内存通常在多个应用程序之间共享,因此称为常驻集大小 (RSS) 的内存使用标准度量将大大高估内存使用。...只需在终端上触发以下命令即可测量内存使用情况。...smem 显示总内存使用情况 甚至输出显示在 中MB,要使用 smem 获取总内存,请添加t选项。...x86_64-linux-gnu/girepository-1 6 0 0 /usr/lib/x86_64-linux-gnu/girepository-1
文章目录 一、Linux 内核 动态分配内存 系统接口函数 二、统计输出 vmalloc 分配的内存 一、Linux 内核 动态分配内存 系统接口函数 ---- Linux 内核 " 动态分配内存 "...是通过 " 系统接口 " 实现的 , 下面介绍几个重要的 接口函数 ; ① 以 " 页 " 为单位分配内存 : alloc_pages , __get_free_page ; ② 以 " 字节 " 为单位分配..." 虚拟地址连续的内存块 " : vmalloc ; ③ 以 " 字节 " 为单位分配 " 物理地址连续的内存块 " : kmalloc ; 注意 该 " 物理地址连续的内存块 " 是以 Slab 为中心的...; 二、统计输出 vmalloc 分配的内存 ---- 执行 grep vmalloc /proc/vmallocinfo 命令 , 可以统计输出 通过 vmalloc 函数分配的 " 虚拟地址连续的内存块
本文详细介绍了Linux系统中的free命令的使用方法以及关键参数的含义,这可能是你见过的关于free命令最详细的一篇文章了,绝对值得你收藏。...free命令显示了Linux系统中物理内存、交换分区的使用统计信息。...,第一行为 物理内存使用统计: 标题 说明 total 物理内存总量 total = used + free used 已使用内存总量,包含应用使用量+buffer+cached free 空闲内存总量...free 空闲内存加上buffer和cached之后的内存,也就是真正的可用内存总量 第三行为交换分区使用统计 标题 说明 total 交换分区内存总量 used 正在使用的交换分区内存 free...Total的统计信息 -o 禁止显示第二行的缓冲区调整值 -s 每隔多少秒自动刷新结果 -c 与-s配合使用,控制刷新结果次数 -l 显示高低内存的统计详情 -a 显示可用内存 -V 显示版本号 版本不同
JAVA统计服务器资源(cpu,内存,磁盘)–LINUX 使用类: com.sun.management.OperatingSystemMXBean 继承:java.lang.management.OperatingSystemMXBean...自从: 1.5 修饰符和类型 方法 描述 long getCommittedVirtualMemorySize() 返回保证对正在运行的进程可用的虚拟内存量(以字节为单位,或者-1如果不支持此操作...long getFreePhysicalMemorySize() 返回以字节为单位的可用物理内存量。 long getFreeSwapSpaceSize() 返回以字节为单位的可用交换空间量。...ong getTotalPhysicalMemorySize() 返回以字节为单位的物理内存总量。 long getTotalSwapSpaceSize() 返回以字节为单位的交换空间总量。...= osmxb.getFreePhysicalMemorySize(); System.out.println("空闲物理内存:" + freePhysicalMemorySize /
meminfo') as fd: 和 fd=open('/proc/meminfo') 执行的结果一样,都是遍历文件;前者只有在Python 2.6 及后版本才有,后者当打开的文件达到几个G的时候,很消耗内存
一个基于 Linux 操作系统的服务器运行的同时,也会表征出各种各样参数信息。...第二行统计了系统的任务状态信息。...top 虽然非常强大,但是通常用于控制台实时监测系统信息,不适合长时间(几天、几个月)监测系统的负载信息,同时对于短命的进程也会遗漏无法给出统计信息。...说到这里,想到以前很多人纠结编译 linux kernel 的时候 -j 参数究竟是 CPU Core 还是 CPU Core+1?...通过上面修改 -j 参数值编译 boost 和 linux kernel 的同时开启 vmstat 监控,发现两种情况下 context switch 基本没有变化,且也只有显著增加 -j 值后 context
但是,当Linux物理内存超过1G时,线性访问机制就不够用了,因为只能有1G的内存可以被映射,剩余的物理内存无法被内核管理,所以,为了解决这一问题,Linux把内核地址分为线性区和非线性区两部分,线性区规定最大为...DMA Zone通常很小,只有几十M,低端内存区与高端内存区的划分来源于Linux内核空间大小的限制。...因此,Linux 规定“内核直接映射空间” 最多映射 896M 物理内存。...1G) 2.3 Linux内核高端内存的理解 前 面我们解释了高端内存的由来。...4 页框管理 4.1 页框管理 Linux采用4KB页框大小作为标准的内存分配单元。
移除交换空间 ---- 概念 内存管理是Linux系统重要的组成部分。...为了解决内存紧缺的问题,Linux引入了虚拟内存的概念。为了解决快速存取,引入了缓存机制、交换机制等。...当需要用到原始内容时,这些信息会被重新从交换空间读入物理内存。 Linux的内存管理采取的是分页存取机制。...要深入了解Linux内存运行机制,需要知道下面提到的几个方面。 首先,Linux系统会不时地进行页面交换操作,以保持尽可能多的空闲物理内存。...其次,Linux进行页面交换是有条件的,不是所有页面在不用时都交换到虚拟内存中,Linux内核根据“最近最经常使用”算法,仅仅将一些不经常使用的页面文件交换到虚拟内存中。
free命令显示了Linux系统中物理内存、交换分区的使用统计信息。...,第一行为 物理内存使用统计: 标题 说明 total 物理内存总量 total = used + free used 已使用内存总量,包含应用使用量+buffer+cached free 空闲内存总量...free 空闲内存加上buffer和cached之后的内存,也就是真正的可用内存总量 第三行为交换分区使用统计 标题 说明 total 交换分区内存总量 used 正在使用的交换分区内存 free...Total的统计信息 -o 禁止显示第二行的缓冲区调整值 -s 每隔多少秒自动刷新结果 -c 与-s配合使用,控制刷新结果次数 -l 显示高低内存的统计详情 -a 显示可用内存 -V 显示版本号 版本不同...参考示例 # free -t -a -g ---- ————广告时间———— 《马哥Linux云计算及架构师》网络课程,由知名Linux布道师马哥创立,经历了8年的发展,联合阿里巴巴、唯品会、大众点评
CPU访问本地内存的速度比访问远程内存的速度要快 Linux适用于各种不同的体系结构, 而不同体系结构在内存管理方面的差别很大....因此linux内核需要用一种体系结构无关的方式来表示内存....因此linux内核把物理内存按照CPU节点划分为不同的node, 每个node作为某个cpu结点的本地内存, 而作为其他CPU节点的远程内存, 而UMA结构下, 则任务系统中只存在一个内存node, 这样对于...系统中的NUMA结点都是从0开始编号的 3.1 linux-2.4中的实现 pgdat_next指针域和pgdat_list内存结点链表 而对于NUMA结构的系统中, 在linux-2.4.x之前的内核中所有的节点...-3.x~4.x的实现 node_data内存节点数组 在新的linux3.x~linux4.x的内核中,内核移除了pg_data_t的pgdat_next之指针域, 同时也删除了pgdat_list链表
1 Linux如何描述物理内存 Linux把物理内存划分为三个层次来管理 层次 描述 存储节点(Node) CPU被划分为多个节点(node), 内存则被分簇, 每个CPU对应一个本地物理内存, 即一个...内存中的每个节点都是由pg_data_t描述,而pg_data_t由struct pglist_data定义而来, 该数据结构定义在include/linux/mmzone.h, line 615, 每个结点关联到系统中的一个处理器...简单来说, 页是一个数据块, 可以存放在任何页框(内存中)或者磁盘(被交换至交换分区)中 我们今天就来详细讲解一下linux下物理页帧的描述 2 页帧 内核把物理页作为内存管理的基本单位....因此在后来linux-2.4.x的更新中, 删除了这个字段, 取而代之的是page->flags的最高ZONE_SHIFT位和NODE_SHIFT位, 存储了其所在zone和node在内存区域表zone_table...3.2 内存页标识pageflags 其中最后一个flag用于标识page的状态, 这些状态由枚举常量enum pageflags定义, 定义在include/linux/page-flags.h?
2 (N)UMA模型中linux内存的机构 Linux适用于各种不同的体系结构, 而不同体系结构在内存管理方面的差别很大. 因此linux内核需要用一种体系结构无关的方式来表示内存....Linux内核通过插入一些兼容层, 使得不同体系结构的差异很好的被隐藏起来, 内核对一致和非一致内存访问使用相同的数据结构 2.1 (N)UMA模型中linux内存的机构 非一致存储器访问(NUMA)模式下...而内存管理的其他地方则认为他们就是在处理一个(伪)NUMA系统. 2.2 Linux物理内存的组织形式 Linux把物理内存划分为三个层次来管理 层次 描述 存储节点(Node) CPU被划分为多个节点..., 我们会在后面典型架构(x86)上内存区域划分详细讲解x86_32上的内存区域划分 因此Linux内核对不同区域的内存需要采用不同的管理方式和映射方式, 为了解决这些制约条件,Linux使用了三种区:...2.6 高端内存 由于能够被Linux内核直接访问的ZONE_NORMAL区域的内存空间也是有限的,所以LINUX提出了高端内存(High memory)的概念,并且允许对高端内存的访问
#!/bin/awk -f BEGIN{ MAX = 0 MIN = 9999999 CCID=ENVIRON["ccid"...
统计文件行数(单个文件): wc -l file 例如: homer@ubuntu:~/workspace/android/game$ wc -l LGameAndroid2DActivity.java... 906 LGameAndroid2DActivity.java 统计目录所有文件行数(全部目录): find ..../game/utils/NumberUtils.java 68753 total 统计目录并按行数排序(按行大小排序): find ..../game/core/geom/AffineTransform.java 68753 total 统计目录并按行数排序(按行文件名排序): find .
统计 统计当前文件夹下文件的个数,包括子文件夹里的 ls -lR|grep "^-"|wc -l [zhou@localhost logs]$ ls -lR|grep "^-"|wc -l 73 统计文件夹下目录的个数...,包括子文件夹里的 ls -lR|grep "^d"|wc -l 统计当前文件夹下文件的个数 ls -l |grep "^-"|wc -l 统计当前文件夹下目录的个数 ls -l |grep "^d"|...wc -l 备注: 统计输出信息的行数 wc -l 将长列表输出信息过滤一部分,只保留一般文件,如果只保留目录就是 ^d grep "^-" 2.查找 查找文件大小大于50M的文件 find / -size
本文结构: 介绍用命令行如何统计内存占用百分比 介绍用python 如何通过读取进程文件,统计进程的内存总大小,然后计算占系统内存的百分比 第一部分: 在linux 下,统计apache 进程的内存使用百分比...,有很多方法: 使用命令将所有apache 的进程进行统计,然后相加,然后和系统的物理内存相除,求百分比。...如图,"ps aux" 命令输出的第六个字段就是某个进程所占的物理内存,单位是KB.然后就可以将需要的apache 进程过滤出来,统计。 最后,用free 就可以看到系统的总内存: ?...linux下有这样一个命令"pidof".如果想查看系统里所有httpd 进程的pid 号,可以执行"pidof httpd", 发现它和"ps aux|grep httpd" 命令统计的pid号是一样的...继续完善脚本,统计所有httpd 的内存,需要通过/proc/pid/status 文件: #!
Linux使用enum zone_type来标记内核所支持的所有内存区域 3.1 内存区域类型zone_type zone_type结构定义在include/linux/mmzone.h, 其基本信息如下所示...), 他们都通过typedef被重定义为zone_t类型 zone对象用于跟踪诸如页面使用情况的统计数, 空闲区域信息和锁信息 里面保存着内存使用状态信息,如page使用统计, 未使用的内存区域,...compact_blockskip_flush; #endif bool contiguous; ZONE_PADDING(_pad3_) /* Zone statistics 内存域的统计信息...用于标识最近的一次页面扫描中, LRU算法发现了很多脏的页面 ZONE_WRITEBACK 最近的回收扫描发现有很多页在写回 ZONE_FAIR_DEPLETED 公平区策略耗尽(没懂) 4.4 内存域统计信息...vm_stat 内存域struct zone的vm_stat维护了大量有关该内存域的统计信息.
Linux运行一段时间之后,内存会越来越多,导致内存不够用,需要释放一下内存才行 echo "1" > /proc/sys/vm/drop_caches 说明,释放前最好sync一下,防止丢数据。...因为LINUX的内核机制,一般情况下不需要特意去释放已经使用的cache。这些cache起来的内容可以增加文件以及的读写速度。...再用free -m 命令查看一下,剩余的内存 如果没有什么效果,可以使用 echo "2" > /proc/sys/vm/drop_caches 或者 echo "3" > /proc/sys/vm/drop_caches
领取专属 10元无门槛券
手把手带您无忧上云