IT博客汇
  • 首页
  • 精华
  • 技术
  • 设计
  • 资讯
  • 扯淡
  • 权利声明
  • 登录 注册

    Linux中关于Cache Memory的介绍

    admin发表于 2012-10-19 09:57:12
    love 0

    最近在做性能优化时,遇到一个问题,系统中进程占用的内存没有那么多,但是通过TOP看到系统对实际物理内存接近满额,十分纳闷,后来问了同事

    才知道原来是Cache Memory占用了大量内存,上网查阅了相关资料,整理记录下。

    什么是Cache Memory

    当进程对磁盘中的文件大量读写时,Linux内核为了提升读写性能,会将文件在内存中进行缓存,这部分内存就是Cache Memory(缓存内存)。即使你的程序运行结束后,Cache Memory也不会自动释放。这就会导致你在Linux系统中程序频繁读写文件后,你会发现可用物理内存会很少。

    如何释放Cache Memory(缓存内存):

    用下面的命令可以释放Cache Memory:
    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

    free命令介绍

    total used free shared buffers cached
    Mem: 16425996 10727220 5698776 0 380904 9389832
    -/+ buffers/cache: 956484 15469512
    Swap: 8273464 212 8273252

    其中第一行用全局角度描述系统使用的内存状况:
    total——总物理内存
    used——已使用内存,一般情况这个值会比较大,因为这个值包括了cache+应用程序使用的内存
    free——完全未被使用的内存
    shared——应用程序共享内存
    buffers——缓存,主要用于目录方面,inode值等(ls大目录可看到这个值增加)
    cached——缓存,用于已打开的文件

    另外这里有一篇taobao的大牛对memory使用的介绍,很详细:http://blog.yufeng.info/archives/2456

    Linux下禁用Swap的方法

    1. swapoff -a : 禁用swap空间

    2. swapon -a : 开启swap空间

    您可能对下面文章也感兴趣:

    • 使用Bash中Complete自动补全命令
    • [shell学习笔记]sort、uniq、cut、paste和split用法详解
    • 关于pthread_cond_wait使用while循环判断的理解
    • linux通过Shell获得本机ip地址方法
    • 定时备份网站代码与数据的shell工具


沪ICP备19023445号-2号
友情链接