JBOSS優化

JBOSS優化

文章分類:Java編程

Java OPTS設置


在Java的Jvm分爲主要爲兩大塊:一個是heap和 nheap
Heap包括三個區域. Eden space 、survivor space、tenured space.
其中surivor space包括兩個區,一個是from區,一個是to區
Eden是負責新對象的創建區域。當新對象無法在eden區創建的時候,eden區會進行minor gc,會將一些失效的對象清除。會將清除下來的部分對象放到survivor space區域或者tenured space區域。當tenured space的對象越來越多的時候,達到jvm內存不足10%的時候,會進行一次full gc來釋放對象。項目要儘可能少的full gc ,應爲full gc比較佔用內存,一般要求吞吐量比較大的時候,儘量的將new區域設置的比較大一點。也就是eden和survivor這個區域。
下面簡要的說一下配置參數
set JAVA_OPTS=%JAVA_OPTS% -Xms128m -Xmx512m -XX:MaxPermSize=256m

-Xms512m 代表jvm最少用 512m內存,32bit操作系統最大在1.5g-2g之間。64位的無限制
-Xmx1024m 代表jvm最多使用 1024m內存,儘量的將-Xms和-Xmx大小設置相同,這樣避免內存重新分配影響性能
-Xss=128k 線程初始化大小,5.0之前默認是128k,之後爲1m,線程機器最大爲3000-5000
-XX:MaxPermSize=256m.這是表明持久類,也就是noheap區域的最大爲256
-XX:PermSize=256m這個持久區域初始化爲256m,一般持久類的大小是64m
這個配置是最常用的配置。如果需要考慮到吞吐量,那麼new space和old space你就得重新分配一下
Jvm垃圾收集器包括三種:串行,並行,併發
串行:處理小型數據,jdk1.4之前默認使用
並行:1.5和1.5之後使用,處理
典型服務器配置有以下幾種:
-Xmx3800m -Xms3800m -Xmn2g -Xss128k -XX:+UseParallelGC -XX:ParallelGCThreads=20
-XX:+UseParallelGC:選擇垃圾收集器爲並行收集器。此配置僅對年輕代有效。即上述配置下,年輕代使用併發收集,而年老代仍舊使用串行收集。
-XX:ParallelGCThreads=20:配置並行收集器的線程數,即:同時多少個線程一起進行垃圾回收。此值最好配置與處理器數目相同
-Xmx3550m -Xms3550m -Xmn2g -Xss128k -XX:+UseParallelGC -XX:ParallelGCThreads=20 -XX:+UseParallelOldGC
-XX:+UseParallelOldGC:配置年老代垃圾收集方式爲並行收集。JDK6.0支持對年老代並行收集。
-Xmx3550m -Xms3550m -Xmn2g -Xss128k -XX:+UseConcMarkSweepGC -XX:CMSFullGCsBeforeCompaction=5 -XX:+UseCMSCompactAtFullCollection
XX:CMSFullGCsBeforeCompaction:由於併發收集器不對內存空間進行壓縮、整理,所以運行一段時間以後會產生“碎片”,使得運行效率降低。此值設置運行多少次GC以後對內存空間進行壓縮、整理。
-XX:+UseCMSCompactAtFullCollection:打開對年老代的壓縮。可能會影響性能,但是可以消除碎片

常見配置彙總
1. 堆設置
-Xss128k:JBoss每增加一個線程(thread)就會立即消耗128K,默認值好像是512k.
-Xms512m:初始堆大小,代表jvm最少用 512m內存
-Xmx:最大堆大小 一般爲服務器的3/4內存量,推薦至少使用4G內存,不應該超過物理內存的90%。
-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數。並行收集線程數。
查看CPU數
cat /proc/cpuinfo | grep "processor" | wc -l
生產環境8G內存jboss配置如下

Java代碼 複製代碼
  1. if "x$JAVA_OPTS" "x" ]; then    
  2.    JAVA_OPTS="-Xss128k -Xms6000m -Xmx6000m -XX:MaxNewSize=512m -XX:MaxPermSize=512M -XX:+UseParallelGC -XX:ParallelGCThreads=16 -XX:+UseParallelOldGC -Dsun.rmi.dgc.client.gcInterval=3600000 -Dsun.rmi.dgc.server.gcInterval=3600000"    
  3. fi    
  4. 生產環境4G內存jboss配置如下    
  5. if "x$JAVA_OPTS" "x" ]; then    
  6.    JAVA_OPTS="-Xss128k -Xms3000m -Xmx3000m -XX:MaxNewSize=256m -XX:MaxPermSize=256m -XX:+UseParallelGC -XX:ParallelGCThreads=16 -XX:+UseParallelOldGC -Dsun.rmi.dgc.client.gcInterval=3600000 -Dsun.rmi.dgc.server.gcInterval=3600000"    
  7. fi   
if [ "x$JAVA_OPTS" = "x" ]; then 
   JAVA_OPTS="-Xss128k -Xms6000m -Xmx6000m -XX:MaxNewSize=512m -XX:MaxPermSize=512M -XX:+UseParallelGC -XX:ParallelGCThreads=16 -XX:+UseParallelOldGC -Dsun.rmi.dgc.client.gcInterval=3600000 -Dsun.rmi.dgc.server.gcInterval=3600000" 
fi 
生產環境4G內存jboss配置如下 
if [ "x$JAVA_OPTS" = "x" ]; then 
   JAVA_OPTS="-Xss128k -Xms3000m -Xmx3000m -XX:MaxNewSize=256m -XX:MaxPermSize=256m -XX:+UseParallelGC -XX:ParallelGCThreads=16 -XX:+UseParallelOldGC -Dsun.rmi.dgc.client.gcInterval=3600000 -Dsun.rmi.dgc.server.gcInterval=3600000" 
fi 

 

 

數據庫連接
在JBOSS_HOME\Server\default\deploy目錄下存在**-xa-ds.xml文件,用於JBOSS同數據庫連接等配置,默認 情況下**-xa-ds.xml文件中不包含關於數據庫連接池等方面的配置信息,可以添加一下內容進行數據庫連接池方面的設置:

Xml代碼 複製代碼
  1. <min-pool-size>100</min-pool-size>    
  2. <max-pool-size>500</max-pool-size>    
<min-pool-size>100</min-pool-size> 
<max-pool-size>500</max-pool-size>  
 



第3章    Tomcat
3.1    web.xml

修改Tomcat的JSP自動編譯配置項:
%JBOSS_HOME%/deploy/jbossweb-tomcat50.sar/conf/web.xml
修改如下代碼:

Xml代碼 複製代碼
  1. <SPAN><servlet>  
  2. <servlet-name>jsp</servlet-name>  
  3. <servlet-class>org.apache.jasper.servlet.JspServlet</servlet-class>  
  4. <init-param>  
  5. <param-name>development</param-name>  
  6. <param-value>false</param-value>  
  7. </init-param>  
  8. </servlet></SPAN>  
<servlet> <servlet-name>jsp</servlet-name> <servlet-class>org.apache.jasper.servlet.JspServlet</servlet-class> <init-param> <param-name>development</param-name> <param-value>false</param-value> </init-param> </servlet>

 


 追加development=false
通知tomcat在用戶訪問時不必作JSP文件是否已被修改的檢查。
3.2    server.xml
修改Tomcat的server.xml文件,設置線程數、支持壓縮協議等…


%JBOSS_HOME%/deploy/jbossweb-tomcat50.sar/server.xml

Xml代碼 複製代碼
  1. <SPAN><Connector port="80" address="0.0.0.0"  
  2. maxThreads="75" maxHttpHeaderSize="8192"  
  3. minSpareThreads="55" maxSpareThreads="25"  
  4. enableLookups="false" redirectPort="8443" acceptCount="100"  
  5. connectionTimeout="20000" disableUploadTimeout="true"  
  6. compression="on" compressableMimeType="text/html,text/xml,text/plain,text/css,   
  7. text/javascript,application/xhtml+xml,application/x-javascript,application/javascript,text/xhtml"   
  8. /></SPAN>  
<Connector port="80" address="0.0.0.0" maxThreads="75" maxHttpHeaderSize="8192" minSpareThreads="55" maxSpareThreads="25" enableLookups="false" redirectPort="8443" acceptCount="100" connectionTimeout="20000" disableUploadTimeout="true" compression="on" compressableMimeType="text/html,text/xml,text/plain,text/css, text/javascript,application/xhtml+xml,application/x-javascript,application/javascript,text/xhtml" />

 


第4章    日誌優化
優化JBOSS日誌:%JBOSS_HOME%/server/default/conf/log4j.xml
4.1    修改Append

修改以下內容:

Xml代碼 複製代碼
  1. <SPAN><param name="Append" value="true"/>  
  2. <param name="Threshold" value="WARN"/></SPAN>  
<param name="Append" value="true"/> <param name="Threshold" value="WARN"/>

 


修改後的代碼如下:

Xml代碼 複製代碼
  1. <SPAN><appender name="FILE" class="org.jboss.logging.appender.DailyRollingFileAppender">  
  2. <errorHandler class="org.jboss.logging.util.OnlyOnceErrorHandler"/>  
  3. <param name="File" value="${jboss.server.home.dir}/log/server.log"/>  
  4. <param name="Append" value="true"/>  
  5. <param name="Threshold" value="WARN"/>  
  6. <param name="DatePattern" value="'.'yyyy-MM-dd"/>  
  7. <layout class="org.apache.log4j.PatternLayout">  
  8. <param name="ConversionPattern" value="%d %-5p [%c] %m%n"/>  
  9. </layout>  
  10. </appender></SPAN>  
<appender name="FILE" class="org.jboss.logging.appender.DailyRollingFileAppender"> <errorHandler class="org.jboss.logging.util.OnlyOnceErrorHandler"/> <param name="File" value="${jboss.server.home.dir}/log/server.log"/> <param name="Append" value="true"/> <param name="Threshold" value="WARN"/> <param name="DatePattern" value="'.'yyyy-MM-dd"/> <layout class="org.apache.log4j.PatternLayout"> <param name="ConversionPattern" value="%d %-5p [%c] %m%n"/> </layout> </appender>

 


4.2    修改Root
關閉控制檯日誌輸出:
屏蔽:<appender-ref ref="CONSOLE"/>

Xml代碼 複製代碼
  1. <root>  
  2. <!--<appender-ref ref="CONSOLE"/>-->  
  3. <appender-ref ref="FILE"/>  
  4. </root>  
<root>
<!--<appender-ref ref="CONSOLE"/>-->
<appender-ref ref="FILE"/>
</root>
 

 


JBOSS瘦身
在JBOSS中提供許多通常不需要的服務和Jar包,比如JMX、Mail、AOP、Hibernate等,可以根據具體項目所涉及的技術,刪減JBOSS內置應用,從而提高JBOSS中間件啓動速度,減少佔用系統資源。


 刪減服務
在%JBOSS_HOME%/server/default/deploy中含有一些比如jboss-aop.deployer等目錄和mail- service.xml等應用配置文件,如果不需要使用這些應用的話,可以將其一一刪除,不過刪除時要分外小心,避免應用系統無法啓動。
下圖爲只包含數據庫應用的一個已刪減不需要服務後的deploy文件夾目錄:
 
刪減Jar包
在%JBOSS_HOME%/server/default/lib中包含一些應用系統不需要的Jar包,這些包同樣可以進行刪除。

 

 

 

 

 

 

 

 

 

--------------------------------------------------------------------------------------------

JBoss性能優化:內存緊張的問題終於解決了(轉載)

(2006-11-01 06:30:25)
  分類: IT 筆記
 
    昨天查了一天的資料,運氣不錯,收穫不小,解決了一個老大難問題:JBoss內存緊張的問題。
    這是一個困擾了我兩年整的問題,就是從前年這個時候,用JBoss 3.2.1架站以來,始終是一個大問題。不大的站點,1G的內存都不夠用,經常要消耗500Mb的交換內存(swap)。
原來是自己犯了非常低級的錯誤,不懂JAVA_OPTS各參數的含義造成的。
之前的JAVA_OPTS是 -Xms 520m -Xmx 1220m -Xss 15120k +XX:AggressiveHeap
這個JAVA_OPTS犯了2個致命的錯誤:
1. +XX:AggressiveHeap會使得 Xms 1220m沒有意義。這個參數讓jvm忽略Xmx參數,瘋狂地吃完一個G物理內存,再吃盡一個G的swap。
另外Xmx作爲允許jvm使用的最大內存數量,不應該超過物理內存的90%。
而之所以使用了這個參數,是因爲不加的話,JBoss會在運行一天左右的時間後迅速崩潰,上機課是,甚至出現過半個小時就崩潰的情況。
之所以要用這個參數,用swap支持服務器運行,是因爲犯了下面的錯誤:
2. -Xss 15120k
這使得JBoss每增加一個線程(thread)就會立即消耗15M內存,而最佳值應該是128K,默認值好像是512k.
這就是JBoss剛啓動時,還有200Mb內存富餘,但會在一個小時內迅速用完,因爲服務器的threads在迅速增加。前3天,每天都多吃80Mb左右 的swap.在第四天開始穩定下來。今年春節在外度假,觀察到了這個現象,卻不理解其原因:服務器在線程到達100之後,一般不再增加新的線程,新增加的 在用完之後,會被迅速destroy,1.25-2.10所使用的線程基本是1.21- 1.23創建的,因此沒有再消耗新的內存。服務器持續運行時間,也因此大大超乎我5天的預期,到達了20天。
昨天所作的修改:
1.修改JAVA_OPTS,去掉+XX:AggressiveHeap,修改Xss。現在的JAVA_OPTS爲:
-Xms 520m -Xmx 900m -Xss 128k
2.修改deploy/jbossweb-tomcat55.sar/service.xml
將maxThreads根據目前的訪問量由默認的250降爲75,並使用jboss 4默認未寫在標準service.xml裏面而jboss 3寫入了的2個參數: maxSparseThreads=55,minSparseThreads=25
3.修改了oracle-ds.xml將最大連接數有150降爲50.
4.去掉了一些不用的服務。
 
 
 
 
 
 
 
 
 
Jboss 優化配置



一. Jboss後臺啓動:
添加後臺修改命令:
vi run.sh
while true; do
  if [ "x$LAUNCH_JBOSS_IN_BACKGROUND" = "x" ]; then
  # Execute the JVM in the foreground
  nohup "$JAVA" $JAVA_OPTS \
  -Djava.endorsed.dirs="$JBOSS_ENDORSED_DIRS" \
  -classpath "$JBOSS_CLASSPATH" \
  org.jboss.Main "$@"
  JBOSS_STATUS=$?
  else
  # Execute the JVM in the background
  "$JAVA" $JAVA_OPTS \
  -Djava.endorsed.dirs="$JBOSS_ENDORSED_DIRS" \
  -classpath "$JBOSS_CLASSPATH" \
  org.jboss.Main "$@" &
  JBOSS_PID=$!
  # Trap common signals and relay them to the jboss process
  trap "kill -HUP $JBOSS_PID" HUP
  trap "kill -TERM $JBOSS_PID" INT
  trap "kill -QUIT $JBOSS_PID" QUIT
  trap "kill -PIPE $JBOSS_PID" PIPE
  trap "kill -TERM $JBOSS_PID" TERM
  # Wait until the background process exits
  WAIT_STATUS=0
  while [ "$WAIT_STATUS" -ne 127 ]; do
  JBOSS_STATUS=$WAIT_STATUS
  wait $JBOSS_PID 2>/dev/null
  WAIT_STATUS=$?
  done
  fi
  # If restart doesn't work, check you are running JBossAS 4.0.4+
  # http://jira.jboss.com/jira/browse/JBAS-2483
  # or the following if you're running Red Hat 7.0
  # http://developer.java.sun.com/developer/bugParade/bugs/4465334.html  
  if [ $JBOSS_STATUS -eq 10 ]; then
  echo "Restarting JBoss..."
  else
  exit $JBOSS_STATUS
  fi
done &
二. Jboss內存優化:
修改這個兩參數,給jvm分配適當的內存,一般爲服務器的3/4內存量,推薦至少使用4G內存。
另外添加兩個參數 -XX:+UseParallelGC -XX:+UseParallelOldGC 這兩個讓服務並行回收內存空間。修改完成後,大致爲 JAVA_OPTS = “-Xms4096m -Xmx8192m -XX:+UseParallelGC -XX:+UseParallelOldGC -Dsum……
三. Jboss日誌輸出模式
[root@190MEM conf]# pwd
/usr/local/jboss/server/default/conf
[root@190MEM conf]# vi jboss-log4j.xml
  <appender name="FILE" class="org.jboss.logging.appender.DailyRollingFileAppender">
  <errorHandler class="org.jboss.logging.util.OnlyOnceErrorHandler"/>
  <param name="File" value="${jboss.server.log.dir}/server.log"/>
  <param name="Append" value="false"/>
  <param name="Threshold" value="ERROR"/>
四. Jboss數據庫連接池優化
修改數據庫連接池:
<datasources>
  <local-tx-datasource>
  <jndi-name>training_master_db</jndi-name> <connection-url>jdbc:mysql://211.100.192.128:3306/dts?useUnicode=true&amp;characterEncoding=UTF-8</connection-url>
  <driver-class>com.mysql.jdbc.Driver</driver-class>
  <user-name>root</user-name>
  <password></password>
  <min-pool-size>100</min-pool-size>
  <max-pool-size>500</max-pool-size> <exception-sorter-class-name>org.jboss.resource.adapter.jdbc.vendor.MySQLExceptionSorter</exception-sorter-class-name>
五. Jboss部署目錄優化:
  去掉和應用無關的部署,加快jboss運行速度
bsh-deployer.xml 
client-deployer-service.xml  
ear-deployer.xml
ejb-deployer.xml 
http-invoker.sar 
jboss-bean.deployer 
jboss-ws4ee.sar
jms 
jsr88-service.xml  
schedule-manager-service.xml
scheduler-service.xml
sqlexception-service.xml
uuid-key-generator.sar
六. Jboss應用安全加固:
去掉:
Tomcat status (full) (XML) 
JMX Console 
JBoss Web Console
刪除deploy下的jmx-console.war/ management/
[root@190MEM deploy]# pwd
/usr/local/jboss/server/default/deploy
[root@190MEM deploy]# ls jmx-console.war/ management/
jmx-console.war/:
checkJNDI.jsp displayMBeans.jsp p_w_picpaths inspectMBean.jsp META-INF WEB-INF
cluster displayOpResult.jsp index.jsp jboss.css style_master.css

management/:
console-mgr.sar
[root@190MEM deploy]#
七. 備註:
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章