• <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
            <2010年9月>
            2930311234
            567891011
            12131415161718
            19202122232425
            262728293012
            3456789

            常用鏈接

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

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

            国产99久久久国产精品~~牛| 亚洲AV无码一区东京热久久| 色综合久久综精品| 国内精品久久久久久久影视麻豆| 久久久久无码精品| 久久丫精品国产亚洲av| 国产69精品久久久久99| 久久精品国产亚洲AV忘忧草18| 97久久久精品综合88久久| 久久久艹| 夜夜亚洲天天久久| 久久天天躁狠狠躁夜夜网站| 麻豆久久| 91精品免费久久久久久久久| 亚洲精品乱码久久久久66| 国产精品VIDEOSSEX久久发布| 色诱久久久久综合网ywww| 亚洲国产成人精品久久久国产成人一区二区三区综 | 国产精品久久久久蜜芽| 国产精品gz久久久| 国产精品久久久久久久久| 97久久国产综合精品女不卡| 久久综合色区| 久久人人超碰精品CAOPOREN| 国产巨作麻豆欧美亚洲综合久久| 欧美黑人又粗又大久久久| 久久无码AV一区二区三区| 久久久久亚洲AV成人网人人网站| 久久A级毛片免费观看| 亚洲午夜久久久久久久久久| 久久婷婷午色综合夜啪| 无码任你躁久久久久久久| 污污内射久久一区二区欧美日韩| 久久久久亚洲精品无码网址| 久久久久国产一区二区三区| 久久强奷乱码老熟女| 欧美亚洲另类久久综合婷婷 | 性欧美大战久久久久久久| 久久人人爽人人爽人人片AV麻豆| 久久精品国产一区二区三区| 无码任你躁久久久久久|