【面試虐菜】—— Jboss調優


  吐血整理了以前Jboss以及JVM在生產環境下的調優參數,各種不同的案例,都是來自網友杜撰。整合后,希望對廣大使用jboss作為生產應用服務器的朋友有所幫助。

JBOSS參數調優

配置deploy/jboss-web.deployer/server.xml文件 .
       

<Connector
         port="8080"
         address="0.0.0.0"
         maxThreads="1600"
        minSpareThreads="100"
        maxSpareThreads="250"
         emptySessionPath="false"
        enableLookups="false"
         redirectPort="8443"
         acceptCount="800"
        connectionTimeout="20000"
        disableUploadTimeout="true"
         URIEncoding="UTF-8"
         />


maxThreads:表示最多同時處理的連接數。
應該將線程數(最大線程數)設置比最大預期負載(同時並發的點擊)多25%(經驗規則)。

acceptCount:當同時連接的人數達到maxThreads時,還可以接收排隊的連接。

minSpareThread:指“啟動以后,總是保持該數量的線程空閑等待”;設置比預期負載多25%。

maxSpareThread:指“如果超過了minSpareThread,然后總是保持該數量的線程空閑等待”;設置比預期負載多25%。

 

其中主要修改兩個參數maxThreads和acceptCount值。

增加maxThreads,減少acceptCount值有利縮短系統的響應時間。但是maxThreads和acceptCount的總和最高值不能超過6000而且maxThreads過大會增加CPU和內存消耗,故低配置用戶可通過降低maxThreads並同時增大acceptCount值來保證系統的穩定。

下表羅列出了在不同並發情況下jboss參數與並發在線的一般關系。

並發數

服務器內存

jboss參數

 

 

maxThreads

acceptCount

50以下

2G

256

800

50-300

4G

600

1024

300-800

8G

1024

1528

800-1000

8G

1024

2048

1000-1200

12G

1526

2048

1200-1500

16G

2048

2048

 

 

 

 

 

 

 

 

 

jvm調優講解1

A:JVM啟動參數共分為三類:
        其一是標准參數(-),所有的JVM實現都必須實現這些參數的功能,而且向后兼容;
        其二是非標准參數(-X),指的是JVM底層的一些配置參數

  這些參數在一般開發中默認即可,不需要任何配置。但是在生產環境中,並不保證所有jvm實現都滿足,所以為了提高性能,往往需要調整這些參數,以求系統達到最佳性能。另外這些參數不保證向后兼容,也即是說“如有變更,恕不在后續版本的JDK通知”(這是官網上的原話);

        其三是非Stable參數(-XX),這類參數在jvm中是不穩定的,不適合日常使用的,后續也是可能會在沒有通知的情況下就直接取消了,需要慎重使用。

B:而JVM 內存又可分為三個主要的域 :
        新域、舊域以及永久域(有的也叫做新生代,年老代,和永久代)。JVM生成的所有新對象放在新域中。
一旦對象經歷了一定數量的垃圾收集循環后,便進入舊域。而在永久域中是用來存儲JVM自己的反射對象的,如class和method對象,而且GC(GarbageCollection)不會在主程序運行期對永久域進行清理。

  其中新域和舊域屬於堆,永久域是一個獨立域並且不認為是堆的一部分。
C:各主要參數的作用如下 :

        -Xms:設置jvm內存的初始大小
        -Xmx:設置jvm內存的最大值
        -Xmn:設置新域的大小(這個似乎只對 jdk1.4來說是有效的,后來就廢棄了)
        -Xss:設置每個線程的堆棧大小(也就是說,在相同物理內存下,減小這個值能生成更多的線程)
        -XX:NewRatio :設置新域與舊域之比,如-XX:NewRatio = 4就表示新域與舊域之比為1:4
        -XX:NewSize:設置新域的初始值
        -XX:MaxNewSize :設置新域的最大值
        -XX:PermSize:設置永久域的初始值
        -XX:MaxPermSize:設置永久域的最大值
        -XX:SurvivorRatio=n:設置新域中Eden區與兩個Survivor區的比值。

 

Eden區主要是用來存放新生的對象,而兩個 Survivor區則用來存放每次垃圾回收后存活下來的對象


D:常見的錯誤 :
        java.lang.OutOfMemoryError相信很多開發人員都用到過,

這個主要就是JVM參數沒有配好引起的,但是這種錯誤又分兩種:

java.lang.OutOfMemoryError:Java heap spacejava.lang.OutOfMemoryError: PermGenspace

其中前者是有關堆內存的內存溢出,可以同過配置-Xms和-Xmx參數來設置,而后者是有關永久域的內存溢出,可以通過配置 -XX:MaxPermSize來設置。

下面是個例子,請根據實際情況進行修改,修改run.conf文件中的如下內容

 JAVA_OPTS="-Xms256m-Xmx2048m -XX:NewSize=256m -XX:MaxNewSize=512m -XX:PermSize=128m-XX:MaxPermSize=256m -XX:+UseConcMarkSweepGC -XX:+CMSPermGenSweepingEnabled-XX:+CMSClassUnloadingEnabled -Djboss.platform.mbeanserver"

JVM調優講解2

在Java的Jvm分為主要為兩大塊:一個是heap和 nheap
Heap包括三個區域. Eden spacesurvivor spacetenured 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之后使用,處理

 

JVM常見配置匯總

1. 堆設置
-Xss128m:JBoss每增加一個線程(thread)就會立即消耗128K,默認值好像是512k.
-Xms256m:初始堆大小,代表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數。並行收集線程數。

 

JBOSS生產環境下JVM調優

查看CPU數

cat /proc/cpuinfo | grep "processor" | wc -l

JBOSS參數
  生產環境8G內存jboss配置如下

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文件中不包含關於數據庫連接池等方面的配置信息,可以添加一下內容進行數據庫連接池方面的設置:

 
<min-pool-size>100</min-pool-size>    
<max-pool-size>500</max-pool-size>   

日志優化

優化JBOSS日志:%JBOSS_HOME%/server/default/conf/log4j.xml

修改Append

<SPAN><param name="Append" value="true"/>  
<param name="Threshold" value="WARN"/></SPAN>  

修改后的代碼如下:

<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></SPAN>  

 

修改Root

關閉控制台日志輸出:
屏蔽:<appender-ref ref="CONSOLE"/>

<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等應用配置文件,如果不需要使用這些應用的話,可以將其一一刪除,不過刪除時要分外小心,避免應用系統無法啟動。
 
刪減Jar包
在%JBOSS_HOME%/server/default/lib中包含一些應用系統不需要的Jar包,這些包同樣可以進行刪除。

 

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

    昨天查了一天的資料,運氣不錯,收獲不小,解決了一個老大難問題: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

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM