如何写论文?写好论文?免费论文网提供各类免费论文写作素材!
当前位置:免费论文网 > 美文好词 > 优质好文 > linux,查内存命令

linux,查内存命令

来源:免费论文网 | 时间:2018-11-08 14:53 | 移动端:linux,查内存命令

篇一:在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 325000416176 0 110652 2668236 -/+ buffers/cache: 471116 2795064

Swap:204827680160 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 317316 0 107 2605

-/+ buffers/cache: 460 2729

Swap:200078 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

篇二:Linux查看机器常用命令

1,查看磁盘

df -h

2,查看内存大小

free

free [-m|g]按MB,GB显示内存

vmstat

3,查看cpu

cat /proc/cpuinfo

只看cpu数量grep "model name" /proc/cpuinfo | wc -l

4,查看系统内存

cat /proc/meminfo

5,查看每个进程的情况

cat /proc/5346/status 5347是pid

6,查看负载

w

uptime

7,查看系统整体状态

top

最后一些输出信息的解释:

load average: 0.09, 0.05, 0.01

三个数分别代表不同时间段的系统平均负载(一分钟、五分钟、以及十五分钟),它们的数字当然是越小越好。“有多少核心即为有多少负荷”法则:在多核处理中,你的系统均值不应该高于处理器核心的总数量

进程使用的内存可以用top,有3个列VIRT RES SHR, 标示了进程使用的内存情况, VIRT标识这个进程可以使用的内存总大小, 包括这个进程真实使用的内存, 映射过的文件, 和别的进程共享的内存等. RES标识这个这个进程真实占用内存的大小. SHR标识可以和别的进程共享的内存和库大小.

8,性能监视sar命令

sar -u输出显示CPU信息。-u选项是sar的默认选项。该输出以百分比显示CPU的使用情况

CPU

CPU编号

%user

在用户模式中运行进程所花的时间

%nice

运行正常进程所花的时间

%system

在内核模式(系统)中运行进程所花的时间

%iowait

没有进程在该CPU上执行时,处理器等待I/O完成的时间

%idle

没有进程在该CPU上执行的时间

sar 5 10 sar以5秒钟间隔取得10个样本

sar -u -p ALL 5 5 分cup显示

sar -n { DEV | EDEV | NFS | NFSD | SOCK | ALL }

sar 提供六种不同的语法选项来显示网络信息。-n选项使用6个不同的开关:DEV | EDEV | NFS | NFSD | SOCK | ALL 。DEV显示网络接口信息,EDEV显示关于网络错误的统计数据,NFS统计活动的NFS客户端的信息,NFSD统计NFS服务器的信息,SOCK显示套接字信息,ALL显示所有5个开关。它们可以单独或者一起使用。

sar -n DEV 各参数含义

IFACE

LAN接口

rxpck/s

每秒钟接收的数据包

txpck/s

每秒钟发送的数据包

rxbyt/s

每秒钟接收的字节数

txbyt/s

每秒钟发送的字节数

rxcmp/s

每秒钟接收的压缩数据包

txcmp/s

每秒钟发送的压缩数据包

rxmcst/s

每秒钟接收的多播数据包

9,查看命令历史(含时间戳)

export HISTTIMEFORMAT='%F %T ';history| more

10,查看文件夹和文件大小

du -h --max-depth=0 dm 查看dm目录大小

du -h --max-depth=1 dm 查看dm目录大小,以及dm各文件文件夹的大小

du -h --max-depth=0 查看当前文件夹大小

篇三:linux系统如何查看内存使用情况

$cat /proc/meminfo

MemTotal: 2052440 kB //总内存

MemFree: 50004 kB //空闲内存

Buffers: 19976 kB //给文件的缓冲大小

Cached: 436412 kB //高速缓冲存储器()使用的大小

SwapCached: 19864 kB //被高速缓冲存储用的交换空间大小

Active: 1144512 kB //活跃使用中的高速缓冲存储器页面文件大小

Inactive:732788 kB //不经常使用的高速缓冲存储器页面文件大小

Active(anon): 987640 kB //anon:不久

Inactive(anon):572512 kB

Active(file): 156872 kB

Inactive(file):160276 kB

Unevictable: 8 kB

Mlocked:8 kB

HighTotal: 1177160 kB //The total and free amount of memory, in kilobytes, that is not directly mapped into kernel space. HighFree: 7396 kB // The HighTotal value can vary based on the type of kernel used.

LowTotal:875280 kB // The total and free amount of memory, in kilobytes, that is directly mapped into kernel space. used. LowFree: 42608 kB //The LowTotal value can vary based on the type of kernel

SwapTotal: 489940 kB //交换空间总大小

SwapFree:450328 kB //空闲交换空间

Dirty:104 kB //等待被写回到磁盘的大小

Writeback: 0 kB //正在被写回的大小

AnonPages: 1408256 kB //未映射的页的大小

Mapped: 131964 kB //设备和文件映射的大小

Slab: 37368 kB //内核数据结构缓存的大小,可减少申请和释放内存带来的消耗

SReclaimable:14164 kB //可收回slab的大小

SUeclaim: 23204 kB //不可收回的slab的大小23204+14164=37368

PageTables: 13308 kB //管理内存分页的索引表的大小

NFS_Unstable: 0 kB //不稳定页表的大小

Bounce: 0 kB //bounce:退回

WritebackTmp: 0 kB //

CommitLimit: 1516160 kB

Committed_AS: 2511900 kB

VmallocTotal: 122880 kB //虚拟内存大小

VmallocUsed: 28688 kB //已经被使用的虚拟内存大小

VmallocChunk:92204 kB

HugePages_Total: 0 //大页面的分配

HugePages_Free: 0

HugePages_Rsvd: 0

HugePages_Surp: 0

Hugepagesize: 2048 kB

DirectMap4k: 10232 kB

DirectMap2M:899072 kB

下面简单来个例子,看看已用内存和物理内存大小..

#include <stdio.h>

#include <stdlib.h>

#include <string.h>

int MemInfo(char* Info, int len);

int main()

{

char buf[128];

memset(buf, 0, 128);

MemInfo(buf, 100);

printf("%s", buf);

return 0;

}

int MemInfo(char* Info, int len)

{

char sStatBuf[256];

FILE* fp;

int flag;

int TotalMem;

int UsedMem;

char* line;

if(system("free -m | awk '{print $2,$3}' > mem"));//写入文件

memset(sStatBuf, 0, 256);

fp = fopen("mem", "rb");

if(fp < 0)

{

return -1;

}

fread(sStatBuf,1, sizeof(sStatBuf) , fp);

line = strstr(sStatBuf, "/n");

TotalMem = atoi(line);

line = strstr(line, " ");

UsedMem = atoi(line);

memset(sStatBuf, 0, 256);

sprintf(sStatBuf, "Used %dM/Total %dM/n", UsedMem, TotalMem);

if(strlen(sStatBuf) > len)

{

return -1;

}

memcpy(Info, sStatBuf, strlen(sStatBuf));

return 0;

}

结果:Used 488M/Total 495M

Linux系统下如何查看物理内存占用率

Linux下看内存和CPU使用率一般都用top命令,但是实际在用的时候,用top查看出来的内存占用率都非常高,如: Mem:4086496k total, 4034428k used, 52068k free,112620k buffers

Swap: 4192956k total,799952k used, 3393004k free, 1831700k cached

接近98.7%,而实际上的应用程序占用的内存往往并没这么多,

PID USERPR NI VIRT RES SHR S %CPU %MEM TIME+

COMMAND

25801 sybase 150 2648m 806m 805m S 1.0 20.2 27:56.96

dataserver

12084 oracle 160 1294m 741m 719m S 0.0 18.60:13.50

oracle

27576 xugy250 986m 210m 1040 S 1.0 5.3 28:51.24 cti

25587 yaoyang170 1206m 162m 3792 S 0.0 4.19:21.14 java

看%MEM这列的数字,按内存排序后,把前几名加起来,撑死了才不过55%,那剩下的内存都干嘛用了?

一般的解释是Linux系统下有一种思想,内存不用白不用,占用了就不释放,听上去有点道理,但如果我一定要知道应用程序还能有多少内存可用呢?

仔细看top关于内存的显示输出,有两个数据buffers和cached,在Linux系统下的buffer指的是磁盘写缓存,而cache则指的是磁盘读缓存。

(A buffer is something that has yet to be "written" to disk.

A cache is something that has been "read" from the disk and stored for later use.)

而这两块是为了提高系统效率而分配的内存,在内存富余的时候,操作系统将空闲内存利用起来,而有内存需求时,系统会释放这部分的内存供应用程序使用。

这样,真正应用程序可用的内存就是free+buffer+cache,上面的例子就是:

52068k + 112620k + 1831700k = 1996388k

而已用内存则是used-buffer-cache,上面的例子为:

4034428k - 112620k - 1831700k = 2090108k

Linux下查看内存还有一个更方便的命令,free:

$ free

total used free shared buffers cached

Mem: 4086496 403404452452 0 112756 1831564

-/+ buffers/cache: 2089724 1996772

Swap:4192956 799952 3393004

Mem:这列就是用top命令看到的内存使用情况,而-/+buffers/cache这列就是我们刚刚做的计算结果,used-buffer-cache/free+buffer+cache

也可以加-m或者-g参数查看按MB或者GB换算的结果。

$ free -m

total used free shared buffers cached

Mem: 3990 390683 090 1786

-/+ buffers/cache: 2029 1961

Swap:4094 781 3312

这样,真正应用程序的内存使用量就可以得出来了,上面的例子中内存占用率为51.1%。


linux,查内存命令》由:免费论文网互联网用户整理提供;
链接地址:http://www.csmayi.cn/meiwen/28332.html
转载请保留,谢谢!
相关文章