linux清楚oracle缓存,如何清除Linux缓存?linux清除缓存命令,释放Linux操作系统文件缓存...

如何清除Linux缓存?linux清除缓存命令,释放Linux操作系统文件缓存

来源:本站原创 浏览:544次 时间:2015-04-18

今天用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

在Linux操作系统中,我们一般不需要去释放内存,因为系统已经将内存管理的很好。但是凡事也有例外,比如:1)当内存被缓存占用掉,导致系统使用SWAP空间并最终影响了系统性能;2)有些环境上部署了监控软件用于检测内存使用率的,那么当内存使用率达到一定上限(例如:80%)时,就会报警。因此在这些场景中,就需要执行释放内存(清理缓存)的操作了。

Linux系统的缓存机制是相当先进的,他会针对dentry(用于VFS,加速文件路径名到inode的转换)、Buffer Cache(针对磁盘块的读写)和Page Cache(针对文件inode的读写)进行缓存操作。但是在进行了大量文件操作之后,缓存会把内存资源基本用光。但实际上我们文件操作已经完成,这部分缓存已经用不到了。这个时候,我们难道只能眼睁睁的看着缓存把内存空间占据掉么?

所以,我们还是有必要来手动进行Linux下释放内存的操作,其实也就是释放缓存的操作了。

要达到释放缓存的目的,我们首先需要了解下关键的配置文件/proc/sys/vm/drop_caches。这个文件中记录了缓存释放的参数,默认值为0,也就是不释放缓存。他的值可以为0~3之间的任意数字,代表着不同的含义:

0 – 不释放

1 – 释放页缓存

2 – 释放dentries和inodes

3 – 释放所有缓存

知道了参数后,我们就可以根据我们的需要,使用下面的指令来进行操作。

首先我们需要使用sync指令,将所有未写的系统缓冲区写到磁盘中,包含已修改的 i-node、已延迟的块 I/O 和读写映射文件。否则在释放缓存的过程中,可能会丢失未保存的文件。

#sync

接下来,我们需要将需要的参数写进/proc/sys/vm/drop_caches文件中,比如我们需要释放所有缓存,就输入下面的命令:

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

此指令输入后会立即生效,可以查询现在的可用内存明显的变多了。

要查询当前缓存释放的参数,可以输入下面的指令:

#cat /proc/sys/vm/drop_caches

下面我们来看一个实际测试:

先看看内存使用状况

[root@node1 ~]# free -m

total used free shared buffers cached

Mem: 8004 6557 1446 0 163 5630

-/+ buffers/cache: 763 7240

Swap: 1983 0 1983

把内存里的数据暂时写到硬盘里

[root@node1 ~]# sync

修改/proc/sys/vm/drop_caches文件

[root@node1 ~]# echo 3 > /proc/sys/vm/drop_caches

[root@node1 ~]# cat /proc/sys/vm/drop_caches

再看内存,终于释放出来了。

[root@node1 ~]# free -m

total used free shared buffers cached

Mem: 8004 631 7372 0 0 60

-/+ buffers/cache: 570 7433

Swap: 1983 0 1983

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值