jvm調(diào)優(yōu)從哪幾個(gè)方面 一般的Java項(xiàng)目需要JVM調(diào)優(yōu)嗎?注意哪些?
一般的Java項(xiàng)目需要JVM調(diào)優(yōu)嗎?注意哪些?Java以其開源、高效、跨平臺(tái)和良好的生態(tài)環(huán)境成為主流編程語言。即使是以前使用其他技術(shù)棧的公司,現(xiàn)在也在慢慢地向Java平臺(tái)遷移。我相信很多Java學(xué)生在
一般的Java項(xiàng)目需要JVM調(diào)優(yōu)嗎?注意哪些?
Java以其開源、高效、跨平臺(tái)和良好的生態(tài)環(huán)境成為主流編程語言。即使是以前使用其他技術(shù)棧的公司,現(xiàn)在也在慢慢地向Java平臺(tái)遷移。我相信很多Java學(xué)生在面試時(shí)都會(huì)被問到關(guān)于JVM調(diào)優(yōu)的問題,但是他們似乎很少在日常工作中進(jìn)行JVM調(diào)優(yōu)。您想為一般Java項(xiàng)目進(jìn)行JVM調(diào)優(yōu)嗎?
在我們討論JVM調(diào)優(yōu)之前,讓我們先討論一下JVM。什么是JVM?實(shí)際上,JVM是Java虛擬機(jī)的縮寫。Java能夠跨平臺(tái)的原因?qū)嶋H上是基于JVM。
盡管JVM本身是一個(gè)計(jì)算機(jī)程序,但它也有自己的一套軟件和硬件環(huán)境。
就像你買了一臺(tái)新電腦。系統(tǒng)安裝后,您可以正常使用計(jì)算機(jī)。但是很多用戶需要自定義電腦,比如桌面背景。同樣,JVM安裝后,即使沒有任何額外的設(shè)置,也可以正常工作,但在某些情況下,還需要對(duì)JVM進(jìn)行調(diào)優(yōu),而調(diào)優(yōu)的手段就是更改JVM參數(shù)。
JVM調(diào)優(yōu)的目的是使用盡可能少的內(nèi)存和CPU,使Java程序獲得更高的吞吐量和更低的延遲。
2. JVM常用調(diào)優(yōu)項(xiàng)
JVM最常用的調(diào)優(yōu)是更改JVM的默認(rèn)參數(shù),例如:
最大堆大?。?Xmx
新生成大小:-XMN
不朽生成的最小值:-XX:permsize
不朽生成的最大值:-XX:maxpermsize
事實(shí)上,JVM的默認(rèn)設(shè)置可以滿足一般項(xiàng)目的需要。似乎只要您更改參數(shù),JVM的調(diào)優(yōu)就非常簡(jiǎn)單,但不是我,而是您認(rèn)為的那么簡(jiǎn)單。
如果JVM調(diào)優(yōu)不好,會(huì)影響整個(gè)項(xiàng)目的穩(wěn)定性。在正常情況下,不建議調(diào)優(yōu)JVM,除非Java項(xiàng)目?jī)?nèi)存太高,服務(wù)器內(nèi)存太低。
為什么需要jvm調(diào)優(yōu)?
JVM調(diào)優(yōu)目標(biāo):使用較小的內(nèi)存占用來實(shí)現(xiàn)更高的吞吐量或更低的延遲。
在上線前測(cè)試或運(yùn)行程序的過程中,有時(shí)會(huì)出現(xiàn)一些JVM問題,比如CPU,負(fù)載過高,請(qǐng)求延遲,TPS降低,甚至內(nèi)存泄漏(每次垃圾收集時(shí)間越來越長(zhǎng),垃圾收集頻率越來越高,每次垃圾回收清理的垃圾數(shù)據(jù)越來越少),內(nèi)存溢出導(dǎo)致系統(tǒng)崩潰,因此有必要對(duì)JVM進(jìn)行調(diào)優(yōu),使程序在正常運(yùn)行效率的前提下獲得更高的用戶體驗(yàn)和效率。
jvm調(diào)優(yōu)和tomcat調(diào)優(yōu)的區(qū)別?
JVM調(diào)優(yōu)的主要目的是在程序執(zhí)行過程中合理分配內(nèi)存資源,并在程序執(zhí)行后設(shè)置內(nèi)存恢復(fù)機(jī)制。
Tomcat調(diào)優(yōu)主要是設(shè)置最大并發(fā)線程數(shù)、初始化期間創(chuàng)建的線程數(shù)以及超過最大并發(fā)線程數(shù)后可以等待連接的請(qǐng)求數(shù)。
jvm調(diào)優(yōu)參數(shù)?
-XMS initial heap size
-Xmx maximum heap size
-XMN young generation size(1.4或lattice)
-XX:newsize set young generation size(對(duì)于1.3/1.4)
-XX:maxnewsize young generation maximum(對(duì)于1.3/1.4)
-XX:permsize set perm Gen initial value
-XX:maxpermsize set perm Gen persistent generation最大值
-XSS每個(gè)線程的堆棧大小
-XX:threadstack size線程堆棧大小
-XX:newratio年輕一代(包括Eden和兩個(gè)幸存區(qū)域)與老一代(不包括持久性生成)的比率
-XX:survivoratio Eden區(qū)域與幸存區(qū)域的比率
-XX:largepagesizeinbytes內(nèi)存頁大小不能設(shè)置太大,這將影響perm的大小
-XX:快速優(yōu)化原始類型的usefastaccessormethods
-XX:禁用顯式系統(tǒng).gc()
-20:當(dāng)前互聯(lián)網(wǎng)領(lǐng)域正處于結(jié)構(gòu)調(diào)整時(shí)期。從大的發(fā)展趨勢(shì)來看,它正在從消費(fèi)互聯(lián)網(wǎng)向工業(yè)互聯(lián)網(wǎng)轉(zhuǎn)變。這個(gè)過程對(duì)Java程序員的影響主要集中在三個(gè)方面:一是技術(shù)升級(jí)的要求;二是行業(yè)經(jīng)驗(yàn)的要求;三是創(chuàng)新的要求。
盡管Java語言是一種完整的場(chǎng)景開發(fā)語言,在生產(chǎn)環(huán)境中采用Java將大大降低開發(fā)風(fēng)險(xiǎn),但仍有大量技術(shù)結(jié)構(gòu)陳舊的Java程序員。比如很多Java程序員還不掌握大數(shù)據(jù)、云計(jì)算等開發(fā)技術(shù),未來這些技術(shù)的應(yīng)用場(chǎng)景還會(huì)不斷增加,發(fā)布的機(jī)會(huì)也會(huì)越來越多。因此,對(duì)于Java程序員來說,如何及時(shí)升級(jí)技術(shù)是一個(gè)必須考慮的問題。
行業(yè)經(jīng)驗(yàn)也將在Java程序員的開發(fā)中發(fā)揮關(guān)鍵作用,特別是在工業(yè)互聯(lián)網(wǎng)階段。掌握一定的行業(yè)經(jīng)驗(yàn)可以顯著提高Java程序員的崗位競(jìng)爭(zhēng)力。目前,云計(jì)算技術(shù)正在從IAAs向PAAS和SaaS發(fā)展。未來云計(jì)算平臺(tái)將在行業(yè)內(nèi)垂直整合,這將明顯降低軟件開發(fā)的技術(shù)難度。此時(shí),行業(yè)經(jīng)驗(yàn)將成為程序員高效開發(fā)的關(guān)鍵因素。因此,Java程序員應(yīng)該在工作中積累更多的行業(yè)經(jīng)驗(yàn)。
最后,在大數(shù)據(jù)、云計(jì)算和物聯(lián)網(wǎng)技術(shù)的推動(dòng)下,程序員的創(chuàng)新能力將越來越受到重視。特別是在云計(jì)算技術(shù)的推動(dòng)下,未來將有大量的應(yīng)用級(jí)程序員升級(jí)為研發(fā)級(jí)程序員,研發(fā)級(jí)程序員的核心競(jìng)爭(zhēng)力是創(chuàng)新能力。對(duì)于初級(jí)Java程序員來說,培養(yǎng)自己的創(chuàng)新能力,研究生是一個(gè)不錯(cuò)的選擇。