<menu id="w8yyk"><menu id="w8yyk"></menu></menu>
  • <dd id="w8yyk"><nav id="w8yyk"></nav></dd>
    <menu id="w8yyk"></menu>
    <menu id="w8yyk"><code id="w8yyk"></code></menu>
    <menu id="w8yyk"></menu>
    <xmp id="w8yyk">
    <xmp id="w8yyk"><nav id="w8yyk"></nav>
  • 網站首頁 > 物聯資訊 > 技術分享

    嵌入式 linux 查看內存

    2016-09-28 00:00:00 廣州睿豐德信息科技有限公司 閱讀
    睿豐德科技 專注RFID識別技術和條碼識別技術與管理軟件的集成項目。質量追溯系統、MES系統、金蝶與條碼系統對接、用友與條碼系統對接

    在Windows系統中查看內存的使用情況很簡單,想必大家都已經耳熟能詳了,那么在linux系統如何查看內存使用情況呢?下面和大家分享在Linux下查看內存使用情況的free命令:

      [root@scs-2 tmp]# free

      total used free shared buffers cached

      Mem: 3266180 3250004 16176 0 110652 2668236

      -/+ buffers/cache: 471116 2795064

      Swap: 2048276 80160 1968116

      下面是對這些數值的解釋:

      total:總計物理內存的大小。

      used:已使用多大。

      free:可用有多少。

      Shared:多個進程共享的內存總額。

      Buffers/cached:磁盤緩存的大小。

      第三行(-/+ buffers/cached):

      used:已使用多大。

      free:可用有多少。

      第四行就不多解釋了。

      區別:第二行(mem)的used/free與第三行(-/+ buffers/cache) used/free的區別。 這兩個的區別在于使用的角度來看,第一行是從OS的角度來看,因為對于OS,buffers/cached 都是屬于被使用,所以他的可用內存是16176KB,已用內存是3250004KB,其中包括,內核(OS)使用+Application(X, oracle,etc)使用的+buffers+cached.

      第三行所指的是從應用程序角度來看,對于應用程序來說,buffers/cached 是等于可用的,因為buffer/cached是為了提高文件讀取的性能,當應用程序需在用到內存的時候,buffer/cached會很快地被回收。

      所以從應用程序的角度來說,可用內存=系統free memory+buffers+cached。

      如上例:

      2795064=16176+110652+2668236

      接下來解釋什么時候內存會被交換,以及按什么方交換。 當可用內存少于額定值的時候,就會開會進行交換。

      如何看額定值:

      cat /proc/meminfo

      [root@scs-2 tmp]# cat /proc/meminfo

      MemTotal: 3266180 kB

      MemFree: 17456 kB

      Buffers: 111328 kB

      Cached: 2664024 kB

      SwapCached: 0 kB

      Active: 467236 kB

      Inactive: 2644928 kB

      HighTotal: 0 kB

      HighFree: 0 kB

      LowTotal: 3266180 kB

      LowFree: 17456 kB

      SwapTotal: 2048276 kB

      SwapFree: 1968116 kB

      Dirty: 8 kB

      Writeback: 0 kB

      Mapped: 345360 kB

      Slab: 112344 kB

      Committed_AS: 535292 kB

      PageTables: 2340 kB

      VmallocTotal: 536870911 kB

      VmallocUsed: 272696 kB

      VmallocChunk: 536598175 kB

      HugePages_Total: 0

      HugePages_Free: 0

      Hugepagesize: 2048 kB

      用free -m查看的結果:

      [root@scs-2 tmp]# free -m

      total used free shared buffers cached

      Mem: 3189 3173 16 0 107 2605

      -/+ buffers/cache: 460 2729

      Swap: 2000 78 1921

      查看/proc/kcore文件的大小(內存鏡像):

      [root@scs-2 tmp]# ll -h /proc/kcore

      -r——– 1 root root 4.1G Jun 12 12:04 /proc/kcore

      備注:

      占用內存的測量

      測量一個進程占用了多少內存,linux為我們提供了一個很方便的方法,/proc目錄為我們提供了所有的信息,實際上top等工具也通過這里來獲取相應的信息。

      /proc/meminfo 機器的內存使用信息

      /proc/pid/maps pid為進程號,顯示當前進程所占用的虛擬地址。

      /proc/pid/statm 進程所占用的內存

      [root@localhost ~]# cat /proc/self/statm

      654 57 44 0 0 334 0

      輸出解釋

      CPU 以及CPU0。。。的每行的每個參數意思(以第一行為例)為:

      參數 解釋 /proc//status

      Size (pages) 任務虛擬地址空間的大小 VmSize/4

      Resident(pages) 應用程序正在使用的物理內存的大小 VmRSS/4

      Shared(pages) 共享頁數 0

      Trs(pages) 程序所擁有的可執行虛擬內存的大小 VmExe/4

      Lrs(pages) 被映像到任務的虛擬內存空間的庫的大小 VmLib/4

      Drs(pages) 程序數據段和用戶態的棧的大小 (VmData+ VmStk )4

      dt(pages) 04

      查看機器可用內存

      /proc/28248/>free

      total used free shared buffers cached

      Mem: 1023788 926400 97388 0 134668 503688

      -/+ buffers/cache: 288044 735744

      Swap: 1959920 89608 1870312

      我們通過free命令查看機器空閑內存時,會發現free的值很小。這主要是因為,在linux中有這么一種思想,內存不用白不用,因此它盡可能的cache和buffer一些數據,以方便下次使用。但實際上這些內存也是可以立刻拿來使用的。

      所以 空閑內存=free+buffers+cached=total-used

    $ free -m
                 total       used       free     shared    buffers     cached
    Mem:         1002        769        232          0         62        421
    -/+ buffers/cache:        286        715
    Swap:         1153          0       1153

    第一部分Mem行:
    total 內存總數: 1002M
    used 已經使用的內存數: 769M
    free 空閑的內存數: 232M
    shared 當前已經廢棄不用,總是0
    buffers Buffer 緩存內存數: 62M
    cached Page 緩存內存數:421M

    關系:total(1002M) = used(769M) + free(232M)

    第二部分(-/+ buffers/cache):
    (-buffers/cache) used內存數:286M (指的第一部分Mem行中的used - buffers - cached)
    (+buffers/cache) free內存數: 715M (指的第一部分Mem行中的free + buffers + cached)

    可見-buffers/cache反映的是被程序實實在在吃掉的內存,而+buffers/cache反映的是可以挪用的內存總數。(從這里我們可以看出,實際上 :可用內存=第一部分Mem行中的free + buffers + cached,并不是只有free部分)


    第三部分是指交換分區, 我想不講大家都明白.

    我想大家看了上面,還是很暈.第一部分(Mem)與第二部分(-/+ buffers/cache)的結果中有關used和free為什么這么奇怪.
    其實我們可以從二個方面來解釋.
    對操作系統來講是Mem的參數.buffers/cached 都是屬于被使用,所以它認為free只有232.
    對應用程序來講是(-/+ buffers/cach).buffers/cached 是等同可用的,因為buffer/cached是為了提高程序執行的性能,當程序使用內存時,buffer/cached會很快地被使用。

    所以,以應用來看看,以(-/+ buffers/cache)的free和used為主.所以我們看這個就好了.另外告訴大家一些常識.Linux為了提高磁盤和內存存取效率, Linux做了很多精心的設計, 除了對dentry進行緩存(用于VFS,加速文件路徑名到inode的轉換), 還采取了兩種主要Cache方式:Buffer Cache和Page Cache。前者針對磁盤塊的讀寫,后者針對文件inode的讀寫。這些Cache能有效縮短了 I/O系統調用(比如read,write,getdents)的時間。

    記住內存是拿來用的,不是拿來看的.不象windows,無論你的真實物理內存有多少,他都要拿硬盤交換文件來讀.這也就是windows為什么常 常提示虛擬空間不足的原因.你們想想,多無聊,在內存還有大部分的時候,拿出一部分硬盤空間來充當內存.硬盤怎么會快過內存.所以我們看linux,只要 不用swap的交換空間,就不用擔心自己的內存太少.如果常常swap用很多,可能你就要考慮加物理內存了.這也是linux看內存是否夠用的標準哦.


    補充:cat /proc/meminfo

    可以查看內存的詳細使用情況,free的結果由此文件生成。

    RFID管理系統集成商 RFID中間件 條碼系統中間層 物聯網軟件集成
    最近免费观看高清韩国日本大全