tomcat設定記憶體引數
一.系統引數:
windows xp
tomcat6
jdk版本 java version "1.6.0_32"
二.用到的各引數介紹
1概述
.預設的java虛擬機器的大小比較小,在對大資料進行處理時java就會報錯:java.lang.OutOfMemoryError。
設定jvm記憶體的方法,對於單獨的.class,可以用下面的方法對Test執行時的jvm記憶體進行設定。
java -Xms64m -Xmx256m Test
2JVM記憶體分配設定
A:JVM記憶體分配設定的引數有四個:
-Xmx Java Heap最大值,預設值為實體記憶體的1/4,最佳設值應該視實體記憶體大小及計算機內其他記憶體開銷而定;
(注意:JVM 中最大堆大小有三方面限制:相關作業系統的資料模型(32-bt還是64-bit)限制;系統的可用虛擬記憶體限制;系統的可用實體記憶體限制。32位系統下,一般限制在1.5G~2G;64為作業系統對記憶體無限制。我在Windows Server 2003 系統,3.5G實體記憶體,JDK5.0下測試,最大可設定為1478m。)
-Xms Java Heap初始值,Server端JVM最好將-Xms和-Xmx設為相同值,開發測試機JVM可以保留預設值;
-Xmn Java Heap Young區大小,不熟悉最好保留預設值;
-Xss 每個執行緒的Stack大小,不熟悉最好保留預設值;
B:輔助資訊
- JVM提供了大量命令列引數,列印資訊,供除錯使用。主要有以下一些:
- -XX:+PrintGC
輸出形式:[GC 118250K->113543K(130112K), 0.0094143 secs]
[Full GC 121376K->10414K(130112K), 0.0650971 secs]
- -XX:+PrintGCDetails
輸出形式:[GC [DefNew: 8614K->781K(9088K), 0.0123035 secs] 118250K->113543K(130112K), 0.0124633 secs]
[GC [DefNew: 8614K->8614K(9088K), 0.0000665 secs][Tenured:112761K->10414K(121024K), 0.0433488 secs] 121376K->10414K(130112K),0.0436268 secs]
- -XX:+PrintGCTimeStamps -XX:+PrintGC:PrintGCTimeStamps可與上面兩個混合使用
輸出形式:11.851: [GC 98328K->93620K(130112K), 0.0082960 secs] - -XX:PrintHeapAtGC:列印GC前後的詳細堆疊資訊
輸出形式:
34.702: [GC {Heap before gc invocations=7:
def new generation total 55296K, used 52568K [0x1ebd0000, 0x227d0000, 0x227d0000)
eden space 49152K, 99% used [0x1ebd0000, 0x21bce430, 0x21bd0000)
from space 6144K, 55% used [0x221d0000, 0x22527e10, 0x227d0000)
to space 6144K, 0% used [0x21bd0000, 0x21bd0000, 0x221d0000)
tenured generation total 69632K, used 2696K [0x227d0000, 0x26bd0000, 0x26bd0000)
the space 69632K, 3% used [0x227d0000, 0x22a720f8, 0x22a72200, 0x26bd0000)
compacting perm gen total 8192K, used 2898K [0x26bd0000, 0x273d0000, 0x2abd0000)
the space 8192K, 35% used [0x26bd0000, 0x26ea4ba8, 0x26ea4c00, 0x273d0000)
ro space 8192K, 66% used [0x2abd0000, 0x2b12bcc0, 0x2b12be00, 0x2b3d0000)
rw space 12288K, 46% used [0x2b3d0000, 0x2b972060, 0x2b972200, 0x2bfd0000)
34.735: [DefNew: 52568K->3433K(55296K), 0.0072126 secs] 55264K->6615K(124928K)Heap after gc invocations=8:
def new generation total 55296K, used 3433K [0x1ebd0000, 0x227d0000, 0x227d0000)
eden space 49152K, 0% used [0x1ebd0000, 0x1ebd0000, 0x21bd0000)
from space 6144K, 55% used [0x21bd0000, 0x21f2a5e8, 0x221d0000)
to space 6144K, 0% used [0x221d0000, 0x221d0000, 0x227d0000)
tenured generation total 69632K, used 3182K [0x227d0000, 0x26bd0000, 0x26bd0000)
the space 69632K, 4% used [0x227d0000, 0x22aeb958, 0x22aeba00, 0x26bd0000)
compacting perm gen total 8192K, used 2898K [0x26bd0000, 0x273d0000, 0x2abd0000)
the space 8192K, 35% used [0x26bd0000, 0x26ea4ba8, 0x26ea4c00, 0x273d0000)
ro space 8192K, 66% used [0x2abd0000, 0x2b12bcc0, 0x2b12be00, 0x2b3d0000)
rw space 12288K, 46% used [0x2b3d0000, 0x2b972060, 0x2b972200, 0x2bfd0000)
}
, 0.0757599 secs] - -Xloggc:filename:與上面幾個配合使用,把相關日誌資訊記錄到檔案以便分析。
- 常見配置彙總
- 堆設定
- -Xms:初始堆大小
- -Xmx:最大堆大小
- -XX:NewSize=n:設定年輕代大小
- -XX:NewRatio=n:設定年輕代和年老代的比值。如:為3,表示年輕代與年老代比值為1:3,年輕代佔整個年輕代年老代和的1/4
- -XX:SurvivorRatio=n:年輕代中Eden區與兩個Survivor區的比值。注意Survivor區有兩個。如:3,表示Eden:Survivor=3:2,一個Survivor區佔整個年輕代的1/5
- -XX:MaxPermSize=n:設定持久代大小
- 收集器設定
- -XX:+UseSerialGC:設定序列收集器
- -XX:+UseParallelGC:設定並行收集器
- -XX:+UseParalledlOldGC:設定並行年老代收集器
- -XX:+UseConcMarkSweepGC:設定併發收集器
- 垃圾回收統計資訊
- -XX:+PrintGC
- -XX:+PrintGCDetails
- -XX:+PrintGCTimeStamps
- -Xloggc:filename
- 並行收集器設定
- -XX:ParallelGCThreads=n:設定並行收集器收集時使用的CPU數。並行收集執行緒數。
- -XX:MaxGCPauseMillis=n:設定並行收集最大暫停時間
- -XX:GCTimeRatio=n:設定垃圾回收時間佔程式執行時間的百分比。公式為1/(1+n)
- 併發收集器設定
- -XX:+CMSIncrementalMode:設定為增量模式。適用於單CPU情況。
- -XX:ParallelGCThreads=n:設定併發收集器年輕代收集方式為並行收集時,使用的CPU數。並行收集執行緒數。
- 堆設定
(1)當在命令提示符下啟動並使用JVM時(只對當前執行的類Test生效):
java -Xmx128m -Xms64m -Xmn32m -Xss16m Test
(2)當在整合開發環境下(如eclipse)啟動並使用JVM時:
a. 在eclipse根目錄下開啟eclipse.ini,預設內容為(這裡設定的是運行當前開發工具的JVM記憶體分配):
-vmargs
-Xms40m
-Xmx256m
-vmargs表示以下為虛擬機器設定引數,可修改其中的引數值,也可新增-Xmn,-Xss,另外,eclipse.ini內還可以設定非堆記憶體,如:-XX:PermSize=56m,-XX:MaxPermSize=128m。
此處設定的引數值可以通過以下配置在開發工具的狀態列顯示:
在eclipse根目錄下建立檔案options,檔案內容為:org.eclipse.ui/perf/showHeapStatus=true
修改eclipse根目錄下的eclipse.ini檔案,在開頭處新增如下內容:
-debug
options
-vm
javaw.exe
重新啟動eclipse,就可以看到下方狀態條多了JVM資訊。
b. 開啟eclipse-視窗-首選項-Java-已安裝的JRE(對在當前開發環境中執行的java程式皆生效)
編輯當前使用的JRE,在預設VM引數中輸入:-Xmx128m -Xms64m -Xmn32m -Xss16m
c. 開啟eclipse-執行-執行-Java應用程式(只對所設定的java類生效)
選定需設定記憶體分配的類-自變數,在VM自變數中輸入:-Xmx128m -Xms64m -Xmn32m -Xss16m
注:如果在同一開發環境中同時進行了b和c設定,則b設定生效,c設定無效,如:
開發環境的設定為:-Xmx256m,而類Test的設定為:-Xmx128m -Xms64m,則執行Test時生效的設定為:
-Xmx256m -Xms64m
(3)當在伺服器環境下(如Tomcat)啟動並使用JVM時(對當前伺服器環境下所以Java程式生效):
a. 設定環境變數:
變數名:CATALINA_OPTS
變數值:-Xmx128m -Xms64m -Xmn32m -Xss16m
b. 開啟Tomcat根目錄下的bin資料夾,編輯catalina.bat,在set JAVA_OPTS=%JAVA_OPTS%....這句之後加上:set JAVA_OPTS=%JAVA_OPTS% -Xms1024m -Xmx1024m
c、若沒有catalina.bat,只有tomcat.exe,tomcat6w.exe;則可以在啟動tomcat6w.exe 後 右鍵配置--Java--java option 下面輸入:
-Xmx256m
-Xms64m
也可以找到登錄檔HKEY_LOCAL_MACHINE\SOFTWARE\Apache Software Foundation\Tomcat Service Manager\Tomcat6\Parameters\JavaOptions
原值為
-Dcatalina.home="C:\ApacheGroup\Tomcat 6.0"
-Djava.endorsed.dirs="C:\ApacheGroup\Tomcat 6.0\common\endorsed"
-Xrs
加入
-Xms300m
-Xmx350m
注意登錄檔中的各引數最後不允許有空格
重起tomcat服務,設定生效
操作截圖:
使用登錄檔方式修改:
相關推薦
tomcat設定記憶體引數
一.系統引數: windows xp tomcat6 jdk版本 java version "1.6.0_32" 二.用到的各引數介紹 1概述 .預設的java虛擬機器的大小比較小,在對大資料進行處理時java就會報錯:java.lang.OutOfMemoryError。
關於tomcat的記憶體引數優化——如何配置catalina.sh的JAVA_OPTS?
以下是實體記憶體為16G的建議配置: export JAVA_OPTS="-server -Xms4096m -Xmx4096m -Xss256k -XX:PermSize=256m -XX:MaxPermSize=4096m -XX:NewSize=512m -XX:Ma
Linux 下tomcat設定JVM引數
編輯 tomcat/bin 下catalina.sh 在第一行加入 JAVA_OPTS="-Xms36m -Xmx36m -Xss256K -XX:ParallelGCThreads=8 -XX:+UseConcMarkSweepGC -Xloggc:/var/tomcat
JIRA應用的記憶體引數設定不當+容器沒有對資源進行限制導致服務掛掉的例子
背景: 應用的部署結構是這樣的:使用rancher管理的Docker叢集,有三臺物理主機,二十多個Docker容器, 提供的功能是問題跟蹤(JIRA),文件管理(Confluence),程式碼託管(svn,gitlab),持續整合(jenkins,gitlab-ci + Docker),程式碼質量管理(Son
Tomcat 調節快取與記憶體引數
Tomcat 調節快取與記憶體引數 2018年03月27日 21:12:33 在風中的意志 閱讀數:280 版權宣告:歡迎轉載,轉載請說明出處https://csdn.yanxml.com。大資料Github專案地址https://github.com/SeanYanxml/bigd
JVM引數,啟動jar 包以及 啟動tomcat的 JVM引數設定
一,基本的啟動引數的位置 public class TestJVM { public static void main(String[] args) { long maxM = Runtime.getRuntime().maxMemory(); long totalM =
SAP ABAP 使用記憶體引數設定SET /GET PARAMTER ID
更多內容關注公眾號:SAP Technical SET /GET PARAMTER ID使用SPA/GPA 引數--SAP記憶體引數設定 這是在外部程式之間傳送資料的最常用方法。使用EXPORT/IMPORT資料(ABAP
eclipse /myeclipse 設定tomcat 的記憶體
調整jvm記憶體: 1. java.lang.OutOfMemoryError: Java heap space --- JVM Heap (堆) 溢位 JVM 在啟動的時候會自動設定 JVM Heap 的值, 其初始空間 (即 -Xms) 是實體記憶體個的1/64
設定tomcat啟動記憶體及檢視某程序目前正在使用記憶體
tomcat啟動記憶體,及JVM啟動記憶體。主要分成兩種:堆記憶體,非堆記憶體。 -Xms256m -Xmx768m -XX:PermSize=128M -XX:MaxPermSize=256M 可以看到 -Xms啟動堆記憶體 -Xmx最大堆記憶體 -XX:PermSize
Tomcat 伺服器配置及遠端除錯和不同web專案session共享方法以及設定TOMCAT的記憶體
tomcat環境變數配置 classpath = ./;%JAVA_HOME%/lib/dt.jar;%JAVA_HOME%/lib/tools.jar;%TOMCAT_HOMT%/common/lib/servlet-api.jar;%TOMCAT_HOME%/com
tomcat設定執行記憶體
在tomcat的bin目錄下的catalina.bat檔案中,新增 set JAVA_OPTS=-Xms512m -Xmx2048m -Xss1024K -XX:PermSize=64m -XX:MaxPermSize=128m 設定記憶體大小資料按具體
MyEclipse2017 下查詢和設定伺服器 Tomcat JVM記憶體大小
1.為什麼要設定JVM記憶體大小呢? 因為如果你的程式執行時超過JVM預設記憶體大小,就不會報傳說中記憶體溢位異常。Exception in thread "main" java.lang.OutOfMemoryError: Java heap spaceat junit.B
Oracle基礎知識--記憶體引數設定
from http://www.cnblogs.com/afant/archive/2008/06/25/1229448.html 1.SGA區的大小 SGA=log_buffer + Large_pool_size + java_pool_size + sha
JVM記憶體引數設定
在一些規模稍大的應用中,Java虛擬機器(JVM)的記憶體設定尤為重要,想在專案中取得好的效率,GC(垃圾回收)的設定是第一步。 PermGen space:全稱是Permanent Generation space.就是說是永久儲存的區域,用於存放Class和Meta
Eclipse中啟動Tomcat,設定記憶體
-Xms128M -Xmx512M -XX:PermSize=64M -XX:MaxPermSize=128M -Xms128m JVM初始分配的堆記憶體 -Xmx512m JVM最大允許分配的堆記憶
jenkins,Tomcat重啟指令碼,設定jvm引數之後遇到了一個坑。
如下是我的重啟指令碼 #/bin/sh source /etc/profile sh /opt/kms_jsoncach.sh pid=`ps -ef | grep "APPmanager" | grep -v 'grep\|tail\|more\|le
Tomcat 啟動 設定JVM引數& 使用指定的配置檔案啟動
1、設定虛擬機器引數 若需要設定TOMCAT JAVA虛擬機器的引數,可在環境變數中設定CATALINA_OPTS或JAVA_OPTS: export CATALINA_OPTS="-Xms128m -Xmx1024m -XX:PermSize=64M -XX:MaxPer
Tomcat防止記憶體溢位設定
一、設定Tomcat啟動的初始記憶體 其初始空間(即-Xms)是實體記憶體的1/64,最大空間(-Xmx)是實體記憶體的1/4。可以利用JVM提供的-Xmn -Xms -Xmx等選項可進行設定 例項,以下給出1G記憶體環境下java jvm 的引數設定參考:
java執行時記憶體引數設定
package com.ibank.web; import com.tasfe.framework.netty.TasfeApplication; import com.tasfe.framework.
Tomcat 設定JVM記憶體大小
我的伺服器的配置: # OS specific support. $var _must_ be set to either true or false. JAVA_OPTS="-Xms1024m -Xmx4096m -Xss1024K -XX:PermSize=512m