<meter id="pryje"><nav id="pryje"><delect id="pryje"></delect></nav></meter>
          <label id="pryje"></label>

          新聞中心

          EEPW首頁(yè) > 嵌入式系統(tǒng) > 設(shè)計(jì)應(yīng)用 > Linux內(nèi)存使用的體會(huì)

          Linux內(nèi)存使用的體會(huì)

          作者: 時(shí)間:2007-05-23 來(lái)源:網(wǎng)絡(luò) 收藏

          ,實(shí)際上跟windows的有很相像的地方,都是用虛擬內(nèi)存這個(gè)的概念,說(shuō)到這里不得不罵MS,為什么在很多時(shí)候還有很大的物理內(nèi)存的時(shí)候,卻還是用到了pagefile. 所以才經(jīng)常要跟一幫人吵著說(shuō)Pagefile的大小,以及如何分配這個(gè)問(wèn)題,在大家就不用再吵什么swap大小的問(wèn)題,我個(gè)人認(rèn)為,swap設(shè)個(gè)512M已經(jīng)足夠了,如果你問(wèn)說(shuō)512M的SWAP不夠用怎么辦?只能說(shuō)大哥你還是加內(nèi)存吧,要不就檢查你的應(yīng)用,是不是真的出現(xiàn)了memory leak.

          下查看內(nèi)存我們一般用command free
          [root@nonamelinux ~]# free
          total used free shared buffers cached
          Mem: 386024 377116 8908 0 21280 155468
          -/+ buffers/cache: 200368 185656
          Swap: 393552 0 393552
          下面是對(duì)這些數(shù)值的解釋?zhuān)?
          第二行(mem):
          total:總計(jì)物理內(nèi)存的大小。
          used:已使用多大。
          free:可用有多少。
          Shared:多個(gè)進(jìn)程共享的內(nèi)存總額。
          Buffers/cached:磁盤(pán)緩存的大小。
          第三行(-/+ buffers/cached):
          used:已使用多大。
          free:可用有多少。
          第四行就不多解釋了。
          區(qū)別:
          第二行(mem)的used/free與第三行(-/+ buffers/cache) used/free的區(qū)別。
          這兩個(gè)的區(qū)別在于使用的角度來(lái)看,第一行是從OS的角度來(lái)看,因?yàn)閷?duì)于OS,buffers/cached 都是屬于被使用,所以他的可用內(nèi)存是8908KB,已用內(nèi)存是377116KB,其中包括,內(nèi)核(OS)使用+Application(X,oracle,etc)使用的+buffers+cached.
          第三行所指的是從應(yīng)用程序角度來(lái)看,對(duì)于應(yīng)用程序來(lái)說(shuō),buffers/cached 是等于可用的,因?yàn)閎uffer/cached是為了提高文件讀取的性能,當(dāng)應(yīng)用程序需在用到內(nèi)存的時(shí)候,buffer/cached會(huì)很快地被回收。
          所以從應(yīng)用程序的角度來(lái)說(shuō),可用內(nèi)存=系統(tǒng)free memory+buffers+cached.
          如上例:
          185656=8908+21280+155468
          接下來(lái)解釋什么時(shí)候內(nèi)存會(huì)被交換,以及按什么方交換。
          當(dāng)可用內(nèi)存少于額定值的時(shí)候,就會(huì)開(kāi)會(huì)進(jìn)行交換.
          如何看額定值(RHEL4.0):
          #cat /proc/meminfo
          交換將通過(guò)三個(gè)途徑來(lái)減少系統(tǒng)中使用的物理頁(yè)面的個(gè)數(shù): 
          1.減少緩沖與頁(yè)面cache的大小,
          2.將系統(tǒng)V類(lèi)型的內(nèi)存頁(yè)面交換出去, 
          3.換出或者丟棄頁(yè)面。(Application 占用的內(nèi)存頁(yè),也就是物理內(nèi)存不足)。
          事實(shí)上,少量地使用swap是不是影響到系統(tǒng)性能的。

          本文引用地址:http://www.ex-cimer.com/article/258124.htm

          下面是buffers與cached的區(qū)別。
          buffers是指用來(lái)給塊設(shè)備做的緩沖大小,他只記錄文件系統(tǒng)的metadata以及 tracking in-flight pages.
          cached是用來(lái)給文件做緩沖。
          那就是說(shuō):buffers是用來(lái)存儲(chǔ),目錄里面有什么內(nèi)容,權(quán)限等等。
          而cached直接用來(lái)記憶我們打開(kāi)的文件,如果你想知道他是不是真的生效,你可以試一下,先后執(zhí)行兩次命令#man X ,你就可以明顯的感覺(jué)到第二次的開(kāi)打的速度快很多。
          實(shí)驗(yàn):在一臺(tái)沒(méi)有什么應(yīng)用的機(jī)器上做會(huì)看得比較明顯。記得實(shí)驗(yàn)只能做一次,如果想多做請(qǐng)換一個(gè)文件名。
          #free
          #man X
          #free
          #man X
          #free
          你可以先后比較一下free后顯示buffers的大小。
          另一個(gè)實(shí)驗(yàn):
          #free
          #ls /dev
          #free
          你比較一下兩個(gè)的大小,當(dāng)然這個(gè)buffers隨時(shí)都在增加,但你有l(wèi)s過(guò)的話,增加的速度會(huì)變得快,這個(gè)就是buffers/chached的區(qū)別。

          linux操作系統(tǒng)文章專(zhuān)題:linux操作系統(tǒng)詳解(linux不再難懂)


          關(guān)鍵詞: 內(nèi)存管理 Linux

          評(píng)論


          相關(guān)推薦

          技術(shù)專(zhuān)區(qū)

          關(guān)閉
          看屁屁www成人影院,亚洲人妻成人图片,亚洲精品成人午夜在线,日韩在线 欧美成人 (function(){ var bp = document.createElement('script'); var curProtocol = window.location.protocol.split(':')[0]; if (curProtocol === 'https') { bp.src = 'https://zz.bdstatic.com/linksubmit/push.js'; } else { bp.src = 'http://push.zhanzhang.baidu.com/push.js'; } var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(bp, s); })();