jvm調優(yōu)從哪幾個方面 一般的Java項目需要JVM調優(yōu)嗎?注意哪些?
一般的Java項目需要JVM調優(yōu)嗎?注意哪些?Java以其開源、高效、跨平臺和良好的生態(tài)環(huán)境成為主流編程語言。即使是以前使用其他技術棧的公司,現在也在慢慢地向Java平臺遷移。我相信很多Java學生在
一般的Java項目需要JVM調優(yōu)嗎?注意哪些?
Java以其開源、高效、跨平臺和良好的生態(tài)環(huán)境成為主流編程語言。即使是以前使用其他技術棧的公司,現在也在慢慢地向Java平臺遷移。我相信很多Java學生在面試時都會被問到關于JVM調優(yōu)的問題,但是他們似乎很少在日常工作中進行JVM調優(yōu)。您想為一般Java項目進行JVM調優(yōu)嗎?
在我們討論JVM調優(yōu)之前,讓我們先討論一下JVM。什么是JVM?實際上,JVM是Java虛擬機的縮寫。Java能夠跨平臺的原因實際上是基于JVM。
盡管JVM本身是一個計算機程序,但它也有自己的一套軟件和硬件環(huán)境。
就像你買了一臺新電腦。系統(tǒng)安裝后,您可以正常使用計算機。但是很多用戶需要自定義電腦,比如桌面背景。同樣,JVM安裝后,即使沒有任何額外的設置,也可以正常工作,但在某些情況下,還需要對JVM進行調優(yōu),而調優(yōu)的手段就是更改JVM參數。
JVM調優(yōu)的目的是使用盡可能少的內存和CPU,使Java程序獲得更高的吞吐量和更低的延遲。
2. JVM常用調優(yōu)項
JVM最常用的調優(yōu)是更改JVM的默認參數,例如:
最大堆大小:-Xmx
新生成大?。?XMN
不朽生成的最小值:-XX:permsize
不朽生成的最大值:-XX:maxpermsize
事實上,JVM的默認設置可以滿足一般項目的需要。似乎只要您更改參數,JVM的調優(yōu)就非常簡單,但不是我,而是您認為的那么簡單。
如果JVM調優(yōu)不好,會影響整個項目的穩(wěn)定性。在正常情況下,不建議調優(yōu)JVM,除非Java項目內存太高,服務器內存太低。
為什么需要jvm調優(yōu)?
JVM調優(yōu)目標:使用較小的內存占用來實現更高的吞吐量或更低的延遲。
在上線前測試或運行程序的過程中,有時會出現一些JVM問題,比如CPU,負載過高,請求延遲,TPS降低,甚至內存泄漏(每次垃圾收集時間越來越長,垃圾收集頻率越來越高,每次垃圾回收清理的垃圾數據越來越少),內存溢出導致系統(tǒng)崩潰,因此有必要對JVM進行調優(yōu),使程序在正常運行效率的前提下獲得更高的用戶體驗和效率。
jvm調優(yōu)參數?
-XMS initial heap size
-Xmx maximum heap size
-XMN young generation size(1.4或lattice)
-XX:newsize set young generation size(對于1.3/1.4)
-XX:maxnewsize young generation maximum(對于1.3/1.4)
-XX:permsize set perm Gen initial value
-XX:maxpermsize set perm Gen persistent generation最大值
-XSS每個線程的堆棧大小
-XX:threadstack size線程堆棧大小
-XX:newratio年輕一代(包括Eden和兩個幸存區(qū)域)與老一代(不包括持久性生成)的比率
-XX:survivoratio Eden區(qū)域與幸存區(qū)域的比率
-XX:largepagesizeinbytes內存頁大小不能設置太大,這將影響perm的大小
-XX:快速優(yōu)化原始類型的usefastaccessormethods
-XX:禁用顯式系統(tǒng).gc()
-20:JVM性能調優(yōu)有很多設置,可以通過參考JVM參數來設置。調優(yōu)的主要目的是控制GC的行為。GC是后臺處理,但它也會消耗系統(tǒng)性能。因此,GC的行為往往會根據系統(tǒng)運行程序的特點而改變,從而控制JVM堆棧的大小。一般來說,您不需要修改JVM的內存分配。但是,當程序中的新一代對象在一段時間內增多時,需要控制新一代堆的大小。同時,需要控制JVM的總大小以避免內存溢出控制JVM線程的內存分配。如果是多線程程序,那么生成線程和運行線程所消耗的內存也可以控制。經過一定時間的觀察,配置最優(yōu)的結果
JVM調優(yōu)主要是在程序執(zhí)行過程中合理分配內存資源,設置程序執(zhí)行后的內存恢復機制。
Tomcat調優(yōu)主要是設置最大并發(fā)線程數、初始化期間創(chuàng)建的線程數以及超過最大并發(fā)線程數后可以等待連接的請求數。
jvm性能調優(yōu)都做了什么?
1. 布爾型參數值
-XX:<option> “”表示啟用選項
-XX:<option> “”表示關閉選項
2。數值型參數值
-XX:<option>=<number>,為該選項設置一個數值型值,該值可以跟在單位后面,例如“m”或“m”表示兆字節(jié)“K”或“K”千字節(jié)“g”或“g”千兆字節(jié)。32K與32768大小相同。
3. 字符串類型參數值:
-XX:<option>=<string>為選項設置字符串類型值,該值通常用于指定文件、路徑或一系列命令列表。
例如:-XX:heapdumppath=/轉儲.core