自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

專家答疑 Tomcat的JVM內(nèi)存大小如何設(shè)置?

開(kāi)發(fā) 后端
這里向大家描述一下如何設(shè)置Tomcat的JVM內(nèi)存大小,Tomcat本身不能直接在計(jì)算機(jī)上運(yùn)行,需要依賴于硬件基礎(chǔ)之上的操作系統(tǒng)和一個(gè)JVM。

本文和大家重點(diǎn)討論一下如何設(shè)置Tomcat的JVM內(nèi)存大小,JAVA程序啟動(dòng)時(shí)JVM都會(huì)分配一個(gè)初始內(nèi)存和***內(nèi)存給這個(gè)應(yīng)用程序。這個(gè)初始內(nèi)存和***內(nèi)存在一定程度都會(huì)影響程序的性能。

如何設(shè)置Tomcat的JVM內(nèi)存大小

    Tomcat本身不能直接在計(jì)算機(jī)上運(yùn)行,需要依賴于硬件基礎(chǔ)之上的操作系統(tǒng)和一個(gè)JVM。JAVA程序啟動(dòng)時(shí)JVM都會(huì)分配一個(gè)初始JVM內(nèi)存和***JVM內(nèi)存給這個(gè)應(yīng)用程序。這個(gè)初始內(nèi)存和***內(nèi)存在一定程度都會(huì)影響程序的性能。比如說(shuō)在應(yīng)用程序用到***內(nèi)存的時(shí)候,JVM是要先去做垃圾回收的動(dòng)作,釋放被占用的一些內(nèi)存。所以想調(diào)整Tomcat的啟動(dòng)時(shí)初始內(nèi)存和***內(nèi)存就需要向JVM聲明,一般的JAVA程序在運(yùn)行都可以通過(guò)中-Xms-Xmx來(lái)調(diào)整應(yīng)用程序的初始內(nèi)存和***內(nèi)存:

    這兩個(gè)值的大小一般根據(jù)需要進(jìn)行設(shè)置。初始化堆的大小執(zhí)行了虛擬機(jī)在啟動(dòng)時(shí)向系統(tǒng)申請(qǐng)的內(nèi)存的大小。一般而言,這個(gè)參數(shù)不重要。但是有的應(yīng)用程序在大負(fù)載的情況下會(huì)急劇地占用更多的內(nèi)存,此時(shí)這個(gè)參數(shù)就是顯得非常重要,如果虛擬機(jī)啟動(dòng)時(shí)設(shè)置使用的內(nèi)存比較小而在這種情況下有許多對(duì)象進(jìn)行初始化,虛擬機(jī)就必須重復(fù)地增加內(nèi)存來(lái)滿足使用。由于這種原因,我們一般把-Xms和-Xmx設(shè)為一樣大,而堆的***值受限于系統(tǒng)使用的物理內(nèi)存。一般使用數(shù)據(jù)量較大的應(yīng)用程序會(huì)使用持久對(duì)象,內(nèi)存使用有可能迅速地增長(zhǎng)。當(dāng)應(yīng)用程序需要的內(nèi)存超出堆的***值時(shí)虛擬機(jī)就會(huì)提示內(nèi)存溢出,并且導(dǎo)致應(yīng)用服務(wù)崩潰。因此一般建議堆的***值設(shè)置為可用JVM內(nèi)存的***值的80%。

Tomcat默認(rèn)可以使用的內(nèi)存為128MB,在較大型的應(yīng)用項(xiàng)目中,這點(diǎn)內(nèi)存是不夠的,需要調(diào)大。有以下幾種方法可以選用:

***種方法:

  Windows下,在文件/bin/catalina.bat,Unix下,在文件/bin/catalina.sh的前面,增加如下設(shè)置:

  JAVA_OPTS='-Xms【初始化內(nèi)存大小】-Xmx【可以使用的***內(nèi)存】'

  需要把這個(gè)兩個(gè)參數(shù)值調(diào)大。例如:

  JAVA_OPTS='-Xms256m-Xmx512m'

  表示初始化內(nèi)存為256MB,可以使用的***內(nèi)存為512MB。

第二種方法:環(huán)境變量中設(shè)

變量名:JAVA_OPTS

變量值:-Xms512m-Xmx512m

第三種方法:前兩種方法針對(duì)的是bin目錄下有catalina.bat的情況(比如直接解壓的Tomcat等),但是有些安裝版的Tomcat下沒(méi)有catalina.bat,這個(gè)時(shí)候可以采用如下方法,當(dāng)然這個(gè)方法也是最通用的方法:

打開(kāi)tomcatHome/\bin/\tomcat5w.exe,點(diǎn)擊Java選項(xiàng)卡,然后將會(huì)發(fā)現(xiàn)其中有這么兩項(xiàng):Initialmemorypool和Maximummemorypool.Initialmemorypool這個(gè)就是初始化設(shè)置的內(nèi)存的大小。Maximummemorypool這個(gè)是***JVM內(nèi)存的大小設(shè)置完了就按確定然后再重啟TOMCAT你就會(huì)發(fā)現(xiàn)tomcat中jvm可用的內(nèi)存改變了。

  另外需要考慮的是Java提供的垃圾回收機(jī)制。虛擬機(jī)的堆大小決定了虛擬機(jī)花費(fèi)在收集垃圾上的時(shí)間和頻度。收集垃圾可以接受的速度與應(yīng)用有關(guān),應(yīng)該通過(guò)分析實(shí)際的垃圾收集的時(shí)間和頻率來(lái)調(diào)整。如果堆的大小很大,那么完全垃圾收集就會(huì)很慢,但是頻度會(huì)降低。如果你把堆的大小和內(nèi)存的需要一致,完全收集就很快,但是會(huì)更加頻繁。調(diào)整堆大小的的目的是最小化垃圾收集的時(shí)間,以在特定的時(shí)間內(nèi)***化處理客戶的請(qǐng)求。在基準(zhǔn)測(cè)試的時(shí)候,為保證***的性能,要把堆的大小設(shè)大,保證垃圾收集不在整個(gè)基準(zhǔn)測(cè)試的過(guò)程中出現(xiàn)。

    如果系統(tǒng)花費(fèi)很多的時(shí)間收集垃圾,請(qǐng)減小堆大小。一次完全的垃圾收集應(yīng)該不超過(guò)3-5秒。如果垃圾收集成為瓶頸,那么需要指定代的大小,檢查垃圾收集的詳細(xì)輸出,研究垃圾收集參數(shù)對(duì)性能的影響。一般說(shuō)來(lái),你應(yīng)該使用物理內(nèi)存的80%作為堆大小。當(dāng)增加處理器時(shí),記得增加內(nèi)存,因?yàn)榉峙淇梢圆⑿羞M(jìn)行,而垃圾收集不是并行的。

    一個(gè)要注意的地方:建議把內(nèi)存的***值跟***值的差值縮小,不然會(huì)浪費(fèi)很多內(nèi)存的,***值加大,***值可以隨便設(shè),但是要根據(jù)實(shí)際的物理內(nèi)存,如果內(nèi)存設(shè)置太大了,比如設(shè)置了512M***內(nèi)存,但如果沒(méi)有512M可用內(nèi)存,Tomcat就不能啟動(dòng),還有可能存在內(nèi)存被系統(tǒng)回收,終止進(jìn)程的情況。

【編輯推薦】

  1. Eclipse中進(jìn)行JVM內(nèi)存設(shè)置
  2. JVM內(nèi)存限制問(wèn)題解決方案
  3. 揭露MyEclipse JVM內(nèi)存不足的內(nèi)幕
  4. 專家指導(dǎo) 如何進(jìn)行JVM參數(shù)配置
  5. 巧解IBM JVM for Linux onPOWER性能調(diào)優(yōu)

 

責(zé)任編輯:佚名 來(lái)源: blog.csdn.net
相關(guān)推薦

2010-09-17 15:47:14

TOMCATJVM

2010-09-17 13:10:29

JVMJava虛擬機(jī)

2010-09-26 10:29:45

JVMJava虛擬機(jī)

2010-09-27 15:03:34

TomcatJVM內(nèi)存設(shè)置

2010-09-27 10:01:02

Tomcat5JVM

2016-10-19 13:32:31

JavaMemory

2013-09-02 10:08:03

虛擬化核心應(yīng)用

2010-09-25 13:13:17

tomcatJVM

2019-11-26 09:55:53

Windows 10虛擬內(nèi)存Windows

2010-06-10 15:03:51

IT業(yè)界JavaTomcat 7

2010-08-04 15:55:08

Flex是什么

2010-07-15 13:34:32

Perl隨機(jī)數(shù)

2010-06-10 16:27:17

什么是uml

2010-06-07 19:27:40

UML是什么

2010-09-27 11:00:27

TomcatJVM內(nèi)存

2010-01-22 10:45:05

2010-09-28 11:32:30

HTML DOM是什么

2010-07-05 10:20:27

UML圖

2010-01-20 16:12:16

專家答疑端到端加密保護(hù)數(shù)據(jù)

2010-09-26 15:16:37

MyEclipseJVM
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)