Linux Cache Memory
http://www.opsers.org/base/cache-memory-on-linux-detailed-cache-memory.html
Linux與Win的記憶體管理不同,會盡量快取記憶體以提高讀寫效能,通常叫做Cache Memory。有時候你會發現沒有什麼程式在執行,但是使用top或free命令看到可用記憶體free項會很少,此時檢視系統的 /proc/meminfo 檔案,會發現有一項 Cached Memory:
輸入cat /proc/meminfo檢視:
MemTotal: 1012704 kB MemFree: 281284 kB Buffers: 39836 kB Cached: 458000 kB
free命令裡各項記憶體指標說明:
total used free shared buffers cached Mem: 16425996 10727220 5698776 0 380904 9389832 -/+ buffers/cache: 956484 15469512 Swap: 8273464 212 8273252
其中第一行用全域性角度描述系統使用的記憶體狀況:
total——總實體記憶體
used——已使用記憶體,一般情況這個值會比較大,因為這個值包括了cache+應用程式使用的記憶體
free——完全未被使用的記憶體
shared——應用程式共享記憶體
buffers——快取,主要用於目錄方面,inode值等(ls大目錄可看到這個值增加)
cached——快取,用於已開啟的檔案
總結:
total=used+free used=buffers+cached (maybe add shared also)
第二行描述應用程式的記憶體使用:
前個值表示-buffers/cache——應用程式使用的記憶體大小,used減去快取值
後個值表示+buffers/cache——所有可供應用程式使用的記憶體大小,free加上快取值
總結:
-buffers/cache=used-buffers-cached +buffers/cache=free+buffers+cached
第三行表示swap的使用:
used——已使用
free——未使用
什麼是Cache Memory(快取記憶體):
當你讀寫檔案的時候,Linux核心為了提高讀寫效能與速度,會將檔案在記憶體中進行快取,這部分記憶體就是Cache Memory(快取記憶體)。即使你的程式執行結束後,Cache Memory也不會自動釋放。這就會導致你在Linux系統中程式頻繁讀寫檔案後,你會發現可用實體記憶體會很少。
其實這快取記憶體(Cache Memory)在你需要使用記憶體的時候會自動釋放,所以你不必擔心沒有記憶體可用。如果你希望手動去釋放Cache Memory也是有辦法的。
如何釋放Cache Memory(快取記憶體):
用下面的命令可以釋放Cache Memory:
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
注意,釋放前最好sync一下,防止丟失資料。
總結:個人經驗認為沒必要手動釋放,這種記憶體管理方式也是比win優勝的地方之一!因為Linux的核心記憶體管理機制,一般情況下不需要特意去釋放已經使用的cache。這些cache起來的內容可以提高檔案以及磁碟的讀寫速度。
轉自:http://www.ha97.com/4337.html
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/720091/viewspace-1065846/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- influxdb報錯:cache-max-memory-size exceededUX
- Linux 核心101:cache原理Linux
- Linux Buffer/Cache 的區別Linux
- PostgreSQL DBA(89) - Linux(Buffer vs Cache)SQLLinux
- Linux 核心101:cache組織策略Linux
- Linux記憶體、Swap、Cache、BufferLinux記憶體
- Linux arm64 set_memory_ro/rw函式Linux函式
- memory
- Linux工具效能調優系列二:buffer和cacheLinux
- Linux如何手動釋放Swap、Buffer和CacheLinux
- Linux核心引數overcommit_memory和OOM killer介紹LinuxMITOOM
- 手動釋放Linux上的Swap、Buffer和CacheLinux
- BMZCTF:memory
- 解決linux下redis資料庫overcommit_memory問題LinuxRedis資料庫MIT
- Cache和Buffer都是快取,有什麼區別?Linux快取Linux
- [Memory Leak] 1. console.log cause memory leak
- VM warning: INFO: OS::commit_memory Cannot allocate memoryMIT
- memory-cnblog
- Memory Management in RustRust
- OOM(Out Of Memory)OOM
- library cache pin和library cache lock(一)
- library cache pin和library cache lock (zt)
- library cache pin和library cache lock(二)
- OH解決linux下redis資料庫overcommit_memory問題vlrLinuxRedis資料庫MIT
- Guava CacheGuava
- Spring CacheSpring
- ORACLE LARGE MEMORY(zt)Oracle
- 如何理解Memory leak
- Service Worker Cache 和 HTTP Cache 的區別HTTP
- MySQL:Table_open_cache_hits/Table_open_cache_misses/Table_open_cache_overflowsMySql
- ES叢集搭建問題:memory locking requested for elasticsearch process but memory is not lockedElasticsearch
- 什麼是 ABAP 程式語言的 Used Memory 和 Allocated Memory
- Library Cache最佳化篇(一)降低library cache lock和library cache pin的方法
- PWA(Progressive Web App)入門系列:Cache Storage & CacheWebAPP
- library cache lock和library cache bin實驗_2.0
- 【Cache】將常用的“小表”快取到Buffer Cache快取
- Client Side Cache 和 Server Side Cache 的區別clientIDEServer
- ORA-00837: Specified value of MEMORY_TARGET greater than MEMORY_MAX_TARGET
- Linux下玩轉nginx系列(六)---nginx實現cache(快取)服務LinuxNginx快取