• <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 閱讀(305) 評論(0)  編輯 收藏 引用 所屬分類: Linux_Coding
            <2009年5月>
            262728293012
            3456789
            10111213141516
            17181920212223
            24252627282930
            31123456

            常用鏈接

            留言簿(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

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

            久久精品一区二区国产| 久久天天躁狠狠躁夜夜网站| 91久久福利国产成人精品| 精品人妻伦九区久久AAA片69| 久久无码人妻精品一区二区三区 | 久久午夜夜伦鲁鲁片免费无码影视| 久久亚洲高清综合| 久久久久亚洲AV无码网站| 精品国产婷婷久久久| 久久热这里只有精品在线观看| 91久久精品无码一区二区毛片| 狠狠色丁香久久婷婷综合| 国产ww久久久久久久久久| 伊人久久久AV老熟妇色| 亚洲国产成人精品91久久久| 国产精品久久久久…| 亚洲人成精品久久久久| 久久精品国产亚洲一区二区三区 | 精品久久久久香蕉网| 综合久久精品色| 超级碰久久免费公开视频| 久久久婷婷五月亚洲97号色 | 久久精品国产亚洲AV麻豆网站| 亚洲精品午夜国产va久久| 久久电影网| 精品国产热久久久福利| 国产福利电影一区二区三区久久久久成人精品综合 | 国产69精品久久久久99| 一本一道久久a久久精品综合| 99久久精品免费| 国产午夜精品理论片久久影视| 一本色道久久99一综合| 久久天天躁狠狠躁夜夜不卡| 久久久国产99久久国产一| 三级韩国一区久久二区综合| 国内精品欧美久久精品| 国产福利电影一区二区三区久久老子无码午夜伦不 | 久久久国产精品福利免费 | 久久久久国产精品麻豆AR影院| 久久线看观看精品香蕉国产| 久久精品国产福利国产秒|