• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            posts - 297,  comments - 15,  trackbacks - 0

            細心的朋友會注意到,當你在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吃掉了.別緊張,這是為了提高文件讀取效率的做法.

            引用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.

            轉自
            http://blog.chinaunix.net/u2/76292/showart_1334673.html
            posted on 2009-12-07 23:57 chatler 閱讀(308) 評論(0)  編輯 收藏 引用 所屬分類: Linux_Coding
            <2010年4月>
            28293031123
            45678910
            11121314151617
            18192021222324
            2526272829301
            2345678

            常用鏈接

            留言簿(10)

            隨筆分類(307)

            隨筆檔案(297)

            algorithm

            Books_Free_Online

            C++

            database

            Linux

            Linux shell

            linux socket

            misce

            • cloudward
            • 感覺這個博客還是不錯,雖然做的東西和我不大相關,覺得看看還是有好處的

            network

            OSS

            • Google Android
            • Android is a software stack for mobile devices that includes an operating system, middleware and key applications. This early look at the Android SDK provides the tools and APIs necessary to begin developing applications on the Android platform using the Java programming language.
            • os161 file list

            overall

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

            久久精品国产亚洲AV香蕉| 国产精品女同久久久久电影院| 久久久久久毛片免费看| 无码国内精品久久综合88| 91精品国产综合久久婷婷| 久久伊人五月天论坛| 狠狠色丁香久久综合五月| 狠狠色丁香久久婷婷综合图片| 人人狠狠综合久久亚洲婷婷| 久久久久久精品免费免费自慰| 91久久精品91久久性色| 综合久久国产九一剧情麻豆| 精品久久人人妻人人做精品| 99久久精品毛片免费播放| 麻豆精品久久久久久久99蜜桃| 精品视频久久久久| 人人狠狠综合久久亚洲88| 国产99久久精品一区二区| 亚洲精品乱码久久久久久按摩| 亚洲色欲久久久久综合网| 久久亚洲电影| 无夜精品久久久久久| 久久久国产精品| 久久人人爽人人澡人人高潮AV| 色综合久久久久| 久久婷婷久久一区二区三区| 久久久无码一区二区三区| 浪潮AV色综合久久天堂| 婷婷久久久亚洲欧洲日产国码AV| 囯产精品久久久久久久久蜜桃| 色青青草原桃花久久综合| 久久SE精品一区二区| 色欲综合久久躁天天躁蜜桃| 久久亚洲精品无码AV红樱桃| 国产麻豆精品久久一二三| 久久精品国产精品亚洲精品| 久久久久久综合一区中文字幕| 狠狠色综合久久久久尤物| 久久婷婷色综合一区二区| 一级做a爰片久久毛片毛片| 国产亚洲精品久久久久秋霞 |