Linux中Memory與Swap內存學習整理

1.背景介紹

  這篇文章介紹一下Linux中swap與memory。對於memory沒什麼可說的就是機器的物理內存,讀寫速度低於cpu一個量級,可是高於磁盤不止一個量級。因此,程序和數據若是在內存的話,會有很是快的讀寫速度。可是,內存的造價是要高於磁盤的,雖然相對來講價格一直在下降。除此以外,內存的斷電丟失數據也是一個緣由說不能把全部數據和程序都保存在內存中。既然不能所有使用內存,那數據還有程序確定不可能一直霸佔在內存中。當內存沒有可用的,就必需要把內存中不常常運行的程序給踢出去。可是踢到哪裏去,這時候swap就出現了。 swap全稱爲swap place,即交換區,當內存不夠的時候,被踢出的進程被暫時存儲到交換區。當須要這條被踢出的進程的時候,就從交換區從新加載到內存,不然它不會主動交換到真實內存中。

2.swap介紹

  在詳細介紹swap以前,咱們須要知道的是計算機對內存分爲物理內存與虛擬內存(注意虛擬內存和虛擬地址空間的區別)。物理內存就是計算機的實際內存大小,由RAM芯片組成的。虛擬內存則是虛擬出來的、使用磁盤代替內存。虛擬內存的出現,讓機器內存不夠的狀況獲得部分解決。當程序運行起來由操做系統作具體虛擬內存到物理內存的替換和加載(相應的頁與段的虛擬內存管理)。 這裏的虛擬內存即所謂的swap
  當用戶提交程序,而後產生進程,在機器上運行。機器會判斷當前物理內存是否還有空閒容許進程調入內存運行,若是有那麼則直接調入內存進行運行;若是沒有,那麼會根據優先級選擇一個進程掛起,把該進程交換到swap中等待,而後把新的進程調入到內存中運行。根據這種換入和換出,實現了內存的循環利用,讓用戶感受不到內存的限制。從這也能夠看出swap扮演了一個很是重要的角色,就是暫存被換出的進程。  內存與swap之間是按照內存頁爲單位來交換數據的,通常Linux中頁的大小設置爲4kb。而內存與磁盤則是按照塊來交換數據的。

3.swap的設置

  從上能夠看出,當物理內存使用完或者達到必定比例以後,咱們可使用swap作臨時的內存使用。當物理內存和swap都被使用完那麼就會出錯,out of memory。對於使用多大比例內存以後開始使用swap,在系統的配置文件中能夠經過調整參數進行修改。cat  /proc/sys/vm/swappiness 60
該參數能夠從0-100進行設置。0就是最大限度使用內存,儘可能不使用swap;100就是積極使用swap。這個具體的經過系統的算法進行肯定。
 物理內存咱們是沒法更改的,因此swap的大小設置將會影響應用可否正常運行。那麼swap大小如何肯定。根據centos官網介紹能夠得出以下公式:M = Amount of RAM in GB, and S = Amount of swap in GB, then If M < 2, S = M *2 Else S = M + 2。並且其最小不該該小於32M(never less than 32 MB.)。
  swap分區的數量對性能也有很大的影響。由於swap畢竟仍是以磁盤來假裝成內存,交換的操做是磁盤IO的操做而不是內存的load與store操做。若是有多個swap交換區,每一個swap會有必定的優先級,該優先級也能夠調整。swap空間的分配會以輪流的方式操做於全部的swap,這樣會大大均衡IO的負載,加快swap交換的速度。
四:swap相關命令
  swapon/swapoff swap-disk_name:啓動和關閉相應的swap_disk_name
  swapon -s :能夠查看當期swap的使用狀況,也能夠經過 cat /proc/swaps命令查看
 

四、linux的swap內存

通常狀況下不會用到swap的,通常物理內存使用在90%以上(默認是這個數,能夠自行在/etc/sysctl.conf裏設置vm.swappiness參數),但有的時候,內存會被緩存佔用,致使系統開始使用swap空間,此時就須要清理下swap了 這裏先說下vm.swappiness參數,設置成vm.swappiness=10:就是說當內存使用90%以上纔會使用swap空間 node

第一步:先執行sync命令linux

 #sync算法

sync命令用於強制被改變的內容馬上寫入磁盤,更新超塊信息,以防止釋放,sync命令則可用來強制將內存緩衝區中的數據當即寫入磁盤中。centos

第二步:(若是僅僅是清理swap的話,這一步能夠不執行)緩存

#echo 3 > /proc/sys/vm/drop_caches1oracle

此指令輸入當即生效,意在釋放全部緩存。 關於drop_caches: drop_caches的詳細文檔以下: Writing to this will cause the kernel to drop clean caches, dentries and inodes from memory, causing that memory to become free. To free pagecache: * echo 1 > /proc/sys/vm/drop_caches To free dentries and inodes: * echo 2 > /proc/sys/vm/drop_caches To free pagecache, dentries and inodes: * echo 3 > /proc/sys/vm/drop_caches As this is a non-destructive operation, and dirty objects are notfreeable, the user should run 「sync」 first in order to make sure allcached objects are freed. This tunable was added in 2.6.16. **echo 1:釋放頁面緩存 echo 2:釋放目錄文件和inodes echo 3:釋放全部緩存(頁面緩存,目錄文件和inodes)** 以下圖是執行完echo3 的cache的對比:app

 

第三步:關閉swap,再開戶swapless

#swapoff -a #swapon -a12ide

  如今看swap的used的那一項爲零了,說明已經清空工具

 

在Linux下查看內存咱們通常用free命令:

[root@scs-2 tmp]# free

    total         used         free        shared    buffers     cached

Mem:  3266180   3250004    16176        0         110652     2668236

Swap: 2048276   80160    1968116

下面是對Linux查看內存命令中這些數值的解釋:

total:總計物理內存的大小。 used:已使用多大。 free:可用有多少。 Shared:多個進程共享的內存總額。 Buffers/cached:磁盤緩存的大小。

 區別:第二行(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

接下來解釋何時內存會被交換,以及按什麼方交換。 當可用內存少於額定值的時候,就會開會進行交換。 Linux查看內存命令時如何看額定值: 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

Linux查看內存命令的輸出解釋 CPU 以及CPU0。。。的每行的每一個參數意思(以第一行爲例)爲:

參數 解釋 /proc//status Size (pages) 任務虛擬地址空間的大小 VmSize/4 Resident(pages) 應用程序正在使用的物理內存的大小 VmRSS/4 Shared(pages) 共享頁數 \ 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

相關文章
相關標籤/搜索