新聞中心
Linux是一種開源操作系統(tǒng),它是一個(gè)非常強(qiáng)大的平臺(tái),具有強(qiáng)大的擴(kuò)展性和可定制性。它非常受歡迎,包括開發(fā)、科研、娛樂以及服務(wù)器和其他應(yīng)用程序。在Linux環(huán)境中運(yùn)行的應(yīng)用程序,通常是多線程的,并且需要使用一定數(shù)量的內(nèi)存來運(yùn)行。這篇文章將介紹如何在Linux中調(diào)整線程內(nèi)存,以使應(yīng)用程序的性能得到優(yōu)化。

1. 了解Linux內(nèi)存管理方法
在Linux環(huán)境中,系統(tǒng)管理內(nèi)存的方法包括頁(yè)式存儲(chǔ)管理和虛擬內(nèi)存管理。頁(yè)式存儲(chǔ)管理將內(nèi)存劃分為頁(yè)面,每個(gè)頁(yè)面大小通常為4KB,然后將每個(gè)頁(yè)面加入內(nèi)存中。當(dāng)系統(tǒng)出現(xiàn)內(nèi)存不足的情況時(shí),操作系統(tǒng)將在硬盤上為這些頁(yè)面分配一個(gè)常規(guī)文件,稱為交換文件。這個(gè)文件將被用作內(nèi)存,這樣可以讓系統(tǒng)繼續(xù)運(yùn)行。
虛擬內(nèi)存管理將進(jìn)程的內(nèi)存劃分為邏輯地址和物理地址。邏輯地址是進(jìn)程中的地址,而物理地址是實(shí)際的內(nèi)存地址。虛擬內(nèi)存管理將邏輯地址轉(zhuǎn)換為物理地址,以便訪問內(nèi)存。這種管理方法可以使多個(gè)進(jìn)程訪問相同的內(nèi)存區(qū)域,而不會(huì)相互干擾。
2. 調(diào)整線程內(nèi)存的方法
通常,操作系統(tǒng)會(huì)默認(rèn)為每個(gè)進(jìn)程分配一定的內(nèi)存。但是,在很多情況下,這并不足夠。為了讓應(yīng)用程序能夠更好地運(yùn)行,我們需要將更多的內(nèi)存分配給該應(yīng)用程序。下面是如何調(diào)整線程內(nèi)存的方法:
(1)使用“top”命令查看內(nèi)存使用情況
我們需要使用“top”命令查看目前系統(tǒng)中正在使用的內(nèi)存的情況。在終端中運(yùn)行“top”命令,它將顯示系統(tǒng)中進(jìn)程和線程的使用情況。我們可以看到,每個(gè)進(jìn)程和線程使用的內(nèi)存量都會(huì)被列出。
(2)使用“ulimit”命令調(diào)整線程內(nèi)存限制
ulimit命令可以用來限制進(jìn)程使用的內(nèi)存量。我們可以使用以下命令來設(shè)置線程的內(nèi)存限制:ulimit -m ,其中“size”指的是分配給線程的內(nèi)存大?。ㄒ訩B為單位)。這樣可以確保線程在使用內(nèi)存時(shí)不會(huì)超出限制,但是也會(huì)影響一些應(yīng)用的正常運(yùn)行。
(3)使用“pmap”命令查看線程內(nèi)存映射
使用“pmap”命令可以查看線程內(nèi)存映射。這個(gè)命令將顯示線程每個(gè)地址空間的大小。它還可以告訴我們哪些內(nèi)存地址對(duì)線程程序非常重要,以便您可以對(duì)它們進(jìn)行更多的調(diào)整。
(4)使用“/proc//maps”文件
我們還可以通過訪問“/proc//maps”文件來查看線程的內(nèi)存映射。這個(gè)文件顯示了進(jìn)程的地址空間中每個(gè)映射區(qū)域的詳細(xì)信息。我們可以使用該文件來查看哪些線程使用了大量?jī)?nèi)存,以便我們可以針對(duì)性地進(jìn)行調(diào)整。
3. 結(jié)論
相關(guān)問題拓展閱讀:
- 如何手動(dòng)釋放Linux內(nèi)存的方法
- linux啟動(dòng)內(nèi)存參數(shù)
如何手動(dòng)釋放Linux內(nèi)存的方法
Linux釋放內(nèi)存的命令:
sync
echo 1 > /proc/sys/vm/drop_caches
drop_caches的值可以是0-3之間的數(shù)字,代表不同的含義:
0:不釋放(系統(tǒng)默認(rèn)值)
1:釋放頁(yè)緩存
2:釋放dentries和inodes
3:釋放所有緩存
釋放完內(nèi)存后改回去讓系統(tǒng)重新自動(dòng)分配內(nèi)存。
echo 0 >/proc/sys/vm/drop_caches
free -m #看內(nèi)存是否已經(jīng)釋放掉了。
如果我們需要釋放所有緩存,就輸入下面的命令:跡蠢清
echo 3 > /proc/sys/vm/drop_caches
######### Linux釋放內(nèi)存的相關(guān)知識(shí) ###############
在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)存(清理緩存)的操作了。
Linux系統(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,也就 是不釋放緩存。
一般復(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í)間。”
釋放內(nèi)存前先使用sync命令做同步,以確保文件系統(tǒng)的完整性,將所有未寫的系統(tǒng)緩沖姿前區(qū)寫到磁盤中,包含已修改的 i-node、已延遲的塊 I/O 和讀寫映射文件。否則在釋放緩存的過程中,可能會(huì)丟失未保存的文件。
# free -m
totalusedfree shared buffers cached
Mem:
-/ buffers/cache:
Swap:
之一行用全局角度描述系統(tǒng)使用的內(nèi)存狀況:
total 內(nèi)存總數(shù)
used 已經(jīng)使用的內(nèi)存數(shù),一般情況這個(gè)值會(huì)比較大,因?yàn)檫@個(gè)值包括了cache 應(yīng)用程序使用的內(nèi)存
free 空閑的內(nèi)存數(shù)
shared 多個(gè)進(jìn)程共享的內(nèi)存總額
buffers 緩存,主要用于目錄方面,inode值等(ls大目錄可看到這個(gè)值增加)
cached 緩存,用于已打開的文件
第二行描述應(yīng)用程序的內(nèi)存使用:
-buffers/cache 的內(nèi)存數(shù):used – buffers – cached
buffers/cache 的內(nèi)存數(shù):free buffers cached
前個(gè)值表示-buffers/cache 應(yīng)用程序使用的內(nèi)存大小,used減去緩存值
后個(gè)值表示 buffers/cache 所有可供應(yīng)用程序使用的內(nèi)存大小,free加上緩存值
第三行表示swap的使用:
used 已使用
free 未使用
可用的內(nèi)存=free memory buffers cached。
為什么free這么小,是否關(guān)閉應(yīng)用后內(nèi)存沒有釋放?
但實(shí)際上,我們都知道這是因?yàn)長(zhǎng)inux對(duì)內(nèi)存的管理與Windows不同,free小并不是說內(nèi)存不夠用了,應(yīng)該看的是free的第二行最后一個(gè)值:-/ buffers/cache:,這才是系統(tǒng)可用的內(nèi)存大小。
實(shí)際項(xiàng)目中的經(jīng)驗(yàn)告訴我們,如果因?yàn)槭菓?yīng)用有像內(nèi)存泄露、溢出的問題,從swap的使用情況是可以比較快速可以判斷的,但free上面反而比較難查看。我覺得既然核心是可以快速清空buffer或cache,但核心并沒有這樣做(默認(rèn)值是0),我們不應(yīng)該隨便去改變它。
一般情況下,應(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)存。
1、首先打開Linux命令窗口,可使用
快捷鍵
Ctrl+Alt+T打開。
2、這時(shí)查看一下當(dāng)前Linux系統(tǒng)內(nèi)存使用情況,使用命令:Free –m,total 內(nèi)存總數(shù),used 已雀閉經(jīng)使用的內(nèi)存數(shù),free 空閑的內(nèi)存數(shù)。
3、接下來的操作需要先獲取高級(jí)用戶權(quán)限,輸入命令:sudo -i,確定后輸入高級(jí)用戶密碼。
4、這時(shí)進(jìn)行拷貝文件拷貝,增加內(nèi)存使用量(即used的占用量),輸入命令: cp -r /etc ~/test/。
5、執(zhí)行命令結(jié)束后,再次查看一下當(dāng)前Linux系統(tǒng)內(nèi)存使用情況,發(fā)現(xiàn)有70M的內(nèi)存被cached用了。使用命令:Free –m。
6、接下頃坦裂來釋放已被占用的緩存,輸入命令: cat /proc/sys/vm/drop_caches,回車后返回結(jié)果0。
7、接著輸入命令:sync,回車后繼續(xù)輸入命令:echo 3 > /proc/sys/vm/drop_caches,回車后繼續(xù)輸入:cat /proc/sys/vm/drop_caches,回車后返回結(jié)果3,將/proc/sys/vm/drop_caches值設(shè)為3。
8、這樣緩存釋放就已經(jīng)完成了,再次執(zhí)行信虧命令Free –m看看,通過圖中可以對(duì)比看到,內(nèi)存被釋放了218M。
linux啟動(dòng)內(nèi)存參數(shù)
啟動(dòng)參數(shù)共分為三類;
其一是標(biāo)準(zhǔn)參數(shù)(-),所有的JVM實(shí)現(xiàn)都必須實(shí)現(xiàn)這些參數(shù)的功能,而且向后衡斗兼容;
其二是非標(biāo)準(zhǔn)參數(shù)(-X),默認(rèn)jvm實(shí)現(xiàn)這些參數(shù)的功能,但是并不保證所有jvm實(shí)現(xiàn)都滿足,且不保證向后兼容;
其三是非Stable參數(shù)(-XX),此類參數(shù)各個(gè)jvm實(shí)現(xiàn)會(huì)有所不同,將來可能會(huì)隨時(shí)取消,需要慎重使用;
本咐如磨文主要描述標(biāo)準(zhǔn)參數(shù)橡肆部分,剩下的兩個(gè)部分將會(huì)陸續(xù)推出;
標(biāo)準(zhǔn)參數(shù)列表如下:
-client
設(shè)置jvm使用client模式,特點(diǎn)是啟動(dòng)速度比較快,但運(yùn)行時(shí)性能和內(nèi)存管理效率不高,通常用于客戶端應(yīng)用程序或者PC應(yīng)用開發(fā)和調(diào)試。
-server
設(shè)置jvm使server模式,特點(diǎn)是啟動(dòng)速度比較慢,但運(yùn)行時(shí)性能和內(nèi)存管理效率很高,適用于生產(chǎn)環(huán)境。在具有64位能力的jdk環(huán)境下將默認(rèn)啟用該模式,而忽略-client參數(shù)。
-agentlib:libname
用于裝載本地lib包;
其中l(wèi)ibname為本地代理庫(kù)文件名,默認(rèn)搜索路徑為環(huán)境變量PATH中的路徑,options為傳給本地庫(kù)啟動(dòng)時(shí)的參數(shù),多個(gè)參數(shù)之間用逗號(hào)分隔。 在Windows平臺(tái)上jvm搜索本地庫(kù)名為libname.dll的文件,在linux上jvm搜索本地庫(kù)名為libname.so的文件,搜索路徑環(huán) 境變量在不同系統(tǒng)上有所不同,比如Solaries上就默認(rèn)搜索LD_LIBRARY_PATH。
比如:-agentlib:hprof
用來獲取jvm的運(yùn)行情況,包括CPU、內(nèi)存、線程等的運(yùn)行數(shù)據(jù),并可輸出到指定文件中;windows中搜索路徑為JRE_HOME/bin/hprof.dll。
-agentpath:pathname關(guān)于linux 線程內(nèi)存調(diào)整的介紹到此就結(jié)束了,不知道你從中找到你需要的信息了嗎 ?如果你還想了解更多這方面的信息,記得收藏關(guān)注本站。
香港服務(wù)器選創(chuàng)新互聯(lián),2H2G首月10元開通。
創(chuàng)新互聯(lián)(www.cdcxhl.com)互聯(lián)網(wǎng)服務(wù)提供商,擁有超過10年的服務(wù)器租用、服務(wù)器托管、云服務(wù)器、虛擬主機(jī)、網(wǎng)站系統(tǒng)開發(fā)經(jīng)驗(yàn)。專業(yè)提供云主機(jī)、虛擬主機(jī)、域名注冊(cè)、VPS主機(jī)、云服務(wù)器、香港云服務(wù)器、免備案服務(wù)器等。
文章標(biāo)題:Linux線程內(nèi)存調(diào)整方法詳解(linux線程內(nèi)存調(diào)整)
轉(zhuǎn)載注明:http://fisionsoft.com.cn/article/cdpsidi.html


咨詢
建站咨詢
