Linux 服务器的系统内存监控方法详细解析

    内存是Linux内核所管理的最重要的资源之一。内存管理系统是操作系统中最为重要的部分,因为系统的物理内存总是少于系统所需要的内存数量。虚拟内存就 是为了克服这个矛盾而采用的策略。系统的虚拟内存通过在各个进程之间共享内存而使系统看起来有多于实际内存的内存容量。Linux支持虚拟内存, 就是使用磁盘作为RAM的扩展,使可用内存相应地有效扩大。核心把当前不用的内存块存到硬盘,腾出内存给其他目的。当原来的内容又要使用时,再读回内存。

 

一、内存使用情况监测

 

(1)实时监控内存使用情况

 

在命令行使用“Free”命令可以监控内存使用情况

 

 

#free

total used free shared buffers cached

Mem: 256024 192284 63740 0 10676 101004

-/+ buffers/cache: 80604 175420

Swap: 522072 0 522072

 

上面给出了一个256兆的RAM和512兆交换空间的系统情况。第三行输出(Mem:)显示物理内存。total列不显示核心使用的物理内存(通常 大约1MB)。used列显示被使用的内存总额(第二行不计缓冲)。 free列显示全部没使用的内存。Shared列显示多个进程共享的内存总额。Buffers列显示磁盘缓存的当前大小。第五行(Swap:)对对换空 间,显示的信息类似上面。如果这行为全0,那么没使用对换空间。在缺省的状态下,free命令以千字节(也就是1024字节为单位)来显示内存使用情况。 可以使用—h参数以字节为单位显示内存使用情况,或者可以使用—m参数以兆字节为单位显示内存使用情况。还可以通过—s参数使用命令来不间断地监视内存使 用情况:

 

#free –b –s2

 

这个命令将会在终端窗口中连续不断地报告内存的使用情况,每2秒钟更新一次。

 

(2)组合watch與 free命令用来实时监控内存使用情况:

 

 

#watch -n 2 -d free

Every 2.0s: free Fri Jul 6 06:06:12 2007

total used free shared buffers cached

Mem: 233356 218616 14740 0 5560 64784

-/+ buffers/cache: 148272 85084

Swap: 622584 6656 615928

 

 

watch命令会每两秒执行 free一次,执行前会清除屏幕,在同样位置显示数据。因为 watch命令不会卷动屏幕,所以适合出长时间的监测内存使用率。可以使用 -n选项,控制执行的频率;也可以利用 -d选项,让命令将每次不同的地方显示出来。Watch命令会一直执行,直到您按下 [Ctrl]-[C] 为止。

 

二、虚拟内存的概念

 

(1)Linux虚拟内存实现机制

 

Linux虚拟内存的实现需要六种机制的支持:地址映射机制、内存分配回收机制、缓存和刷新机制、请求页机制、交换机制、内存共享机制。

 

首先内存管理程序通过映射机制把用户程序的逻辑地址映射到物理地址,在用户程序运行时如果发现程序中要用的虚地址没有对应的物理内存时,就发出了请 求页要求;如果有空闲的内存可供分配,就请求分配内存(于是用到了内存的分配和回收),并把正在使用的物理页记录在缓存中(使用了缓存机制)。 如果没有足够的内存可供分配,那么就调用交换机制,腾出一部分内存。另外在地址映射中要通过TLB(翻译后援存储器)来寻找物理页;交换机制中也要用到交 换缓存,并且把物理页内容交换到交换文件中后也要修改页表来映射文件地址。

 

(2)虚拟内存容量设定

 

也许有人告诉你,应该分配2倍于物理内存的虚拟内存,但这是个不固定的规律。如果你的物理保存比较小,可以这样设定。如果你有1G物理内存或更多的 话,可以缩小一下虚拟内存。Linux会把大量的内存用做Cache的,但在资源紧张时回收回.。你只要看到swap为0或者很小就可以放心了,因为内存 放着不用才是最大的浪费。

 

三、使甩vmstat命令监视虚拟内存使用情况

 

vmstat是Virtual Meomory Statistics(虚拟内存统计)的缩写,可对操作系统的虚拟内存、进程、CPU活动进行监视。它是对系统的整体情况进行统计,不足之处是无法对某个 进程进行深入分析。通常使用vmstat 5 5(表示在5秒时间内进行5次采样)命令测试。将得到一个数据汇总它可以反映真正的系统情况。

 

#vmstat 5 5

procs -----------memory---------- ---swap-- -----io---- --system-- ----cpu----

r b swpd free buff cache si so bi bo in cs us sy id wa

1 0 62792 3460 9116 88092 6 30 189 89 1061 569 17 28 54 2

0 0 62792 3400 9124 88092 0 0 0 14 884 434 4 14 81 0

0 0 62792 3400 9132 88092 0 0 0 14 877 424 4 15 81 0

1 0 62792 3400 9140 88092 0 0 0 14 868 418 6 20 74 0

1 0 62792 3400 9148 88092 0 0 0 15 847 400 9 25 67 0

 

vmstat命令输出分成六个部分:

 

(1)进程procs:

r:在运行队列中等待的进程数 。

b:在等待io的进程数 。

 

(2)内存memoy:

 

swpd:现时可用的交换内存(单位KB)。

 

free:空闲的内存(单位KB)。

 

buff: 缓冲去中的内存数(单位:KB)。

 

cache:被用来做为高速缓存的内存数(单位:KB)。

 

(3) swap交换页面

 

si: 从磁盘交换到内存的交换页数量,单位:KB/秒。

 

so: 从内存交换到磁盘的交换页数量,单位:KB/秒。

 

(4) io块设备:

 

bi: 发送到块设备的块数,单位:块/秒。

 

bo: 从块设备接收到的块数,单位:块/秒。

 

(5)system系统:

 

in: 每秒的中断数,包括时钟中断。

 

cs: 每秒的环境(上下文)切换次数。

 

(6)cpu中央处理器:

cs:用户进程使用的时间 。以百分比表示。

sy:系统进程使用的时间。 以百分比表示。

id:中央处理器的空闲时间 。以百分比表示。

 

如果 r经常大于 4 ,且id经常小于40,表示中央处理器的负荷很重。 如果bi,bo 长期不等于0,表示物理内存容量太小。

 

四、Linux 服务器的内存泄露和回收内存的方法

 

1、内存泄漏的定义:

 

一般我们常说的内存泄漏是指堆内存的泄漏。堆内存是指程序从堆中分配的,大小任意的(内存块 的大小可以在程序运行期决定),使用完后必须显示释放的内存。应用程序一般使用malloc,realloc,new等函数从堆中分配到一块内存,使用完 后,程序必须负责相应的调用free或delete释放该内存块,否则,这块内存就不能被再次使用,我们就说这块内存泄漏了。

 

2、内存泄露的危害

 

从用户使用程序的角度来看,内存泄漏本身不会产生什么危害,作为一般的用户,根本感觉不到内 存泄漏的存在。真正有危害的是内存泄漏的堆积,这会最终消耗尽系统所有的内存。从这个角度来说,一次性内存泄漏并没有什么危害,因为它不会堆积,而隐式内 存泄漏危害性则非常大,因为较之于常发性和偶发性内存泄漏它更难被检测到。存在内存泄漏问题的程序除了会占用更多的内存外,还会使程序的性能急剧下降。对 于服务器而言,如果出现这种情况,即使系统不崩溃,也会严重影响使用。

 

3、内存泄露的检测和回收

 

对于内存溢出之类的麻烦可能大家在编写指针比较多的复杂的程序的时候就会遇到。在 Linux 或者 unix 下,C、C++语言是最使用工具。但是我们的 C++ 程序缺乏相应的手段来检测内存信息,而只能使用 top 指令观察进程的动态内存总额。而且程序退出时,我们无法获知任何内存泄漏信息。

 

使用kill命令

 

使用Linux命令回收内存,我们可以使用Ps、Kill两个命令检测内存使用情况和进行回 收。在使用超级用户权限时使用命令“Ps”,它会列出所有正在运行的程序名称,和对应的进程号(PID)。Kill命令的工作原理是:向Linux操作系 统的内核送出一个系统操作信号和程序的进程号(PID)。

 

应用例子:

 

为了高效率回收内存可以使用命令ps 参数v:

 

 

[root@www ~]# ps v

PID TTY STAT TIME MAJFL TRS DRS RSS %MEM COMMAND

2542 tty1 Ss+ 0:00 0 8 1627 428 0.1 /sbin/mingetty tty1

2543 tty2 Ss+ 0:00 0 8 1631 428 0.1 /sbin/mingetty tty2

2547 tty3 Ss+ 0:00 0 8 1631 432 0.1 /sbin/mingetty tty3

2548 tty4 Ss+ 0:00 0 8 1627 428 0.1 /sbin/mingetty tty4

2574 tty5 Ss+ 0:00 0 8 1631 432 0.1 /sbin/mingetty tty5

2587 tty6 Ss+ 0:00 0 8 1627 424 0.1 /sbin/mingetty tty6

2657 tty7 Ss+ 1:18 12 1710 29981 7040 3.0 /usr/bin/Xorg :0 -br -a

2670 pts/2 Ss 0:01 2 682 6213 1496 0.6 -bash

3008 pts/4 Ss 0:00 2 682 6221 1472 0.6 /bin/bash

3029 pts/4 S+ 0:00 2 32 1783 548 0.2 ping 192.168.1.12

3030 pts/2 R+ 0:00 2 73 5134 768 0.3 ps v

 

然后如果想回收Ping命令的内存的话,使用命令:

 

# Kill -9 3029

 

使用工具软件

 

Memprof是一个非常具有吸引力且非常易于使用的软件,它由Red Hat的Owen Talyor创立。这个工具是用于GNOME前端的Boehm-Demers-Weiser垃圾回收器。这个工具直接就可以执行,并且其工作起来无需对源 代码进行任何修改。在程序执行时,这个工具会以图形化的方式显示内存的使用情况。

 

=====================================================================================

 

Linux中使用free可以查看系统内存使用状态, 默认单位为k

  blue_stone@blueice:~$ free

  total used free shared buffers cached

  Mem: 2075320 1879172 196148 0 533484 952588

  -/+ buffers/cache: 393100 1682220

  Swap: 2008084 0 2008084

  Mem 行显示了从系统角度看来内存使用的情况, total是系统可用的内存大小, 数量上等于系统物理内存减去内核保留的内存. buffers和cached是系统用做缓冲的内存. buffers与某个块设备关联, 包含了文件系统元数据, 并且跟踪了块的变化. cache只包含了文件本身.

  -/+ buffers/cache行则从用户角度显示内存信息, 可用内存从数量上等于mem行used列值减去buffers和cached内存的大小. 因为buffers和cached是操作系统为加快系统运行而设置的, 当用户需要时, 可以只接为用户使用.

  top和vmstat也显示了系统内存的信息, 和free的显示结果类似.

  这些命令都是从/proc/meminfo中读取内存信息.

  blue_stone@blueice:~$ cat /proc/meminfo

  MemTotal: 2075320 kB

  MemFree: 25016 kB

  Buffers: 763564 kB

  Cached: 879860 kB

  SwapCached: 0 kB

  Active: 1056968 kB

  Inactive: 843136 kB

  HighTotal: 917440 kB

  HighFree: 13892 kB

  LowTotal: 1157880 kB

  LowFree: 11124 kB

  SwapTotal: 2008084 kB

  SwapFree: 2008084 kB

  Dirty: 4708 kB

  Writeback: 0 kB

  Mapped: 707152 kB

  Slab: 102728 kB

  CommitLimit: 3045744 kB

  Committed_AS: 691808 kB

  PageTables: 2936 kB

  VmallocTotal: 114680 kB

  VmallocUsed: 14800 kB

  VmallocChunk: 98800 kB

 

关于/proc/meminfo中各行的含意, 在内核源代码的Documentation/filesystems/proc.txt文件中有叙述,系统的真实内存大小可以用dmesg  grep [mM][eE][mM]看到。

  blue_stone@blueice:~$ dmesg  grep [mM][eE][mM]

  895MB HIGHMEM available.

  1152MB LOWMEM available.

  HighMem zone: 229360 pages, LIFO batch:31

  Memory: 2073292k/2097088k available (1493k kernel code, 21648k reserved,

  546k data, 196k init, 917440k highmem)

  Freeing initrd memory: 1079k freed

  MEM window: f8000000-f80fffff

  highmem bounce pool size: 64 pages

  Freeing unused kernel memory: 196k freed

  ehci_hcd 0000:00:10.4: irq 177, io mem 0xf8121000

  /dev/vmnet: hub 0 does not exist, allocating memory.

  [fglrx] Maximum main memory to use for locked dma buffers: 1898 MBytes.

  /dev/vmnet: hub 3 does not exist, allocating memory.

  /dev/vmnet: hub 1 does not exist, allocating memory.

  /dev/vmnet: hub 2 does not exist, allocating memory.

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

  /proc/pid/status显示一个进程的详细状态, 下面是一个示例:

  blue_stone@blueice:~$ cat /proc/5346/status

  Name: bash

  State: S (sleeping)

  SleepAVG: 98%

  Tgid: 5346

  Pid: 5346

  PPid: 5343

  TracerPid: 0

  Uid: 1000 1000 1000 1000

  Gid: 104 104 104 104

  FDSize: 256

  Groups: 6 24 29 44 104 113 1000 1001

  VmPeak: 6528 kB

  VmSize: 6528 kB

  VmLck: 0 kB

  VmHWM: 1976 kB

  VmRSS: 1976 kB

  VmData: 752 kB

  VmStk: 84 kB

  VmExe: 644 kB

  VmLib: 1788 kB

  VmPTE: 16 kB

  Threads: 1

  SigQ: 0/4294967295

  SigPnd: 0000000000000000

  ShdPnd: 0000000000000000

  SigBlk: 0000000000000000

  SigIgn: 0000000000384004

  SigCgt: 000000004b813efb

  CapInh: 0000000000000000

  CapPrm: 0000000000000000

  CapEff: 0000000000000000

  VmSize即为该进程内存总大小, 和top输出中的VIRT一致。

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值