1、緩存機制介紹node
在Linux系統中,爲了提升文件系統性能,內核利用一部分物理內存分配出緩衝區,用於緩存系統操做和數據文件,當內核收到讀寫的請求時,內核先去緩存區找是否有請求的數據,有就直接返回,若是沒有則經過驅動程序直接操做磁盤。
緩存機制優勢:減小系統調用次數,下降CPU上下文切換和磁盤訪問頻率。
CPU上下文切換:CPU給每一個進程必定的服務時間,當時間片用完後,內核從正在運行的進程中收回處理器,同時把進程當前運行狀態保存下來,而後加載下一個任務,這個過程叫作上下文切換。實質上就是被終止運行進程與待運行進程的進程切換。linux
Swap用途:Swap意思是交換分區,一般咱們說的虛擬內存,是從硬盤中劃分出的一個分區。當物理內存不夠用的時候,內核就會釋放緩存區(buffers/cache)裏一些長時間不用的程序,而後將這些程序臨時放到Swap中,也就是說若是物理內存和緩存區內存不夠用的時候,纔會用到Swap。
swap清理:swapoff -a && swapon -a
注意:這樣清理有個前提條件,空閒的內存必須比已經使用的swap空間大緩存
2、查看緩存區及內存使用狀況bash
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
|
free
命令用於檢測物理內存和交換內存已使用量和可用量(默認單位爲KB)
[root@backup ~]
# free -m //使用-m參數表示以兆字節爲單位顯示內存
total used
free
shared buffers cached
Mem: 64181 44372 19809 3 12 216
-/+ buffers
/cache
: 44143 20038
Swap: 32767 0 32767
第一部分Mem行解釋:
total:內存總數;
used:已經使用的內存數;
free
:空閒的內存數;
shared:當前已經廢棄不用;
buffers Buffer:緩存內存數;
cached Page:緩存內存數。
關係:total = used +
free
第二部分(-/+ buffers
/cache
)解釋:
(-buffers
/cache
) used內存數:第一部分Mem行中的 used – buffers – cached
(+buffers
/cache
)
free
內存數: 第一部分Mem行中的
free
+ buffers + cached
可見-buffers
/cache
反映的是被程序實實在在吃掉的內存,而+buffers
/cache
反映的是能夠挪用的內存總數。
第三部分是指交換分區。
---------------------------------------------------------------------------------------------
以字節爲單位顯示內存
加上-b參數的
free
命令,以字節爲單位顯示內存的大小。
[root@backup ~]
# free -b
total used
free
shared buffers cached
Mem: 67299549184 46525181952 20774367232 3272704 12820480 227033088
-/+ buffers
/cache
: 46285328384 21014220800
Swap: 34359734272 0 34359734272
-------------------------------------------------------------------------------------------
以千字節爲單位顯示內存
加上-k參數的
free
命令(默認單位,因此能夠不用使用它),以(KB)千字節爲單位顯示內存大小。
[root@backup ~]
# free -k
total used
free
shared buffers cached
Mem: 65722216 45435760 20286456 3196 12520 221712
-/+ buffers
/cache
: 45201528 20520688
Swap: 33554428 0 33554428
-------------------------------------------------------------------------------------------
以千兆字節爲單位顯示內存
使用-g爲參數,將會以GB(千兆字節)爲單位顯示內存大小。
[root@backup ~]
# free -g
total used
free
shared buffers cached
Mem: 62 43 19 0 0 0
-/+ buffers
/cache
: 43 19
Swap: 31 0 31
------------------------------------------------------------------------------------------
按期時間間隔更新內存狀態
-s選項加上一個整數,用來在按期時間間隔內更新
free
命令。舉個例子,下面的命令將會在每5秒更新一個
free
命令。
[root@backup ~]
# free -s 5
total used
free
shared buffers cached
Mem: 65722216 45436660 20285556 3196 12712 222096
-/+ buffers
/cache
: 45201852 20520364
Swap: 33554428 0 33554428
total used
free
shared buffers cached
Mem: 65722216 45436592 20285624 3196 12720 222096
-/+ buffers
/cache
: 45201776 20520440
Swap: 33554428 0 33554428
|
3、buffers和cached解釋服務器
=========================================================
緩存(cached)是把讀取過的數據保存起來,從新讀取時若命中(找到須要的數據)就不要去讀硬盤了,若沒有命中就讀硬盤。其中的數據會根據讀取頻率進行組織,把最頻繁讀取的內容放在最容易找到的位置,把再也不讀的內容不斷日後排,直至從中刪除。網絡
緩衝(buffers)是根據磁盤的讀寫設計的,把分散的寫操做集中進行,減小磁盤碎片和硬盤的反覆尋道,從而提升系統性能。linux有一個守護進程按期清空緩衝內容(即寫入磁盤),也能夠經過sync命令手動清空緩衝。舉個例子吧:我這裏有一個ext2的U盤,我往裏面cp一個3M的MP3,但U盤的燈沒有跳動,過了一下子(或者手動輸入sync)U盤的燈就跳動起來了。卸載設備時會清空緩衝,因此有些時候卸載一個設備時要等上幾秒鐘。app
修改/etc/sysctl.conf中的vm.swappiness右邊的數字能夠在下次開機時調節swap使用策略。該數字範圍是0~100,數字越大越傾向於使用swap。默認爲60,能夠改一下試試。–二者都是RAM中的數據。性能
二者都是RAM中的數據,簡單來講,buffer是即將要被寫入磁盤的,而cache是被從磁盤中讀出來的。
buffer是由各類進程分配的,被用在如輸入隊列等方面。一個簡單的例子如某個進程要求有多個字段讀入,在全部字段被讀入完整以前,進程把先前讀入的字段放在buffer中保存。
cache常常被用在磁盤的I/O請求上,若是有多個進程都要訪問某個文件,因而該文件便被作成cache以方便下次被訪問,這樣可提升系統性能。
========================================================學習
Cache:緩衝區,高速緩存,是位於CPU與主內存間的一種容量較小但速度很高的存儲器。因爲CPU的速度遠高於主內存,CPU直接從內存中存取數據要等待必定時間週期,Cache中保存着CPU剛用過或循環使用的一部分數據,當CPU再次使用該部分數據時可從Cache中直接調用,這樣就減小了CPU的等待時間,提升了系統的效率。Cache又分爲一級Cache(L1 Cache)和二級Cache(L2 Cache),L1 Cache集成在CPU內部,L2 Cache早期通常是焊在主板上,如今也都集成在CPU內部,常見的容量有256KB或512KB L2 Cache。它是根據程序的局部性原理而設計的,就是cpu執行的指令和訪問的數據每每在集中的某一塊,因此把這塊內容放入cache後,cpu就不用在訪問內存了,這就提升了訪問速度。固然若cache中沒有cpu所須要的內容,仍是要訪問內存的。從內存讀取與磁盤讀取角度考慮,cache能夠理解爲操做系統爲了更高的讀取效率,更多的使用內存來緩存可能被再次訪問的數據。spa
Cache並非緩存文件的,而是緩存塊的(塊是I/O讀寫最小的單元);Cache通常會用在I/O請求上,若是多個進程要訪問某個文件,能夠把此文件讀入Cache中,這樣下一個進程獲取CPU控制權並訪問此文件直接從Cache讀取,提升系統性能。
Buffer:緩衝區,一個用於存儲速度不一樣步的設備或優先級不一樣的設備之間傳輸數據的區域。經過buffer能夠減小進程間通訊須要等待的時間,當存儲速度快的設備與存儲速度慢的設備進行通訊時,存儲慢的數據先把數據存放到buffer,達到必定程度存儲快的設備再讀取buffer的數據,在此期間存儲快的設備CPU能夠幹其餘的事情。
Buffer:通常是用在寫入磁盤的,例如:某個進程要求多個字段被讀入,當全部要求的字段被讀入以前已經讀入的字段會先放到buffer中。Buffer是根據磁盤的讀寫設計的,把分散的寫操做集中進行,減小磁盤碎片和硬盤的反覆尋道,從而提升系統性能。linux有一個守護進程按期清空緩衝內容(即寫入磁盤),也能夠經過sync命令手動清空緩衝。
cache是高速緩存,用於CPU和內存之間的緩衝;
buffer是I/O緩存,用於內存和硬盤的緩衝;
cache最初用於cpu cache,主要緣由是cpu 與memory,因爲cpu快,memory跟不上,且有些值使用次數多,因此放入cache中,主要目的是,重複使用,而且一級\二級物理cache速度快,
buffer主要用於disk與 memory,主要是保護硬盤或減小網絡傳輸的次數(內存數據表現dataSet).固然也能夠提升速度(不會當即寫入硬盤或直接從硬盤中讀出的數據立刻顯示),重複使用,最初最主要的目的是保護disk,
Free中的buffer和cache:(它們都是佔用內存):
buffer : 做爲buffer cache的內存,是塊設備的讀寫緩衝區
cache: 做爲page cache的內存, 文件系統的cache
若是 cache 的值很大,說明cache住的文件數不少。若是頻繁訪問到的文件都能被cache住,那麼磁盤的讀IO bi會很是小。
========================================================
下面經過一些簡單通俗的例子來講明下Cache和Buffer緩存之間的區別:
1)Cache緩存
假設某地發生了天然災害(好比地震),居民缺衣少食,因而派救火車去給若干個居民點送水。救火車到達第一個居民點,開閘放水,老百姓就拿着盆盆罐罐來接水。假如說救火車在一個居民點停留100分鐘放完了水,而後從新儲水花半個小時,再開往下一個居民點。這樣一個白天來來來回回的,也就是4-5個居民點。
但咱們想一想,救火車是何等存在,若是把水龍頭徹底打開,其強大的水壓能輕易衝上10層樓以上, 10分鐘就能夠把水所有放完。但由於居民是拿盆罐接水,100%打開水龍頭那就是給人洗澡了,因此只能打開一小部分(好比10%的流量)。但這樣就下降了放水的效率(只有原來的10%了),10分鐘變100分鐘。
那麼,咱們是否能改進這個放水的過程,讓救火車以最高效率放完水、儘快趕往下一個居民點呢?
方法就是:在居民點建蓄水池。
救火車把水放到蓄水池裏,由於是以100%的效率放水,10分鐘結束而後走人。居民再從蓄水池裏一點一點的接水。
咱們分析一下這個例子,就能夠知道Cache的含義了。
救火車要給居民送水,居民要從救火車接水,就是說居民和救火車之間有交互,有聯繫。
但救火車是"高速設備",居民是"低速設備",低速的居民跟不上高速的救火車,因此救火車被迫下降了放水速度以適應居民。
爲了不這種狀況,在救火車和居民之間多了一層"蓄水池(也就是Cache)",它一方面以100%的高效和救火車打交道,另外一方面以10%的低效和居民打交道,這就解放了救火車,讓其以最高的效率運行,而不被低速的居民拖後腿,因而救火車只須要在一個居民點停留10分鐘就能夠了。
因此說,蓄水池是"活雷鋒",把高效留給別人,把低效留給本身。把10分鐘留給救火車,把100分鐘留給本身。
從以上例子能夠看出,所謂Cache,就是"爲了彌補高速設備和低速設備之間的矛盾"而設立的一箇中間層。由於在現實裏常常出現高速設備要和低速設備打交道,結果被低速設備拖後腿的狀況。Cache的存在是爲了解決什麼問題?速度太慢了,要加快速度!
以PC爲例。CPU速度很快,但CPU執行的指令是從內存取出的,計算的結果也要寫回內存,但內存的響應速度跟不上CPU。CPU跟內存說:你把某某地址的指令發給我。內存聽到了,但由於速度慢,遲遲不見指令返回,這段時間,CPU只能無所事事的等待了。這樣一來,再快的CPU也發揮不了效率。
怎麼辦呢?在CPU和內存之間加一塊"蓄水池",也就是Cache(片上緩存),這個Cache速度比內存快,從Cache取指令不須要等待。當CPU要讀內存的指令的時候先讀Cache再讀內存,但一開始Cache是空着的,只能從內存取,這時候的確是很慢,CPU須要等待。但從內存取回的不只僅是CPU所須要的指令,還有其它的、當前不須要的指令,而後把這些指令存在Cache裏備用。CPU再取指令的時候仍是先讀Cache,看看裏面有沒有所需指令,若是碰巧有就直接從Cache取,不用等待便可返回(命中),這就解放了CPU,提升了效率。(固然不會是100%命中,由於Cache的容量比內存小)
2)Buffer緩存
好比說吐魯番的葡萄熟了,要用大卡車裝葡萄運出去賣果園的姑娘採摘葡萄,固然不是前手把葡萄摘下來,後手就放到卡車上,而是須要一箇中間過程"籮筐":摘葡萄→放到籮筐裏→把籮筐裏的葡萄倒入卡車。也就是說,雖然最終目的是"把葡萄倒入卡車",但中間必需要通過"籮筐"的轉手,這裏的籮筐就是Buffer。是"暫時存放物品的空間"。
注意2個關鍵詞:暫時,空間
再換句話說,爲了完成最終目標:把葡萄放入卡車的空間,須要暫時把葡萄放入籮筐的空間。
以BT爲例,BT下載須要長時間的掛機,電腦就有可能24小時連軸轉,但BT下載的數據是碎片化的,體如今硬盤寫入上也是碎片化的,由於硬盤是機械尋址器件,這種碎片化的寫入會形成硬盤長時間高負荷的機械運動,形成硬盤過早老化損壞,當年有大量的硬盤由於BT下載而損壞。因而新出的BT軟件在內存裏開闢了Buffer,數據暫時寫入Buffer,攢到必定的大小(好比512M)再一次性寫入硬盤,這種"化零爲整"的寫入方式大大下降了硬盤的負荷。這就是:爲了完成最終目標:把數據寫入硬盤空間,須要暫時寫入Buffer的空間。
3)兩者之間的區別總結
Cache和Buffer的相同點:都是2個層面之間的中間層,都是內存。
Cache和Buffer的不一樣點:Cache解決的是時間問題,Buffer解決的是空間問題。
爲了提升速度,引入了Cache這個中間層。
爲了給信息找到一個暫存空間,引入了Buffer這個中間層。
爲了解決2個不一樣維度的問題(時間、空間),恰巧取了同一種解決方法:加入一箇中間層,先把數據寫到中間層上,而後再寫入目標。
這個中間層就是內存「RAM」,既然是存儲器就有2個參數:寫入的速度有多塊(速度),能裝多少東西(容量)
Cache利用的是RAM提供的高讀寫速度,Buffer利用的是RAM提供的存儲容量(空間)。
a)Buffer(緩衝區)是系統兩端處理速度平衡(從長時間尺度上看)時使用的。它的引入是爲了減少短時間內突發I/O的影響,起到流量整形的做用。好比生產者——消費者問題,他們產生和消耗資源的速度大致接近,加一個buffer能夠抵消掉資源剛產生/消耗時的忽然變化。
b)Cache(緩存)則是系統兩端處理速度不匹配時的一種折衷策略。由於CPU和memory之間的速度差別愈來愈大,因此人們充分利用數據的局部性(locality)特徵,經過使用存儲系統分級(memory hierarchy)的策略來減少這種差別帶來的影響。
c)假定之後存儲器訪問變得跟CPU作計算同樣快,cache就能夠消失,可是buffer依然存在。好比從網絡上下載東西,瞬時速率可能會有較大變化,但從長期來看倒是穩定的,這樣就能經過引入一個buffer使得OS接收數據的速率更穩定,進一步減小對磁盤的傷害。
========================================================
4、手動清理緩存
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
|
釋放緩存區內存的方法
1)清理pagecache(頁面緩存)
[root@backup ~]
# echo 1 > /proc/sys/vm/drop_caches 或者 # sysctl -w vm.drop_caches=1
2)清理dentries(目錄緩存)和inodes
[root@backup ~]
# echo 2 > /proc/sys/vm/drop_caches 或者 # sysctl -w vm.drop_caches=2
3)清理pagecache、dentries和inodes
[root@backup ~]
# echo 3 > /proc/sys/vm/drop_caches 或者 # sysctl -w vm.drop_caches=3
上面三種方式都是臨時釋放緩存的方法,要想永久釋放緩存,須要在
/etc/sysctl
.conf文件中配置:vm.drop_caches=1
/2/3
,而後sysctl -p生效便可!
另外,可使用
sync
命令來清理文件系統緩存,還會清理殭屍(zombie)對象和它們佔用的內存
[root@backup ~]
# sync
舒適提示:
上面操做在大多數狀況下都不會對系統形成傷害,只會有助於釋放不用的內存。
可是若是在執行這些操做時正在寫數據,那麼實際上在數據到達磁盤以前就將它從文件緩存中清除掉了,這可能會形成很很差的影響。
那麼若是避免這種事情發生呢?
所以,這裏不得不提一下
/proc/sys/vm/vfs_cache_pressure
這個文件,告訴內核,當清理inoe
/dentry
緩存時應該用什麼樣的優先級。
[root@backup ~]
# cat /proc/sys/vm/vfs_cache_pressure
100
vfs_cache_pressure=100 這個是默認值,內核會嘗試從新聲明dentries和inodes,並採用一種相對於頁面緩存和交換緩存比較
"合理"
的比例。
減小vfs_cache_pressure的值,會致使內核傾向於保留dentry和inode緩存。
增長vfs_cache_pressure的值,(即超過100時),則會致使內核傾向於從新聲明dentries和inodes
總之,vfs_cache_pressure的值:
小於100的值不會致使緩存的大量減小
超過100的值則會告訴內核你但願以高優先級來清理緩存。
其實不管vfs_cache_pressure的值採用什麼值,內核清理緩存的速度都是比較低的。
若是將此值設置爲10000,系統將會將緩存減小到一個合理的水平。
======================================================
這裏順便說下本身遇到的一個內存問題:
IDC機房有一臺專門的備份服務器,天天凌晨執行多個備份腳本。某天早上忽然發現收到不少條zabbix監控報警信息:這臺備份服務器的內存使用了已超過80%!
因而,趕忙登錄這臺備份服務器,使用
free
命令查看內存使用狀況:
[root@backup ~]
# free -m
total used
free
shared buffers cached
Mem: 64181 48585 15596 3 2 18
-/+ buffers
/cache
: 48564 15617
Swap: 32767 0 3276
確實發現內存使用率已超過80%!可是使用
"top"
命令查看,發現此時並無什麼進程在佔用內存,而且本機是備份服務器,只有晚上執行備份腳本,
其餘時間都沒有服務進程在跑!因而嘗試手動釋放內存:
[root@backup ~]
# echo 1 > /proc/sys/vm/drop_caches
[root@backup ~]
# echo 2 > /proc/sys/vm/drop_caches
[root@backup ~]
# echo 3 > /proc/sys/vm/drop_caches
[root@backup ~]
# sync
發如今執行了上面第三條命令後,內存才真正被釋放出來了,其餘命令都沒有起到效果。
|