linux 内存释放

linux 内存释放(含脚本)



#cat /proc/meminfo | grep "MemFree" | awk '{print $2}'    (用来查看free的内存有多少)之前先了解一下内存的基本知识#free -mtotal       used       free     shared    buffers     cached
Mem:         1002        769        232          0         62        421
-/+ buffers/cache:        286        715
Swap:         1153          0       1153

第一部分Mem行:
total 内存总数: 1002M
used 已经使用的内存数: 769M
free 空闲的内存数: 232M
shared 当前已经废弃不用,总是0
buffers Buffer 缓存内存数: 62M
cached Page 缓存内存数:421M

关系:total(1002M) = used(769M) + free(232M)

第二部分(-/+ buffers/cache):
(-buffers/cache) used内存数:286M (指的第一部分Mem行中的used - buffers - cached)
(+buffers/cache) free内存数: 715M (指的第一部分Mem行中的free + buffers + cached)

可见-buffers/cache反映的是被程序实实在在吃掉的内存,而+buffers/cache反映的是可以挪用的内存总数。(从这里我们可以看出,实际上 :可用内存=第一部分Mem行中的free + buffers + cached,并不是只有free部分)
#sync
#sync
#echo 3   > /proc/sys/vm/drop_caches
#free -m


[root@server test]# cat /proc/sys/vm/drop_caches
0
首先,/proc/sys/vm/drop_caches的值,默认为0

[root@server test]# sync    #把内存里的数据暂时写到硬盘里

手动执行sync命令(描述:sync 命令运行 sync 子例程。如果必须停止系统,则运行 sync 命令以确保文件系统的完整性。sync 命令将所有未写的系统缓冲区写到磁盘中,包含已修改的 i-node、已延迟的块 I/O 和读写映射文件)

[root@server test]# echo 3 > /proc/sys/vm/drop_caches
[root@server test]# cat /proc/sys/vm/drop_caches
3

将/proc/sys/vm/drop_caches值设为3

[root@server test]# free -m
total       used       free     shared    buffers     cached
Mem:           249         66        182          0          0         11
-/+ buffers/cache:         55        194
Swap:          511          0        511

再来运行free命令,发现现在的used为66MB,free为182MB,buffers为0MB,cached为11MB.那么有效的释放了buffer和cache.

有关/proc/sys/vm/drop_caches的用法在下面进行了说明

/proc/sys/vm/drop_caches (since Linux 2.6.16)
Writing to this file causes the kernel to drop clean caches,
dentries and inodes from memory, causing that memory to become
free.

              To free pagecache, use echo 1 > /proc/sys/vm/drop_caches; to
free dentries and inodes, use echo 2 > /proc/sys/vm/drop_caches;
to   free   pagecache,   dentries and inodes, use echo 3 >
/proc/sys/vm/drop_caches.

              Because this is a non-destructive operation and dirty objects
are not freeable, the user should run sync(8) first.


--内存释放前

#sync

#echo 1 > /proc/sys/vm/drop_caches

内存释放后:

echo 2 > /proc/sys/vm/drop_caches

echo 3 > /proc/sys/vm/drop_caches

cache释放:

To free pagecache:

echo 1 > /proc/sys/vm/drop_caches

To free dentries and inodes:

echo 2 > /proc/sys/vm/drop_caches

To free pagecache, dentries and inodes:

echo 3 > /proc/sys/vm/drop_caches

说明,释放前最好sync一下,防止丢数据。

因为LINUX的内核机制,一般情况下不需要特意去释放已经使用的cache。这些cache起来的内容可以增加文件以及的读写速度。

查看内存条数命令:

#dmidecode |grep -A16 "Memory Device$"

先说下free命令怎么看内存

[root@yuyii proc]# free

total used free shared buffers cached

Mem: 515588 295452 220136 0 2060 64040

-/+ buffers/cache: 229352 286236

Swap: 682720 112 682608

其中第一行用全局角度描述系统使用的内存状况:

total——总物理内存

used——已使用内存,一般情况这个值会比较大,因为这个值包括了cache+应用程序使用的内存

free——完全未被使用的内存

shared——应用程序共享内存

buffers——缓存,主要用于目录方面,inode值等(ls大目录可看到这个值增加)

cached——缓存,用于已打开的文件

note:

total=used+free

used=buffers+cached (maybe add shared also)

第二行描述应用程序的内存使用:

前个值表示-buffers/cache——应用程序使用的内存大小,used减去缓存值

后个值表示+buffers/cache——所有可供应用程序使用的内存大小,free加上缓存值

note:

-buffers/cache=used-buffers-cached

+buffers/cache=free+buffers+cached

第三行表示swap的使用:

used——已使用

free——未使用

cache释放:

To free pagecache:

echo 1 > /proc/sys/vm/drop_caches

To free dentries and inodes:

echo 2 > /proc/sys/vm/drop_caches

To free pagecache, dentries and inodes:

echo 3 > /proc/sys/vm/drop_caches

说明,释放前最好sync一下,防止丢数据。

附1:

linux cache内存释放bash 脚本

#! /bin/sh
    freemem=$(cat /proc/meminfo | grep "MemFree" | awk '{print $2}')
       if [ $freemem -le 409600 ]
          then
               date  >> /var/log/mem.log
               free -m >> /var/log/mem.log
               sync
               sync
               echo 3 > /proc/sys/vm/drop_caches
               free -m >> /var/log/mem.log            
       fi 

附2:

[root@hadoop-n1 ~]# cat /shell/release_mem.sh 
#!/bin/bash
#
date +"%Y-%m-%d %H:%M:%S" >>/shell/release_mem.log
free -m >> /shell/release_mem.log
sync
echo "3" >  /proc/sys/vm/drop_caches
free -m >> /shell/release_mem.log
echo "0" >  /proc/sys/vm/drop_caches
[root@hadoop-n1 ~]# crontab -l
0 0 * * * /shell/release_mem.sh
[root@hadoop-n1 ~]# 

猜你喜欢

转载自blog.csdn.net/u011648187/article/details/12139403