看緩存的命令
成都創(chuàng)新互聯(lián)公司主營玉樹網(wǎng)站建設(shè)的網(wǎng)絡(luò)公司,主營網(wǎng)站建設(shè)方案,成都app軟件開發(fā)公司,玉樹h5重慶小程序開發(fā)搭建,玉樹網(wǎng)站營銷推廣歡迎玉樹等地區(qū)企業(yè)咨詢
free -m
清理緩存的命令
echo 1 /proc/sys/vm/drop_caches
echo 2 /proc/sys/vm/drop_caches
echo 3 /proc/sys/vm/drop_caches
echo 0 是不釋放緩存
echo 1 是釋放頁緩存 《Linux就該這么學(xué)》
ehco 2 是釋放dentries和inodes緩存
echo 3 是釋放 1 和 2 中說道的的所有緩存
Linux釋放內(nèi)存的命令:\x0d\x0async\x0d\x0aecho 1 /proc/sys/vm/drop_caches\x0d\x0a\x0d\x0adrop_caches的值可以是0-3之間的數(shù)字,代表不同的含義:\x0d\x0a0:不釋放(系統(tǒng)默認(rèn)值)\x0d\x0a1:釋放頁緩存\x0d\x0a2:釋放dentries和inodes\x0d\x0a3:釋放所有緩存\x0d\x0a\x0d\x0a釋放完內(nèi)存后改回去讓系統(tǒng)重新自動(dòng)分配內(nèi)存。\x0d\x0aecho 0 /proc/sys/vm/drop_caches\x0d\x0a\x0d\x0afree -m #看內(nèi)存是否已經(jīng)釋放掉了。\x0d\x0a\x0d\x0a如果我們需要釋放所有緩存,就輸入下面的命令:\x0d\x0aecho 3 /proc/sys/vm/drop_caches\x0d\x0a\x0d\x0a######### Linux釋放內(nèi)存的相關(guān)知識(shí) ###############\x0d\x0a\x0d\x0a在Linux系統(tǒng)下,我們一般不需要去釋放內(nèi)存,因?yàn)橄到y(tǒng)已經(jīng)將內(nèi)存管理的很好。但是凡事也有例外,有的時(shí)候內(nèi)存會(huì)被緩存占用掉,導(dǎo)致系統(tǒng)使用SWAP空 間影響性能,例如當(dāng)你在linux下頻繁存取文件后,物理內(nèi)存會(huì)很快被用光,當(dāng)程序結(jié)束后,內(nèi)存不會(huì)被正常釋放,而是一直作為caching。,此時(shí)就需 要執(zhí)行釋放內(nèi)存(清理緩存)的操作了。\x0d\x0a\x0d\x0aLinux系統(tǒng)的緩存機(jī)制是相當(dāng)先進(jìn)的,他會(huì)針對(duì)dentry(用于VFS,加速文件路徑名到inode的轉(zhuǎn)換)、Buffer Cache(針對(duì)磁盤塊的讀寫)和Page Cache(針對(duì)文件inode的讀寫)進(jìn)行緩存操作。但是在進(jìn)行了大量文件操作之后,緩存會(huì)把內(nèi)存資源基本用光。但實(shí)際上我們文件操作已經(jīng)完成,這部分 緩存已經(jīng)用不到了。這個(gè)時(shí)候,我們難道只能眼睜睜的看著緩存把內(nèi)存空間占據(jù)掉嗎?所以,我們還是有必要來手動(dòng)進(jìn)行Linux下釋放內(nèi)存的操作,其實(shí)也就是 釋放緩存的操作了。/proc是一個(gè)虛擬文件系統(tǒng),我們可以通過對(duì)它的讀寫操作做為與kernel實(shí)體間進(jìn)行通信的一種手段.也就是說可以通過修改 /proc中的文件,來對(duì)當(dāng)前kernel的行為做出調(diào)整.那么我們可以通過調(diào)整/proc/sys/vm/drop_caches來釋放內(nèi)存。要達(dá)到釋 放緩存的目的,我們首先需要了解下關(guān)鍵的配置文件/proc/sys/vm/drop_caches。這個(gè)文件中記錄了緩存釋放的參數(shù),默認(rèn)值為0,也就 是不釋放緩存。\x0d\x0a\x0d\x0a一般復(fù)制了文件后,可用內(nèi)存會(huì)變少,都被cached占用了,這是linux為了提高文件讀取效率的做法:為了提高磁盤存取效率, Linux做了一些精心的設(shè)計(jì), 除了對(duì)dentry進(jìn)行緩存(用于VFS,加速文件路徑名到inode的轉(zhuǎn)換), 還采取了兩種主要Cache方式:Buffer Cache和Page Cache。前者針對(duì)磁盤塊的讀寫,后者針對(duì)文件inode的讀寫。這些Cache有效縮短了 I/O系統(tǒng)調(diào)用(比如read,write,getdents)的時(shí)間。"\x0d\x0a\x0d\x0a釋放內(nèi)存前先使用sync命令做同步,以確保文件系統(tǒng)的完整性,將所有未寫的系統(tǒng)緩沖區(qū)寫到磁盤中,包含已修改的 i-node、已延遲的塊 I/O 和讀寫映射文件。否則在釋放緩存的過程中,可能會(huì)丟失未保存的文件。\x0d\x0a\x0d\x0a[root@fcbu.com ~]# free -m\x0d\x0a total used free shared buffers cached\x0d\x0aMem: 7979 7897 82 0 30 3918\x0d\x0a-/ buffers/cache: 3948 4031\x0d\x0aSwap: 4996 438 4558\x0d\x0a\x0d\x0a第一行用全局角度描述系統(tǒng)使用的內(nèi)存狀況:\x0d\x0atotal 內(nèi)存總數(shù)\x0d\x0aused 已經(jīng)使用的內(nèi)存數(shù),一般情況這個(gè)值會(huì)比較大,因?yàn)檫@個(gè)值包括了cache 應(yīng)用程序使用的內(nèi)存\x0d\x0afree 空閑的內(nèi)存數(shù)\x0d\x0ashared 多個(gè)進(jìn)程共享的內(nèi)存總額\x0d\x0abuffers 緩存,主要用于目錄方面,inode值等(ls大目錄可看到這個(gè)值增加)\x0d\x0acached 緩存,用于已打開的文件\x0d\x0a\x0d\x0a第二行描述應(yīng)用程序的內(nèi)存使用:\x0d\x0a-buffers/cache 的內(nèi)存數(shù):used - buffers - cached\x0d\x0abuffers/cache 的內(nèi)存數(shù):free buffers cached\x0d\x0a前個(gè)值表示-buffers/cache 應(yīng)用程序使用的內(nèi)存大小,used減去緩存值\x0d\x0a后個(gè)值表示 buffers/cache 所有可供應(yīng)用程序使用的內(nèi)存大小,free加上緩存值\x0d\x0a\x0d\x0a第三行表示swap的使用:\x0d\x0aused 已使用\x0d\x0afree 未使用 \x0d\x0a\x0d\x0a可用的內(nèi)存=free memory buffers cached。\x0d\x0a\x0d\x0a為什么free這么小,是否關(guān)閉應(yīng)用后內(nèi)存沒有釋放?\x0d\x0a但實(shí)際上,我們都知道這是因?yàn)長inux對(duì)內(nèi)存的管理與Windows不同,free小并不是說內(nèi)存不夠用了,應(yīng)該看的是free的第二行最后一個(gè)值:-/ buffers/cache: 3948 4031 ,這才是系統(tǒng)可用的內(nèi)存大小。\x0d\x0a實(shí)際項(xiàng)目中的經(jīng)驗(yàn)告訴我們,如果因?yàn)槭菓?yīng)用有像內(nèi)存泄露、溢出的問題,從swap的使用情況是可以比較快速可以判斷的,但free上面反而比較難查看。我覺得既然核心是可以快速清空buffer或cache,但核心并沒有這樣做(默認(rèn)值是0),我們不應(yīng)該隨便去改變它。\x0d\x0a一般情況下,應(yīng)用在系統(tǒng)上穩(wěn)定運(yùn)行了,free值也會(huì)保持在一個(gè)穩(wěn)定值的,雖然看上去可能比較小。當(dāng)發(fā)生內(nèi)存不足、應(yīng)用獲取不到可用內(nèi)存、OOM錯(cuò) 誤等問題時(shí),還是更應(yīng)該去分析應(yīng)用方面的原因,如用戶量太大導(dǎo)致內(nèi)存不足、發(fā)生應(yīng)用內(nèi)存溢出等情況,否則,清空buffer,強(qiáng)制騰出free的大小,可 能只是把問題給暫時(shí)屏蔽了,所以說一般情況下linux都不用經(jīng)常手動(dòng)釋放內(nèi)存。
第一步:先執(zhí)行sync命令
#sync
sync命令用于強(qiáng)制被改變的內(nèi)容立刻寫入磁盤,更新超塊信息,以防止釋放,sync命令則可用來強(qiáng)制將內(nèi)存緩沖區(qū)中的數(shù)據(jù)立即寫入磁盤中。
第二步:清理linux內(nèi)存緩存
#echo 3 /proc/sys/vm/drop_caches
一般系統(tǒng)是不會(huì)自動(dòng)釋放內(nèi)存的
關(guān)鍵的配置文件/proc/sys/vm/drop_caches。這個(gè)文件中記錄了緩存釋放的參數(shù),默認(rèn)值為0,也就是不釋放緩存。他的值可以為0~3之間的任意數(shù)字,代表著不同的含義:
0 – 不釋放
1 – 釋放頁緩存
2 – 釋放dentries和inodes
3 – 釋放所有緩存
此指令輸入立即生效,意在釋放所有緩存。
第三步:關(guān)閉swap,再開啟swap
(如果只是清理swap,第二部可以不用進(jìn)行操作,因?yàn)椴僮髁说诙疥P(guān)閉swap時(shí)會(huì)使用更長的時(shí)間)
#swapoff -a? 這一步因?yàn)槭呛笈_(tái) 在一點(diǎn)一點(diǎn)的釋放,如果配置的swap超大,這里就等待得超久一些
#swapon -a? 再開啟
linux什么時(shí)候開始使用虛擬內(nèi)存(swap)
A.[root@wenwen ~]# cat /proc/sys/vm/swappiness
60
上面這個(gè)60代表物理內(nèi)存在使用60%的時(shí)候才會(huì)使用swap
swappiness=0的時(shí)候表示最大限度使用物理內(nèi)存,然后才是 swap空間,
swappiness=100的時(shí)候表示積極的使用swap分區(qū),并且把內(nèi)存上的數(shù)據(jù)及時(shí)的搬運(yùn)到swap空間里面。
通常情況下:
swap分區(qū)設(shè)置建議是內(nèi)存的兩倍 (內(nèi)存小于等于4G時(shí)),如果內(nèi)存大于4G,swap只要比內(nèi)存大就行。另外盡量的將swappiness調(diào)低,這樣系統(tǒng)的性能會(huì)更好。
B.修改swappiness參數(shù)
臨時(shí)性修改:
[root@wenwen ~]# sysctl vm.swappiness=10
vm.swappiness = 10
[root@wenwen ~]# cat /proc/sys/vm/swappiness? ? ? ? ? ? ? ?
10
永久性修改:
[root@wenwen ~]# vim /etc/sysctl.conf
加入?yún)?shù):
vm.swappiness = 35
然后在直接:
[root@wenwen ~]# sysctl -p
查看是否生效:
cat /proc/sys/vm/swappiness
35
在Linux系統(tǒng)中,我們經(jīng)常用free命令來查看系統(tǒng)內(nèi)存的使用狀態(tài)。
默認(rèn)顯示單位是kb,我的服務(wù)器是128G內(nèi)存,所以數(shù)字顯得比較大。這個(gè)命令幾乎是每一個(gè)使用過Linux的人必會(huì)的命令,但越是這樣的命令,似乎真正明白的人越少(我是說比例越少)。一般情況下,對(duì)此命令輸出的理解可以分這幾個(gè)層次:
1.? 不了解。這樣的人的第一反應(yīng)是:天啊,內(nèi)存用了好多,70個(gè)多G,可是我?guī)缀鯖]有運(yùn)行什么大程序???為什么會(huì)這樣?Linux好占內(nèi)存!
2.? 自以為很了解。這樣的人一般評(píng)估過會(huì)說:嗯,根據(jù)我專業(yè)的眼光看的出來,內(nèi)存才用了17G左右,還有很多剩余內(nèi)存可用。buffers/cache占用的較多,說明系統(tǒng)中有進(jìn)程曾經(jīng)讀寫過文件,但是不要緊,這部分內(nèi)存是當(dāng)空閑來用的。
3. ? 真的很了解。這種人的反應(yīng)反而讓人感覺最不懂Linux,他們的反應(yīng)是:free顯示的是這樣,好吧我知道了。神馬?你問我這些內(nèi)存夠不夠,我當(dāng)然不知道啦!我怎么知道你程序怎么寫的?
4. ? 根據(jù)目前網(wǎng)絡(luò)上技術(shù)文檔的內(nèi)容,我相信絕大多數(shù)了解一點(diǎn)Linux的人應(yīng)該處在第二種層次。大家普遍認(rèn)為,buffers和cached所占用的內(nèi)存空間是可以在內(nèi)存壓力較大的時(shí)候被釋放當(dāng)做空閑空間用的。但真的是這樣么?
在論證這個(gè)題目之前,我們先簡(jiǎn)要介紹一下buffers和cached是什么意思:
Free中的buffer和cache:(它們都是占用內(nèi)存):
buffer :?作為buffer cache的內(nèi)存,是塊設(shè)備的讀寫緩沖區(qū)
cache:?作為page cache的內(nèi)存,?文件系統(tǒng)的cache
如果?cache?的值很大,說明cache住的文件數(shù)很多。如果頻繁訪問到的文件都能被cache住,那么磁盤的讀IO bi會(huì)非常小。
cache是高速緩存,用于CPU和內(nèi)存之間的緩沖;
buffer
是I/O緩存,用于內(nèi)存和硬盤的緩沖
buffer和 cache 是兩個(gè)在計(jì)算機(jī)技術(shù)中被用濫的名詞,放在不通語境下會(huì)有不同的意義。在Linux的內(nèi)存管理中,這里的buffer指Linux內(nèi)存的:Buffer cache。這里的cache指Linux內(nèi)存中的:Page
cache。翻譯成中文可以叫做緩沖區(qū)緩存和頁面緩存。在歷史上,它們一個(gè)(buffer)被用來當(dāng)成對(duì)io設(shè)備寫的緩存,而另一個(gè)(cache)被用來當(dāng)作對(duì)io設(shè)備的讀緩存,這里的io設(shè)備,主要指的是塊設(shè)備文件和文件系統(tǒng)上的普通文件。但是現(xiàn)在,它們的意義已經(jīng)不一樣了。在當(dāng)前的內(nèi)核中,page cache顧名思義就是針對(duì)內(nèi)存頁的緩存,說白了就是,如果有內(nèi)存是以page進(jìn)行分配管理的,都可以使用page cache作為其緩存來管理使用。當(dāng)然,不是所有的內(nèi)存都是以頁(page)進(jìn)行管理的,也有很多是針對(duì)塊(block)進(jìn)行管理的,這部分內(nèi)存使用如果要用到cache功能,則都集中到buffer cache中來使用。(從這個(gè)角度出發(fā),是不是buffer cache改名叫做block cache更好?)然而,也不是所有塊(block)都有固定長度,系統(tǒng)上塊的長度主要是根據(jù)所使用的塊設(shè)備決定的,而頁長度在X86上無論是32位還是64位都是4k。
明白了這兩套緩存系統(tǒng)的區(qū)別,就可以理解它們究竟都可以用來做什么了。
Page cache主要用來作為文件系統(tǒng)上的文件數(shù)據(jù)的緩存來用,尤其是針對(duì)當(dāng)進(jìn)程對(duì)文件有read/write操作的時(shí)候。如果你仔細(xì)想想的話,作為可以映射文件到內(nèi)存的系統(tǒng)調(diào)用:mmap是不是很自然的也應(yīng)該用到page cache?在當(dāng)前的系統(tǒng)實(shí)現(xiàn)里,page cache也被作為其它文件類型的緩存設(shè)備來用,所以事實(shí)上page cache也負(fù)責(zé)了大部分的塊設(shè)備文件的緩存工作。
Buffer cache則主要是設(shè)計(jì)用來在系統(tǒng)對(duì)塊設(shè)備進(jìn)行讀寫的時(shí)候,對(duì)塊進(jìn)行數(shù)據(jù)緩存的系統(tǒng)來使用。這意味著某些對(duì)塊的操作會(huì)使用buffer cache進(jìn)行緩存,比如我們?cè)诟袷交募到y(tǒng)的時(shí)候。一般情況下兩個(gè)緩存系統(tǒng)是一起配合使用的,比如當(dāng)我們對(duì)一個(gè)文件進(jìn)行寫操作的時(shí)候,page cache的內(nèi)容會(huì)被改變,而buffer cache則可以用來將page標(biāo)記為不同的緩沖區(qū),并記錄是哪一個(gè)緩沖區(qū)被修改了。這樣,內(nèi)核在后續(xù)執(zhí)行臟數(shù)據(jù)的回寫(writeback)時(shí),就不用將整個(gè)page寫回,而只需要寫回修改的部分即可。
Linux內(nèi)核會(huì)在內(nèi)存將要耗盡的時(shí)候,觸發(fā)內(nèi)存回收的工作,以便釋放出內(nèi)存給急需內(nèi)存的進(jìn)程使用。一般情況下,這個(gè)操作中主要的內(nèi)存釋放都來自于對(duì)buffer/cache的釋放。尤其是被使用更多的cache空間。既然它主要用來做緩存,只是在內(nèi)存夠用的時(shí)候加快進(jìn)程對(duì)文件的讀寫速度,那么在內(nèi)存壓力較大的情況下,當(dāng)然有必要清空釋放cache,作為free空間分給相關(guān)進(jìn)程使用。所以一般情況下,我們認(rèn)為buffer/cache空間可以被釋放,這個(gè)理解是正確的。
但是這種清緩存的工作也并不是沒有成本。理解cache是干什么的就可以明白清緩存必須保證cache中的數(shù)據(jù)跟對(duì)應(yīng)文件中的數(shù)據(jù)一致,才能對(duì)cache進(jìn)行 釋放 。所以伴隨著cache清除的行為的,一般都是系統(tǒng)IO飆高。因?yàn)閮?nèi)核要對(duì)比cache中的數(shù)據(jù)和對(duì)應(yīng)硬盤文件上的數(shù)據(jù)是否一致,如果不一致需要寫回,之后才能回收。
在系統(tǒng)中除了內(nèi)存將被耗盡的時(shí)候可以清緩存以外,我們還可以使用下面這個(gè)文件來人工觸發(fā)緩存清除的操作:
[root@tencent64?~]#?cat?/proc/sys/vm/drop_caches?
1
方法是:
echo?1??/proc/sys/vm/drop_caches
當(dāng)然,這個(gè)文件可以設(shè)置的值分別為1、2、3。它們所表示的含義為:
sync //先做同步數(shù)據(jù) 防止數(shù)據(jù)部分丟失
echo?1??/proc/sys/vm/drop_caches:表示清除pagecache。
echo?2??/proc/sys/vm/drop_caches:表示清除回收slab分配器中的對(duì)象(包括目錄項(xiàng)緩存和inode緩存)。slab分配器是內(nèi)核中管理內(nèi)存的一種機(jī)制,其中很多緩存數(shù)據(jù)實(shí)現(xiàn)都是用的pagecache。
echo?3??/proc/sys/vm/drop_caches:表示清除pagecache和slab分配器中的緩存對(duì)象。
#!/bin/bashecho?????? "開始清理緩存"
sync;sync;sync??????? #寫入硬盤,防止數(shù)據(jù)丟失
sleep 10????????????????????? #延遲10秒
echo 1 /proc/sys/vm/drop_cachesecho????????????????? "清理結(jié)束"
設(shè)置定時(shí)任務(wù)
crontab -e
* 0 * * * /root/cleanBuff.sh???????????????????????
crontab -l?????????????????? //查看是否設(shè)置成功