linux清理缓存

    xiaoxiao2021-03-25  121

    今天用spot on light 查了一下开发服务器的内存占用,只剩下60MB 用下面的方法就可以实现清空缓存 频繁的文件访问会导致系统的Cache使用量大增 首先使用free -m查看剩余内存 [root@ Oracle  ~]# free -m                                      total       used       free     shared    buffers     cached Mem:                            3383       3319          63           0         97       2395 -/+ buffers/cache:         826          2556 Swap:                           1983       195        1788 total 内存总数  used 已经使用的内存数 free 空闲的内存数 shared 多个进程共享的内存总额 说明,释放前最好sync一下,防止丢数据。  使用方式 :  sync  使用说明 : Linux 系统中欲写入硬盘的资料有的时候会了效率起见,      会写到 filesystem buffer 中,这个 buffer 是一块记忆体空间,      如果欲写入硬盘的资料存于此 buffer 中,而系统又突然断电的话,      那么资料就会流失了,sync 指令会将存于 buffer 中的资料强制写入硬盘中。   [root@oracle ~]#  echo 1 > /proc/sys/vm/drop_caches [root@oracle ~]#  sysctl -p [root@oracle ~]# free -m              total       used       free     shared    buffers     cached Mem:          3383       1952        1431           0          1       1136 -/+ buffers/cache:        814        2568 Swap:         1983        195        1788   说明: 1>. /proc是一个虚拟文件系统,我们可以通过对它的读写操作作为与kernel实体间进行通信的一种手段。也就是说可以通过修改/proc中的文件,来对当前kernel的行为做出调整。也就是说我们可以通过调整/proc/sys/vm/drop_caches来释放内存。 0 – 不释放 1 – 释放页缓存 2 – 释放dentries和inodes 3 – 释放所有缓存 数字1是用来清空最近放问过的文件页面缓存 数字2是用来清空文件节点缓存和目录项缓存 数字3是用来清空1和2所有内容的缓存。 2>. 关于drop_caches的官方说明如下: Writing to this file causes the kernel to drop clean caches,dentries and inodes from memory, causing that memory to becomefree. 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 first.   3>.  Linux 内核会将它最近访问过的文件页面缓存在内存中一段时间,这个文件缓存被称为pagecache。 Inode是linux/unix操作系统中的一种数据结构,包含了各文件相关的一些重要信息。在创建文件系统时,就会同时创建大量的inode。一般inode表会占用文件系统磁盘空间的1%。   目录项缓存(dcache)dentries   各参数含义: total:总物理内存 used:已使用内存 free:完全未被使用的内存 shared:应用程序共享内存 buffers:缓存,主要用于目录方面,inode值等 cached:缓存,用于已打开的文件 -buffers/cache:应用程序使用的内存大小,used减去缓存值 +buffers/cache:所有可供应用程序使用的内存大小,free加上缓存值   其中: total = used + free -buffers/cache=used-buffers-cached,这个是应用程序真实使用的内存大小 +buffers/cache=free+buffers+cached,这个是服务器真实还可利用的内存大小 [oracle@cddserver1 ~]$ free -m              total       used       free     shared    buffers     cached Mem:         32096      10379      21717          0         38       7942 -/+ buffers/cache:       2398      29698 Swap:        34287          0      34287 这里面的第二行才是真正服务器的空闲内存     2. Linux的内存分配方式 大家都知道,Linux服务器为了提高效率,会提前申请内存,即使这些内存没有被具体应用使用,Linux也会提前申请这些内存,然后利用这些内存做缓存用,即将刚打开的文件系统存入cache中,这样对应的服务器free值会越来越少,buffers和cached会越来越大,因此给大家表象就是内存越来越少了,大家就紧张了;其实,大家完全不用紧张,Linux服务器在发现内存不足时,会自动清理cached区域,释放内存,然后继续增大cache,free继续减少。因此,那样手动降低内存使用率的方法,其实就是图一时之快,呵呵。         echo 1 > /proc/sys/vm/drop_caches 可以暂时清空cache和buffer 在rhel5和 Ubuntu 上(rhel4不可以),可以直接修改内核文件 # /etc/sysctl.conf vm.drop_caches = 1 #sysctl -p     $ sync $ free -m              total       used       free     shared    buffers     cached Mem:         32096      30084       2011          0        590      26162 -/+ buffers/cache:       3332      28764 Swap:        34287          0      34287 echo 3 > /proc/sys/vm/drop_caches free -m   原本以为是oracle缓存占满了, 在SQLPLUS中输入 ALTER SYSTEM FLUSH BUFFER_CACHE; alter system flush shared_pool;  但是看了一下效果不明显  后面试试Linux清除ARP缓存 一、  arp -n|awk '/^[1-9]/ {print "arp -d "$1}' | sh 清除所有ARP缓存,推荐! 二、for((ip=2;ip<255;ip++));do arp -d 192.168.0.$ip &>/dev/null;done 清除192.168.0.0网段的所有缓存 三、arp -d IP 这样可以清除单一IP 的ARP缓存 注意:以上均需要root权限,尤其是最后一个,如果不再root下执行,则改为: arp -n|awk '/^[1-9]/ {print "arp -d "$1}' | sudo sh
    转载请注明原文地址: https://ju.6miu.com/read-10953.html

    最新回复(0)