qileilove

          blog已經(jīng)轉(zhuǎn)移至github,大家請(qǐng)?jiān)L問 http://qaseven.github.io/

          Linux系統(tǒng)查看內(nèi)存使用率

          Linux下看內(nèi)存和CPU使用率一般都用top命令,但是實(shí)際在用的時(shí)候,用top查看出來的內(nèi)存占用率都非常高,如:
            Mem:   4086496k total, 4034428k used,    52068k free,   112620k buffers
            Swap: 4192956k total,   799952k used, 3393004k free, 1831700k cached
            top –M看更直觀,以M為單位
            接近98.7%,而實(shí)際上的應(yīng)用程序占用的內(nèi)存往往并沒這么多,
            PID USER      PR NI VIRT RES SHR S %CPU %MEM    TIME+ COMMAND
            25801 sybase    15   0 2648m 806m 805m S 1.0 20.2 27:56.96 dataserver
            12084 oracle    16   0 1294m 741m 719m S 0.0 18.6   0:13.50 oracle
            27576 xugy      25   0 986m 210m 1040 S 1.0 5.3 28:51.24 cti
            25587 yaoyang   17   0 1206m 162m 3792 S 0.0 4.1   9:21.14 java
            看%MEM這列的數(shù)字,按內(nèi)存排序后,把前幾名加起來,撐死了才不過55%,那剩下的內(nèi)存都干嘛用了?
            一般的解釋是Linux系統(tǒng)下有一種思想,內(nèi)存不用白不用,占用了就不釋放,聽上去有點(diǎn)道理,但如果我一定要知道應(yīng)用程序還能有多少內(nèi)存可用呢?
            仔細(xì)看top關(guān)于內(nèi)存的顯示輸出,有兩個(gè)數(shù)據(jù)buffers和cached,在Linux系統(tǒng)下的buffer指的是磁盤寫緩存,而cache則指的是磁盤讀緩存。
            (A buffer is something that has yet to be "written" to disk.
            A cache is something that has been "read" from the disk and stored for later use.)
            而這兩塊是為了提高系統(tǒng)效率而分配的內(nèi)存,在內(nèi)存富余的時(shí)候,操作系統(tǒng)將空閑內(nèi)存利用起來,而有內(nèi)存需求時(shí),系統(tǒng)會(huì)釋放這部分的內(nèi)存供應(yīng)用程序使用。
            這樣,真正應(yīng)用程序可用的內(nèi)存就是free+buffer+cache,上面的例子就是:
            52068k + 112620k + 1831700k = 1996388k
            而已用內(nèi)存則是used-buffer-cache,上面的例子為:
            4034428k - 112620k - 1831700k = 2090108k
            Linux下查看內(nèi)存還有一個(gè)更方便的命令,free:
            $ free
            total       used       free     shared    buffers     cached
            Mem:       4086496    4034044      52452          0     112756    1831564
            -/+ buffers/cache:    2089724    1996772
            Swap:      4192956     799952    3393004
            Mem:這列就是用top命令看到的內(nèi)存使用情況,而-/+buffers/cache這列就是我們剛剛做的計(jì)算結(jié)果,used-buffer-cache/free+buffer+cache
            也可以加-m或者-g參數(shù)查看按MB或者GB換算的結(jié)果。
            $ free -m
            total       used       free     shared    buffers     cached
            Mem:          3990       3906         83          0         90       1786
            -/+ buffers/cache:       2029       1961
            Swap:         4094        781       3312
            這樣,真正應(yīng)用程序的內(nèi)存使用量就可以得出來了,上面的例子中內(nèi)存占用率為51.1%。
            例如:
            # free -m
            total       used       free     shared    buffers     cached
            Mem:               4229       2834       1395          0         62       2548
            -/+ buffers/cache:                223        4006    //物理內(nèi)存使用223M,剩余4006M
            Swap:               8001       0         8001

          posted on 2014-08-14 09:33 順其自然EVO 閱讀(3405) 評(píng)論(0)  編輯  收藏 所屬分類: linux

          <2014年8月>
          272829303112
          3456789
          10111213141516
          17181920212223
          24252627282930
          31123456

          導(dǎo)航

          統(tǒng)計(jì)

          常用鏈接

          留言簿(55)

          隨筆分類

          隨筆檔案

          文章分類

          文章檔案

          搜索

          最新評(píng)論

          閱讀排行榜

          評(píng)論排行榜

          主站蜘蛛池模板: 西充县| 塔河县| 阳春市| 芦山县| 瑞昌市| 湟源县| 明光市| 荥经县| 射洪县| 腾冲县| 佛坪县| 长宁县| 万源市| 东乡族自治县| 怀集县| 康定县| 湖南省| 阳信县| 濮阳市| 泗洪县| 鹿泉市| 雷山县| 辽宁省| 青川县| 沽源县| 博白县| 柳河县| 峨眉山市| 许昌市| 且末县| 赣榆县| 平邑县| 玉门市| 富川| 南昌县| 无为县| 佛冈县| 陆河县| 方城县| 盐城市| 根河市|