JBOSS最大連接數配置和jvm內存配置


一.調整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參數

A:JVM啟動參數共分為三類:
        其一是標准參數(-),所有的JVM實現都必須實現這些參數的功能,而且向后兼容;
        其二是非標准參數(-X),指的是JVM底層的一些配置參數,這些參數在一般開發中默認即可,不需要任何配置。但是在生產環境中,並不保證所有jvm實現都滿足,所以為了提高性能,往往需要調整這些參數,以求系統達到最佳性能。另外這些參數不保證向后兼容,也即是說“如有變更,恕不在后續版本的JDK通知”(這是官網上的原話);
        其三是非Stable參數(-XX),這類參數在jvm中是不穩定的,不適合日常使用的,后續也是可能會在沒有通知的情況下就直接取消了,需要慎重使用。
B:而JVM 內存又可分為三個主要的域 :
        新域、舊域以及永久域。JVM生成的所有新對象放在新域中。一旦對象經歷了一定數量的垃圾收集循環后,便進入舊域。而在永久域中是用來存儲JVM自己的反射對象的,如class和method對象,而且GC(Garbage Collection)不會在主程序運行期對永久域進行清理。其中新域和舊域屬於堆,永久域是一個獨立域並且不認為是堆的一部分。
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 space和java.lang.OutOfMemoryError: PermGen space,其中前者是有關堆內存的內存溢出,可以同過配置-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"


日志文件設置:

jboss\server\default\log


        若需要修改JBoss默認的log4j設置,可修改JBoss安裝目錄"server\default\conf下的jboss-log4j.xml文件,在該文件中可以看到,log4j的日志輸出在JBoss安裝目錄"server\

 

如果使用log4j日志框架,將配置文件放在工程目錄下的話容易引起與jboss日志配置的沖突,一個比較好的方式就是將日志配置到jboss的 jboss-log4j.xml文件中,文件的目錄是($JBOSS)/server/default/conf。在配置文件中添加以下內容:

<appender name="myLog" class="org.apache.log4j.DailyRollingFileAppender">
    <!--設置通道名稱是:file,輸出方式DailyRollingFileAppender-->
    <param name="File" value="${jboss.server.home.dir}/log/Mqs.log"/>
    <!--日志文件路徑和文件名稱 -->
  
    <param name="Append" value="true"/>
    <!-- 設置是否在重新啟動服務時,在原有日志的基礎添加新日志 -->

    <!-- Rollover at midnight each day -->
    <param name="DatePattern" value="'.'yyyy-MM-dd"/>

  
    <!-- Rollover at the top of each hour
    <param name="DatePattern" value="'.'yyyy-MM-dd-HH"/>
    -->
    <layout class="org.apache.log4j.PatternLayout">
      <!-- The default pattern: Date Priority [Category] Message/n -->
      <param name="ConversionPattern" value="%d %-5p [%c] %m%n"/>
      <!-- The full pattern: Date MS Priority [Category] (Thread:NDC) Message/n
      <param name="ConversionPattern" value="%d %-5r %-5p [%c] (%t:%x) %m%n"/>
       -->
    </layout>    
  </appender>

  <logger name="com.all" additivity="false" >
    <level value="INFO" />
    <appender-ref ref="myLog"/>
  </logger>

在web工程中使用日志的時候就可以這樣寫

Logger log = Logger.getLogger("com.all");

log.debug("test");

其中"com.all"與<logger name="com.all" additivity="false" > 中的name屬性值對應。additivity屬性非常重要,它表示是否繼承root配置的輸出通道,默認配置是true,如果不將其設為false的話會導致日志重復輸出到控制台與jboss的日志文件中。

default

 

 

jboss\server\default\log


免責聲明!

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



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