1. 程式人生 > >tomcat設定記憶體引數

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:輔助資訊

  1. 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:與上面幾個配合使用,把相關日誌資訊記錄到檔案以便分析。
C:常見配置
  1. 常見配置彙總
    1. 堆設定
      • -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:設定持久代大小
    2. 收集器設定
      • -XX:+UseSerialGC:設定序列收集器
      • -XX:+UseParallelGC:設定並行收集器
      • -XX:+UseParalledlOldGC:設定並行年老代收集器
      • -XX:+UseConcMarkSweepGC:設定併發收集器
    3. 垃圾回收統計資訊
      • -XX:+PrintGC
      • -XX:+PrintGCDetails
      • -XX:+PrintGCTimeStamps
      • -Xloggc:filename
    4. 並行收集器設定
      • -XX:ParallelGCThreads=n:設定並行收集器收集時使用的CPU數。並行收集執行緒數。
      • -XX:MaxGCPauseMillis=n:設定並行收集最大暫停時間
      • -XX:GCTimeRatio=n:設定垃圾回收時間佔程式執行時間的百分比。公式為1/(1+n)
    5. 併發收集器設定
      • -XX:+CMSIncrementalMode:設定為增量模式。適用於單CPU情況。
      • -XX:ParallelGCThreads=n:設定併發收集器年輕代收集方式為並行收集時,使用的CPU數。並行收集執行緒數。
3如何設定JVM的記憶體分配:


(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