linux查看cache中文件,linux 文件cache机制

周四到客户处进行benchmark,客户处的

OS为tuborlinux,16G physical memroy结果使用top命令发现,系统的free内存很小,只有80M,但是数据库的SGA只使用了1.5G,使用V$process查询PGA的使用量为40M,有14个多G的内存不知去向,用ps命令查看也没发现哪个进程在大量的使用内存,把数据库shutdown后,该14G内存仍然没有回收,虽然性能没有什么很大的影响,但是这种现象挺疑惑。

经过几次测试,发现只要数据库访问某一个索引后,内存就会被吃掉。后来发现该索引所在的数据文件大约为14G,并且free命令显示cache部分的内存增加了14G左右,所以应该是linux操作系统把剩余的内存用作文件缓存了。那如何释放这部分的内存呢,到网上查询了一些资料如下:

linux下释放cache内存

细心的朋友会注意到,当你在linux下频繁存取文件后,物理内存会很快被用光,当程序结束后,内存不会被正常释放,而是一直作为caching.这个问题,貌似有不少人在问,不过都没有看到有什么很好解决的办法.那么我来谈谈这个问题.

先来说说free命令

[root@server ~]# free -m

total       used       free     shared    buffers     cached

Mem:           249        163         86          0         10         94

-/+ buffers/cache:         58        191

Swap:          511          0        511

其中:

total 内存总数

used 已经使用的内存数

free 空闲的内存数

shared 多个进程共享的内存总额

buffers Buffer Cache和cached Page Cache 磁盘缓存的大小

-buffers/cache 的内存数:used - buffers - cached

+buffers/cache 的内存数:free + buffers + cached

可用的memory=free memory+buffers+cached

有了这个基础后,可以得知,我现在used为163MB,free为86,buffer和cached分别为10,94

那么我们来看看,如果我执行复制文件,内存会发生什么变化.

[root@server ~]# cp -r /etc ~/test/

[root@server ~]# free -m

total       used       free     shared    buffers     cached

Mem:           249        244          4          0          8        174

-/+ buffers/cache:         62        187

Swap:          511          0        511

在我命令执行结束后,used为244MB,free为4MB,buffers为8MB,cached为174MB,天呐都被cached吃掉了.别紧张,这是为了提高文件读取效率的做法.

引用[url][/url] 为了提高磁盘存取效率, Linux做了一些精心的设计, 除了对dentry进行缓存(用于VFS,加速文件路径名到inode的转换), 还采取了两种主要Cache方式:Buffer Cache和Page Cache。前者针对磁盘块的读写,后者针对文件inode的读写。这些Cache有效缩短了 I/O系统调用(比如read,write,getdents)的时间。"

那么有人说过段时间,linux会自动释放掉所用的内存,我们使用free再来试试,看看是否有释放>?

[root@server test]# free -m

total       used       free     shared    buffers     cached

Mem:           249        244          5          0          8        174

-/+ buffers/cache:         61        188

Swap:          511          0        511

MS没有任何变化,那么我能否手动释放掉这些内存呢???回答是可以的!

/proc 是一个虚拟文件系统,我们可以通过对它的读写操作做为与kernel实体间进行通信的一种手段.也就是说可以通过修改/proc中的文件,来对当前 kernel的行为做出调整.那么我们可以通过调整/proc/sys/vm/drop_caches来释放内存.操作如下:

[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.

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/8052309/viewspace-625283/,如需转载,请注明出处,否则将追究法律责任。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Linux系统,虚拟文件系统(Virtual File System,VFS)是一个抽象层,用于统一管理不同文件系统的接口和操作。它提供了一种统一的文件系统访问方式,使得应用程序可以透明地处理不同类型的文件系统,而无需关心底层文件系统的差异。 虚拟文件系统的管理机制主要包括以下几个方面: 1. VFS数据结构:VFS维护了一些重要的数据结构,如超级块(superblock)、索引节点(inode)、文件描述符(file descriptor)等。这些数据结构用于表示文件系统的状态和属性,并提供了对文件和目录的访问接口。 2. 文件系统注册:在Linux系统启动时,各个文件系统需要向VFS注册自己的操作函数和属性。这样,当用户程序请求访问某个文件系统时,VFS可以根据文件路径的前缀判断应该使用哪个文件系统的操作函数。 3. 文件路径解析:当用户程序提供一个文件路径时,VFS负责将路径解析为具体的文件系统和索引节点。它会逐级搜索路径的目录,并调用相应文件系统的操作函数进行路径解析和权限检查。 4. 文件缓存管理:为了提高文件访问效率,VFS采用了文件缓存(Page Cache机制。它将最近访问的文件块缓存在内存,避免频繁的磁盘访问。文件缓存使用了LRU(Least Recently Used)算法来管理缓存文件块。 5. 文件系统挂载:在Linux系统,可以通过挂载操作将一个文件系统关联到指定的挂载点上。VFS负责管理已挂载的文件系统,并提供了挂载、卸载和重新挂载等操作接口。挂载点形成了一个文件系统的树状结构,称为虚拟文件系统表(Virtual File System Table)。 通过这些机制,VFS实现了对不同文件系统的抽象和统一管理。它使得用户程序可以通过统一的文件系统接口进行文件操作,而无需关心底层文件系统的具体细节。这为Linux系统的灵活性和可扩展性提供了基础。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值