1)緩存機制介紹
在Linux系統(tǒng)中,為了提高文件系統(tǒng)性能,內(nèi)核利用一部分物理內(nèi)存分配出緩沖區(qū),用于緩存系統(tǒng)操作和數(shù)據(jù)文件,當內(nèi)核收到讀寫的請求時,內(nèi)核先去緩存區(qū)找是否有請求的數(shù)據(jù),有就直接返回,如果沒有則通過驅(qū)動程序直接操作磁盤。
緩存機制優(yōu)點:減少系統(tǒng)調(diào)用次數(shù),降低CPU上下文切換和磁盤訪問頻率。
CPU上下文切換:CPU給每個進程一定的服務時間,當時間片用完后,內(nèi)核從正在運行的進程中收回處理器,同時把進程當前運行狀態(tài)保存下來,然后加載下一個任務,這個過程叫做上下文切換。實質(zhì)上就是被終止運行進程與待運行進程的進程切換。
2)查看緩存區(qū)及內(nèi)存使用情況
[root@localhost ~]# free -m
total used free shared buffers cached
Mem: 7866 7725 141 19 74 6897
-/+ buffers/cache: 752 7113
Swap: 16382 32 16350
從上面的命令結果顯示中可以看出:內(nèi)存總共8G,已使用7725M,剩余141M,不少的人都是這么看的。
但其實這樣并不能作為實際的使用率。因為有了緩存機制,具體算法如下:
空閑內(nèi)存=free(141)+buffers(74)+cached(6897)
已用內(nèi)存=total(7866)-空閑內(nèi)存
由此算出空閑內(nèi)存是7112M,已用內(nèi)存754M,這才是真正的使用率,也可參考-/+ buffers/cache這行信息也是內(nèi)存正確使用率。
3)緩存區(qū)分buffers和cached區(qū)別
內(nèi)核在保證系統(tǒng)能正常使用物理內(nèi)存和數(shù)據(jù)量讀寫情況下來分配緩沖區(qū)大小。
buffers用來緩存metadata及pages,可以理解為系統(tǒng)緩存,例如,vi打開一個文件。
cached是用來給文件做緩存,可以理解為數(shù)據(jù)塊緩存,例如,dd if=/dev/zero of=/tmp/test count=1 bs=1G 測試寫入一個文件,就會被緩存到緩沖區(qū)中,當下一次再執(zhí)行這個測試命令時,寫入速度會明顯很快。
4)Swap用途
Swap意思是交換分區(qū),通常我們說的虛擬內(nèi)存,是從硬盤中劃分出的一個分區(qū)。當物理內(nèi)存不夠用的時候,內(nèi)核就會釋放緩存區(qū)(buffers/cache)里一些長時間不用的程序,然后將這些程序臨時放到Swap中,也就是說如果物理內(nèi)存和緩存區(qū)內(nèi)存不夠用的時候,才會用到Swap。
swap清理:
注意:這樣清理有個前提條件,空閑的內(nèi)存必須比已經(jīng)使用的swap空間大
5)釋放緩存區(qū)內(nèi)存的方法
a)清理pagecache(頁面緩存)
# echo 1 > /proc/sys/vm/drop_caches 或者 # sysctl -w vm.drop_caches=1
b)清理dentries(目錄緩存)和inodes
# echo 2 > /proc/sys/vm/drop_caches 或者 # sysctl -w vm.drop_caches=2
c)清理pagecache、dentries和inodes
# 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命令來清理文件系統(tǒng)緩存,還會清理僵尸(zombie)對象和它們占用的內(nèi)存
上面操作在大多數(shù)情況下都不會對系統(tǒng)造成傷害,只會有助于釋放不用的內(nèi)存。
但是如果在執(zhí)行這些操作時正在寫數(shù)據(jù),那么實際上在數(shù)據(jù)到達磁盤之前就將它從文件緩存中清除掉了,這可能會造成很不好的影響。那么如果避免這種事情發(fā)生呢?
因此,這里不得不提一下/proc/sys/vm/vfs_cache_pressure這個文件,告訴內(nèi)核,當清理inoe/dentry緩存時應該用什么樣的優(yōu)先級。
vfs_cache_pressure=100 這個是默認值,內(nèi)核會嘗試重新聲明dentries和inodes,并采用一種相對于頁面緩存和交換緩存比較”合理”的比例。
減少vfs_cache_pressure的值,會導致內(nèi)核傾向于保留dentry和inode緩存。
增加vfs_cache_pressure的值,(即超過100時),則會導致內(nèi)核傾向于重新聲明dentries和inodes
總之,vfs_cache_pressure的值:
小于100的值不會導致緩存的大量減少
超過100的值則會告訴內(nèi)核你希望以高優(yōu)先級來清理緩存。
其實無論vfs_cache_pressure的值采用什么值,內(nèi)核清理緩存的速度都是比較低的。
如果將此值設置為10000,系統(tǒng)將會將緩存減少到一個合理的水平。
釋放內(nèi)存前先使用sync命令做同步,以確保文件系統(tǒng)的完整性,將所有未寫的系統(tǒng)緩沖區(qū)寫到磁盤中,包含已修改的 i-node、已延遲的塊 I/O 和讀寫映射文件。否則在釋放緩存的過程中,可能會丟失未保存的文件。
/proc是一個虛擬文件系統(tǒng),可以通過對它的讀寫操作作為與kernel實體間進行通信的一種手段。也就是說可以通過修改/proc中的文件,來對當前kernel的行為做出調(diào)整。也就是說我們可以通過調(diào)整/proc/sys/vm/drop_caches來釋放內(nèi)存。
drop_caches的值可以是0-3之間的數(shù)字,代表不同的含義:
0:不釋放(系統(tǒng)默認值)
1:釋放頁緩存
2:釋放dentries和inodes
3:釋放所有緩存
以上就是關于Linux系統(tǒng)清除緩存的全部知識點內(nèi)容,感謝大家的學習和對腳本之家的支持。