輸入命令for i in `seq 1 $(cat /proc/cpuinfo |grep "physical id" |wc -l)`;do dd if=/dev/zero of=/dev/null
成都創(chuàng)新互聯(lián)主營(yíng)昌平網(wǎng)站建設(shè)的網(wǎng)絡(luò)公司,主營(yíng)網(wǎng)站建設(shè)方案,成都app軟件開(kāi)發(fā)公司,昌平h5微信平臺(tái)小程序開(kāi)發(fā)搭建,昌平網(wǎng)站營(yíng)銷推廣歡迎昌平等地區(qū)企業(yè)咨詢
done。
這里說(shuō)明一下
cat /proc/cpuinfo |grep "physical id" | wc -l可以獲得CPU的個(gè)數(shù)可以把他表示為N-seq 1 N 用來(lái)生成1到N之間的數(shù)字
for i in seq 1 N; 就是循環(huán)執(zhí)行命令,從1到N dd if=/dev/zero of=/dev/null 執(zhí)行dd命令,輸出到/dev/null, 實(shí)際上這里所只是占用了CPU, 并沒(méi)有的IO操作.
因?yàn)檫B續(xù)執(zhí)行N個(gè)(N是CPU個(gè)數(shù))的dd 命令, 且使用率為百分百, 這時(shí)調(diào)度器會(huì)調(diào)度每個(gè)dd命令在不同的CPU上處理,最終就實(shí)現(xiàn)所有CPU跑滿。
在Linux系統(tǒng)上,可以使用ulimit -m命令來(lái)設(shè)置最大堆內(nèi)存,默認(rèn)使用的是單位KB,如:ulimit -m 20000,表示設(shè)置最大堆內(nèi)存為20000KB。
1.在Linux下查看內(nèi)存:free
2.查看進(jìn)程
3.實(shí)時(shí)顯示系統(tǒng)中各個(gè)進(jìn)程的資源占用狀況 top
4.
5.df 用于顯示 Linux 系統(tǒng)的磁盤利用率
6.du 命令
du是用于查找文件和目錄的磁盤使用情況的命令。du 命令在與各種選項(xiàng)一起使用時(shí)能以多種格式提供結(jié)果。
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:釋放頁(yè)緩存\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ù)掉嗎?所以,我們還是有必要來(lái)手動(dòng)進(jìn)行Linux下釋放內(nèi)存的操作,其實(shí)也就是 釋放緩存的操作了。/proc是一個(gè)虛擬文件系統(tǒng),我們可以通過(guò)對(duì)它的讀寫操作做為與kernel實(shí)體間進(jìn)行通信的一種手段.也就是說(shuō)可以通過(guò)修改 /proc中的文件,來(lái)對(duì)當(dāng)前kernel的行為做出調(diào)整.那么我們可以通過(guò)調(diào)整/proc/sys/vm/drop_caches來(lái)釋放內(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 和讀寫映射文件。否則在釋放緩存的過(guò)程中,可能會(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 緩存,用于已打開(kāi)的文件\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)存沒(méi)有釋放?\x0d\x0a但實(shí)際上,我們都知道這是因?yàn)長(zhǎng)inux對(duì)內(nèi)存的管理與Windows不同,free小并不是說(shuō)內(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)存泄露、溢出的問(wèn)題,從swap的使用情況是可以比較快速可以判斷的,但free上面反而比較難查看。我覺(jué)得既然核心是可以快速清空buffer或cache,但核心并沒(méi)有這樣做(默認(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ò) 誤等問(wèn)題時(shí),還是更應(yīng)該去分析應(yīng)用方面的原因,如用戶量太大導(dǎo)致內(nèi)存不足、發(fā)生應(yīng)用內(nèi)存溢出等情況,否則,清空buffer,強(qiáng)制騰出free的大小,可 能只是把問(wèn)題給暫時(shí)屏蔽了,所以說(shuō)一般情況下linux都不用經(jīng)常手動(dòng)釋放內(nèi)存。