`
kavy
  • 浏览: 890928 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

linux查看内存的大小

 
阅读更多

用free -m查看的结果:
# free -m
         total    used    free     shared buffers     cached
Mem:           504        471       32       0       19        269
-/+ buffers/cache:        183        321
Swap:       996       0        996


查看/proc/kcore文件的大小:
# ll -h /proc/kcore
-r-------- 1 root root 512M 10月 26 20:40 /proc/kcore

 

 

在Linux下查看内存我们一般用free命令:
[root@scs-2 tmp]# free
             total       used       free     shared    buffers     cached
Mem:       3266180    3250004      16176          0     110652    2668236
-/+ buffers/cache:     471116    2795064
Swap:      2048276      80160    1968116

下面是对这些数值的解释:
total:总计物理内存的大小。
used:已使用多大。
free:可用有多少。
Shared:多个进程共享的内存总额。
Buffers/cached:磁盘缓存的大小。
第三行(-/+ buffers/cached):
used:已使用多大。
free:可用有多少。
第四行就不多解释了。
区别:第二行(mem)的used/free与第三行(-/+ buffers/cache) used/free的区别。 这两个的区别在于使用的角度来看,第一行是从OS的角度来看,因为对于OS,buffers/cached 都是属于被使用,所以他的可用内存是16176KB,已用内存是3250004KB,其中包括,内核(OS)使用+Application(X, oracle,etc)使用的+buffers+cached.
第三行所指的是从应用程序角度来看,对于应用程序来说,buffers/cached 是等于可用的,因为buffer/cached是为了提高文件读取的性能,当应用程序需在用到内存的时候,buffer/cached会很快地被回收。
所以从应用程序的角度来说,可用内存=系统free memory+buffers+cached。
如上例:
2795064=16176+110652+2668236

接下来解释什么时候内存会被交换,以及按什么方交换。 当可用内存少于额定值的时候,就会开会进行交换。
如何看额定值:
cat /proc/meminfo

[root@scs-2 tmp]# cat /proc/meminfo
MemTotal:      3266180 kB
MemFree:         17456 kB
Buffers:        111328 kB
Cached:        2664024 kB
SwapCached:          0 kB
Active:         467236 kB
Inactive:      2644928 kB
HighTotal:           0 kB
HighFree:            0 kB
LowTotal:      3266180 kB
LowFree:         17456 kB
SwapTotal:     2048276 kB
SwapFree:      1968116 kB
Dirty:               8 kB
Writeback:           0 kB
Mapped:         345360 kB
Slab:           112344 kB
Committed_AS:   535292 kB
PageTables:       2340 kB
VmallocTotal: 536870911 kB
VmallocUsed:    272696 kB
VmallocChunk: 536598175 kB
HugePages_Total:     0
HugePages_Free:      0
Hugepagesize:     2048 kB

用free -m查看的结果:
[root@scs-2 tmp]# free -m 
             total       used       free     shared    buffers     cached
Mem:          3189       3173         16          0        107       2605
-/+ buffers/cache:        460       2729
Swap:         2000         78       1921


查看/proc/kcore文件的大小(内存镜像):
[root@scs-2 tmp]# ll -h /proc/kcore 
-r-------- 1 root root 4.1G Jun 12 12:04 /proc/kcore

备注:

占用内存的测量

测量一个进程占用了多少内存,linux为我们提供了一个很方便的方法,/proc目录为我们提供了所有的信息,实际上top等工具也通过这里来获取相应的信息。

/proc/meminfo 机器的内存使用信息

/proc/pid/maps pid为进程号,显示当前进程所占用的虚拟地址。

/proc/pid/statm 进程所占用的内存

[root@localhost ~]# cat /proc/self/statm

654 57 44 0 0 334 0

输出解释

CPU 以及CPU0。。。的每行的每个参数意思(以第一行为例)为:

参数 解释 /proc//status

Size (pages) 任务虚拟地址空间的大小 VmSize/4

Resident(pages) 应用程序正在使用的物理内存的大小 VmRSS/4

Shared(pages) 共享页数 0

Trs(pages) 程序所拥有的可执行虚拟内存的大小 VmExe/4

Lrs(pages) 被映像到任务的虚拟内存空间的库的大小 VmLib/4

Drs(pages) 程序数据段和用户态的栈的大小 (VmData+ VmStk )4

dt(pages) 04

查看机器可用内存

/proc/28248/>free

total used free shared buffers cached

Mem: 1023788 926400 97388 0 134668 503688

-/+ buffers/cache: 288044 735744

Swap: 1959920 89608 1870312

我们通过free命令查看机器空闲内存时,会发现free的值很小。这主要是因为,在linux中有这么一种思想,内存不用白不用,因此它尽可能的cache和buffer一些数据,以方便下次使用。但实际上这些内存也是可以立刻拿来使用的。

所以 空闲内存=free+buffers+cached=total-used

 

转自:http://www.cnblogs.com/rosesmall/archive/2012/05/08/2490522.html

分享到:
评论

相关推荐

    linux下查看内存条数及每根内存大小的实现方法(推荐)

    在linux系统中,查看内存条个数,及每根内存的大小,可以使用dmidecode命令。 如下: #dmidecode | grep -A16 Memory Device$ 输出结果: Memory Device #存储设备 Array Handle: 0x1000 #阵列处理 Error ...

    linux C固定大小内存池

    本文将详细讲解Linux C固定大小内存池的实现以及如何支持多线程环境。 一、内存池概念 内存池是预先在堆上分配的一块连续内存区域,通过内部的数据结构(如链表或位图)来管理这些内存块,以便按需分配和释放固定...

    linux下内存池实现

    在Linux系统中,内存池是一种优化内存管理的技术,尤其对于频繁分配和释放小块内存的情况,内存池可以显著提升性能并减少系统开销。本文将深入探讨Linux下的内存池实现,包括其原理、优势以及如何在C或C++中进行实践...

    Linux虚拟内存管理.pdf

    Linux操作系统中,虚拟内存管理是指使用磁盘作为RAM的扩展,以增大可用的内存大小。内核会将暂时不用的内存块的内容写到硬盘上,以便释放出内存空间供其他进程使用。当需要用到原始的内容时,它们被重新读入内存。...

    Linux 获取CPU和内存的大小

    以下是一些获取CPU和内存大小以及使用率的方法。 **一、CPU信息** 1. **查看CPU基本信息** 使用`lscpu`命令可以查看CPU的基本信息,包括型号、架构、核心数、线程数、主频等。 ``` lscpu ``` 2. **CPU使用率*...

    Linux 内存泄露查找

    最后一行指出有一个大小为1字节的内存块没有被释放,这正是变量`hello`所指向的内存块。 #### 六、总结 mtrace是一种简单有效的工具,可以帮助开发人员快速定位和修复内存泄露问题。通过设置环境变量、调用mtrace...

    在linux查看内存的大小.pdf

    总结起来,监控Linux内存使用不仅包括使用`free`命令获取基本的内存统计,还包括理解不同内存组件的作用,如缓冲区、缓存以及它们如何影响系统性能。通过分析这些信息,可以更好地管理和优化系统的内存资源。

    查看linux系统内存使用情况.pdf

    ### 查看Linux系统内存使用情况 #### 一、Free 命令详解 在Linux操作系统中,`free` 命令是一个非常重要的工具,用于查看系统的内存使用情况。...希望本文能够帮助您更好地掌握Linux内存管理的相关知识。

    深入理解linux虚拟内存管理(中+英)

    Linux虚拟内存管理是操作系统设计中的核心部分,它允许程序访问比实际物理内存更大的地址空间,同时优化了内存的使用效率。这一系统通过映射技术,将进程的虚拟地址转换为实际物理地址,使得多个进程可以共享同一...

    linux内存管理实验报告

    这种方式使得进程间不会互相干扰,也允许进程使用超过实际物理内存大小的地址空间,通过交换机制在磁盘与内存之间动态调度。 实验中,学生通过编写C语言程序调用了系统提供的内存管理函数,例如`malloc()`、`calloc...

    Linux内核内存管理

    Linux 采用了伙伴系统算法来管理内存,通过将内页按 2^0, 2^1, 2^2…2^10 大小进行分组,每次分配内存时,从相应大小的池中分配内存,然后再把余下的内存分配给它的下一级缓存池。 在 Linux 内核中,大内存分配的...

    linux内核内存管理

    首先,Linux内核将物理内存划分为不同的类型,以适应不同硬件和内存大小的需求。内存区域划分通常包括DMA区域、DMA32区域、NORMAL区域、HIGHMEM区域等。DMA区域主要对应低端内存(小于16MB),DMA32区域服务于32位...

    Linux内存管理--Linux物理内存三级架构.pdf

    Linux内存管理是操作系统管理计算机内存资源的重要组成部分,它涉及到内存的分配、回收以及效率优化等多方面的技术。Linux内存管理采用的是一种三级架构模型,包括内存节点(node)、内存区域(zone)和物理页框(page)。...

    【LINUX】关于动态内存分配的理解

    通过动态内存分配,程序员可以使用相关函数(如realloc)来重新分配内存大小,实现数组的动态扩充或缩小。 4. 传统数组无法跨函数使用。动态分配的内存可以被函数间共享,因为它是在堆上分配的,作用域不受限于函数...

    Linux 虚拟内存优化提速大法

    在实际应用中,可以根据系统的内存大小和使用情况来决定交换分区的大小,甚至可以完全不使用交换分区。 三、查看交换分区的使用情况 可以使用 `free -m` 命令来查看交换分区的使用情况,如果在日常应用中看到交换...

    jmeter在linux系统下运行及本地内存调优的方法详解

    1.在linux系统下安装跨系统传输文件工具  root用户下 根目录输入 yum -y install lrzsz 2.把apache-jmeter-4.0zip包 用rz命令上传到linux系统的根目录下 解压 3.配置jmeter环境变量 vim /etc/profile 添加 export...

    嵌入式Linux内存与性能详解

    1. **嵌入式系统概述**:嵌入式系统通常具有特定功能,它们在硬件限制下运行,如处理能力、内存大小和电源效率。这些限制使得内存管理成为嵌入式Linux开发中的核心任务。 2. **Linux内存管理**:Linux操作系统采用...

    linux 共享内存详解

    - `size`: 需要分配的共享内存段大小(以字节为单位)。 - `shmflg`: 设置共享内存段的行为标志,如`IPC_CREAT`用于指示如果不存在则创建新的共享内存段,`IPC_EXCL`用于确保当共享内存段已存在时不创建新的共享...

    linux-内存及flash使用情况查询.pdf

    Linux系统作为一款开源的操作系统,在使用过程中,对于系统资源的监控,尤其是内存和Flash存储器的使用情况的查询,是系统管理员日常工作中的重要部分。对于内存和Flash的使用情况查询,有多种方法可以实现,但它们...

Global site tag (gtag.js) - Google Analytics