`

JBOSS性能调优

 
阅读更多
linux jboss 部署时优化设置:

在/conf/web.xml中通过参数指定:
<session-config>    
    <session-timeout>1440</session-timeout>      
</session-config>  
单位为分钟。


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输出日志的等级
打开 <jboss>/server/default/conf/jboss-log4j.xml ,这是一个log4j的配置文件。log4j的详细配置说明请参看  http://logging.apache.org/log4j/1.2/index.html  。日志输出的太多,会导致服务器性能降低,所以减少不必要的日志输出。方法大体如下:

1.找到 name=”org.jboss” 的category 元素,设置里面的priority元素为 <priority value=”INFO” />
2.建一个新的category,内容为 <category name=”javax.faces”><priority value=”INFO” /></category>
log4j 还能够将不同的日志输入到不同的地方,为了以后维护方便,应该将不同 category的日志输入到不同的文件里。详细方法参看上面的网站里的说明。

起用jboss内的tomcat对传输数据的压缩功能
合同管理里用了大量的javascript css等,为了减少传输时间,可以起用压缩功能。方法是:
1.打开<jboss>/server/default/deploy/jboss-web.deployer/server.xml
2.找到 protocol=”HTTP/1.1″的 Connector元素,添加属性 URIEncoding=”utf-8″ compression=”on” compressionMinSize=”2048″ noCompressionUserAgents=”gozilla, traviata” compressableMimeType=”text/html,text/xml,text/javascript, text/css, text/plain,application/xhtml+xml,application/x-javascript,application/javascript,text/xhtml”
添加完后类似于:
<Connector port=”8080″ address=”${jboss.bind.address}”  
maxThreads=”250″ maxHttpHeaderSize=”8192″
emptySessionPath=”true” protocol=”HTTP/1.1″
enableLookups=”false” redirectPort=”8443″ acceptCount=”100″
connectionTimeout=”20000″ disableUploadTimeout=”true” URIEncoding=”utf-8″ compression=”on” compressionMinSize=”2048″ noCompressionUserAgents=”gozilla, traviata” compressableMimeType=”text/html,text/xml,text/javascript, text/css, text/plain,application/xhtml+xml,application/x-javascript,application/javascript,text/xhtml”/>



生产实例

<Connector protocol="HTTP/1.1" port="8080" address="${0.0.0.0}"
               connectionTimeout="20000" redirectPort="8443"
              
                URIEncoding="utf-8"
                compression="on"
                compressionMinSize="2048"
                noCompressionUserAgents="gozilla, traviata"
                compressableMimeType="text/html,text/xml,text/javascript, text/css, text/plain,application/xhtml+xml,application/x-javascript,application/javascript,text/xhtml"
        />



下面这段需调试好久。,

maxThreads="200"
               maxSparseThreads="40"
               minSparseThreads="20"
               acceptCount="10"



给jvm分配适当的内存,一般为服务器的3/4内存量,推荐至少使用4G内存。
JAVA_OPTS = "-Xms4096m -Xmx8192m -XX:+UseParallelGC -XX:+UseParallelOldGC .. . . "
-Xms=128m这是heap初始化大小。32bit操作系统最大在1.5g-2g之间。64位的无限制
-Xmx=512m 这是heap最大的大小。尽量的将-Xms和-Xmx大小设置相同,这样避免内存重新分配影响性能
-Xss=128k 线程初始化大小,5.0之前默认是128k,之后为1m,线程机器最大为3000-5000
-XX:MaxPermSize=256m.这是表明持久类,也就是noheap区域的最大为256
-XX:PermSize=256m这个持久区域初始化为256m,一般持久类的大小是64m

Jvm垃圾收集器包括三种:串行,并行,并发
串行:处理小型数据,jdk1.4之前默认使用
并行:1.5和1.5之后使用,处理

-XX:ParallelGCThreads=20:配置并行收集器的线程数,即:同时多少个线程一起进行垃圾回收。此值最好配置与处理器数目相
-XX:+UseParallelOldGC:配置年老代垃圾收集方式为并行收集。JDK6.0支持对年老代并行收集。
(并发收集器主要是保证系统的响应时间,减少垃圾收集时的停顿时间。适用于应用服务器、电信领域等。)
-XX:+UseConcMarkSweepGC 设置年老代为并发收集。测试中配置这个以后,-XX:NewRatio=4的配置失效了,原因不明。所以,此时年轻代大小最好用-Xmn设置。
-XX:CMSFullGCsBeforeCompaction= 由于并发收集器不对内存空间进行压缩、整理,所以运行一段时间以后会产生“碎片”,使得运行效率降低。此值设置运行多少次GC以后对内存空间进行压缩、整理。
-XX:ParallelGCThreads=n:设置并发收集器年轻代收集方式为并行收集时,使用的CPU数。并行收集线程数。





修改Jboss的bin目录下的run.bat/run.sh,在其加一行:


Windows
set JAVA_OPTS=%JAVA_OPTS% -Xms128m -Xmx256m -XX:PermSize=128m -XX:MaxPermSize=256m -XX:MaxNewSize=256m -Dfile.encoding=GBK
echo "JAVA_OPTS="$JAVA_OPTS


Linux
JAVA_OPTS="$JAVA_OPTS -Xms128m -Xmx256m -XX:PermSize=128m -XX:MaxPermSize=256m -XX:MaxNewSize=256m -Dfile.encoding=GBK"
echo "JAVA_OPTS="$JAVA_OPTS



生产实例



#add wyg 2011-07-25
#modify wyg 2011-07-27
JAVA_OPTS="$JAVA_OPTS -Xms1200m -Xmx1200m -XX:PermSize=600m -XX:MaxPermSize=600m -XX:NewSize=400M -XX:MaxNewSize=400M -XX:+UseTLAB -XX:TLABSize=128K"





32位的Windows操作系统,最大也就能分配到1.5G左右的内存。原因是jvm出于性能的考虑分配内存时必须分配连续的内存块,而在jvm启动以前往往有一些其它的应用程序将操作系统的内存分割开,所以就会在jvm启动时出现不能分配堆内存的错误。解决方法:
1、在32位的windows操作系统上启动多个jvm
2、换成64位操作系统







安全设置
1、jmx-console登录的用户名和密码设置
默认情况访问http://localhost:8080/jmx-console就可以浏览jboss的部署管理的一些信息,不需要输入用户名和密码,使用起来有点安全隐患。下面我们针对此问题对jboss进行配置,使得访问jmx-console也必须要知道用户名和密码才可进去访问。步骤如下:
(1)找到JBoss安装目录/server/default/deploy/jmx-console.war/WEB-INF/jboss-web.xml文件,去掉<security-domain>java:/jaas/jmx-console</security-domain>的注释。修改后的该文件内容为:
(2)修改与(1)中的jboss-web.xml同级目录下的web.xml文件,查找到<security-constraint>节点,去掉它的注释
(3) 在第一步中的jmx-console安全域和第二步中的运行角色JBossAdmin都是在login-config.xml中配置,我们在JBoss安装目录/server/default/config下找到它。查找名字为:jmx-console的application-policy:
<application-policy name = "jmx-console">
<authentication>
<login-module code="org.jboss.security.auth.spi.UsersRolesLoginModule" flag = "required">
<module-option name="usersProperties">props/jmx-console-users.properties</module-option>
<module-option name="rolesProperties">props/jmx-console-roles.properties</module-option>
</login-module>
</authentication>
</application-policy>
在此处可以看出,登录的角色、用户等的信息分别在props目录下的jmx-console-roles.properties和jmx-console-users.properties文件中设置,分别打开这两个文件。
配置完成后读者可以通过访问:http://localhost:8088/jmx-console/,输入jmx-console-roles.properties文件中定义的用户名和密码,访问jmx-console的页面。

2、web-console登录的用户名和密码设置
默认情况下,用户访问JBoss的web-console时,不需要输入用户名和密码,为了安全起见,我们通过修改配置来为其加上用户名和密码。步骤如下:
(1)找到JBoss安装目录F:/JBoss/server/default/deploy/management/console-mgr.sar/web-console.war/WEB-INF/jboss-web.xml文件,去掉<security-domain>java:/jaas/web-console</security-domain>的注释
(2)修改与(1)中的jboss-web.xml同级目录下的web.xml文件,去掉<security-constraint>部分的注释
(3)打开JBoss安装目录在JBoss安装目录/server/default/config下的login-config.xml文件,搜索web-console,找到并修改成如下内容:
<application-policy name = "web-console">
    <authentication>
       <login-module code="org.jboss.security.auth.spi.UsersRolesLoginModule" flag = "required">
           <module-option name="usersProperties">props/web-console-users.properties</module-option>
           <module-option name="rolesProperties">props/web-console-roles.properties</module-option>
       </login-module>
    </authentication>
</application-policy>
在文件中可以看到,设置登录web-console的用户名和角色等信息分别在login-config.xml文件所在目录下的web-console-users.properties和web-console-roles.properties文件中,但因为该目录下无这两个文件,我们在JBoss安装目录/server/default/conf/props目录下建立这两个文件,
文件内容可参考在“jmx-console登录的用户名和密码设置”中的两个相应的配置文件的内容。



禁止/打开文件目录列表
编辑F:/JBoss/server/default/deploy/jboss-web.deployer/conf/web.xml
禁止把listing设置为false,否则true

防止LOG文件无限制的扩大
在F:/JBoss/server/default/conf目录下打开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="MaxFileSize" value="10240KB"/>
<param name="MaxBackupIndex" value="1"/>
其中文件的最大值和备份的数量可以根据实际情况而改变









数据源



<max-pool-size>20</max-pool-size>
      <min-pool-size>5</min-pool-size>
      <idle-timeout-minutes>0</idle-timeout-minutes>







//增加jprofiler 启动参数(要jprofilter先启动才能启动jboss) 一般这个注释掉

修改 JBoss 的启动脚本,加入如下参数:
-agentlib:jprofilerti=port=8849 -Xbootclasspath/a:$JPROFILER_HOME/bin/agent.jar  $JAVA_OPTS





//增加jconsole启动参数

-Djava.rmi.server.hostname=192.168.19.126  -Dcom.sun.management.jmxremote.port=9899-Dcom.sun.management.jmxremote.authenticate=false -Dcom.sun.management.jmxremote.ssl=false  $JAVA_OPTS







jboss线程池



conf/jboss-service.xml

<attribute name="MaximumPoolSize">40</attribute>
      <!-- The max number of tasks before the queue is full -->
      <attribute name="MaximumQueueSize">1000</attribute>



Name:在pool中threads的名称
ThreadGroupName:Thread group的名称
KeepAliveTime:当threads空闲时,保持活动的最长时间(单位毫秒)
MaximumPoolSize:可以并发的thread的最大数目
MinimumPoolSize:可以并发的thread的最小数目
MaximumQueueSize:允许等待的request的最大数目
BlockingMode:等待队列满了以后的处理方式








编译jsp的配置 

一般情况下,jsp文件在第一次被调用时才会被编译,然后每这[被修改一次,就会重新编译。

这利于开发,但在生产环境下,变样的配置会引起问题

1。第一个调用jsp页面的人就要等待jsp页面被编译的时间,最好的选择是关闭页面的懒编译特征

2。每一次页面要求都会检查jsp文件是否被修改以决定是否重新编译,每次请求的检查更更新降低生产环境的性能

jsp文件的编译和运行是被 一个java servlet处理的,这个java servlet叫做jspServlet,在 ..../deployers/jbossweb.deployer/web.xml配置

<servlet>
      <servlet-name>jsp</servlet-name>

<init-param>
                           <description>development</description>
                          <param-name>development</param-name>
                          <param-value>false</param-value>
              </init-param>

<init-param>
                           <description>development</description>
                          <param-name>checkInterval</param-name>
                          <param-value>300</param-value>

<!--  5分钟  -->

              </init-param>

参数

development

  缺省值:true

  描述:是否使用开发模式,如果使用,那么modificationTestInterval参数将会被调用

checkInterval

  缺省值:0

  描述:如果development为false,checkInterval的值大于0,编译器起作用,checkInterval是重复编译的时间间隔,默认一为0

modificationTestInterval

缺省值:4

  描述:jsp页面在最后一次调用后重复检测的时间间隔,如果是0,那么每次调用后都检测,默认值是4
分享到:
评论

相关推荐

    JBoss 性能调优

    JBoss性能调优涉及优化硬件资源使用、配置Java虚拟机(JVM)、调整应用服务器(JBoss AS)的设置,以及针对操作系统级别的优化,以最小的开销满足应用需求并提供快速的应用体验。 性能调优的基本思路是理解系统的...

    jboss性能调优

    【JBoss性能调优】 JBoss是一个开源的J2EE应用服务器,它的代码遵循LGPL许可证,因此在商业应用中可以免费使用。Jboss支持EJB 1.1和EJB 2.0规范,主要作为EJB的管理和运行容器。尽管Jboss核心服务主要是一个EJB...

    Jboss AS7 性能调优

    【JBoss AS7 性能调优】 JBoss Application Server 7 (JBoss AS7) 是一款开源的应用服务器,以其高效能和快速启动而受到赞誉。然而,为了确保最佳性能,对服务器进行适当的配置和调优至关重要。大约80%的应用性能取...

    Jboss性能优化整合

    《JBoss性能优化整合》是一份深度探讨Jboss应用服务器性能提升的重要资料,它集结了作者反复试验与研究的心得,旨在为...无论你是初学者还是经验丰富的开发者,都能从中获得宝贵的性能调优知识,为你的项目保驾护航。

    J2EE应用性能调优.docx

    【性能调优--0:前言】 性能调优是一个针对软件系统进行的持续改进过程,旨在提高系统的效率、响应速度和资源利用率。在J2EE应用中,性能问题可能导致用户体验下降,甚至影响整个系统的稳定性和可扩展性。性能调优...

    Jboss的系统性能调优方法

    Jboss的系统性能调优方法.首先是jbossNativejboss的webcontainer使用的apachetomcat。apachetomcat有一个扩展包,使tomcat可以通过javanativeinterface使用apacheportableruntime(APR),而APR则是大名顶顶的apache...

    性能调优 海量并发 系统架构

    J2EE性能调优 Jboss的优化配置 Memcached分布式缓存 Nginx+Tomcat 动静分离 Nginx+tomcat集群Memcached+Session复制 高性能高并发服务器架构 基于nginx的tomcat负载均衡和集群 实现多服务器负载均衡 系统性能优化 ...

    jboss配置(应用服务器,性能调优)

    应用服务器,性能调优,虚拟主机,数据库配置,结合apache

    一种正规的性能调优方法:基于等待的调优

    【性能调优】是软件开发领域中的重要环节,旨在提升应用程序的效率,减少资源消耗,改善用户体验。传统的性能调优往往依赖于经验和技术直觉,但这种方法存在一定的局限性,容易变得主观且难以量化效果。基于等待的...

    应用服务架构及性能调优详解

    此外,文中还详细阐述了应用服务器的关键组件如类加载器(ClassLoader)的作用以及基于JMX的技术特点,在此基础上进一步解释了应用服务器性能调优的重要性和多种优化方式。 适合人群:从事Java应用开发运维的专业人士...

    AIX服务器weblogic性能调优

    在本文中,我们将深入探讨如何对运行在AIX服务器上的WebLogic应用服务器进行性能调优,以解决加载页面慢的问题。WebLogic是一个流行的Java应用程序服务器,而AIX是一种基于UNIX的操作系统,通常用于企业级服务器环境...

    TOMCAT移植到JBOSS

    - **性能调优**:考虑到JBOSS是一个更重的应用服务器,可能需要对应用的性能进行调优,以适应JBOSS的资源管理和调度策略。 - **安全配置**:由于JBOSS提供了更多的安全特性,例如基于角色的访问控制,因此需要重新...

    Jboss eap 6.1.0 应用平台配置管理文档

    该文档还会详细说明如何通过调整JBoss EAP 6.1的配置来提升应用性能,包括但不限于JVM参数设置、数据库连接池优化、以及服务器级别的性能调优。 ### 知识点七:故障排除 在企业应用运行过程中,故障排除是不可避免...

    JBoss学习全集多本书整合

    在性能调优方面,学习如何监控和调整内存设置、线程池大小、数据库连接池等,可以帮助提升服务器的响应速度和稳定性。JBoss提供了丰富的监控工具,如JMX(Java Management Extensions)和Web管理控制台,使管理员...

    JBoss4.0中文版.pdf

    9. **性能优化**:提供性能调优的技巧和最佳实践,包括内存设置、线程池配置、日志优化等,以提升服务器的运行效率。 10. **故障排查**:书中可能会包含一些常见问题的解决方案,帮助读者解决在使用过程中遇到的...

    最详细的JBOSS使用手册

    2. 性能调优:可以通过调整JVM参数、数据库连接池大小、内存分配等进行性能优化。 九、JBOSS与Java EE JBOSS作为Java EE的实现,支持Java EE的各种规范,如Servlet、JSP、EJB、JMS、JPA等,使得开发者可以轻松构建...

    jboss-as-sprint-int-5.0.0.GA.jar 和 jboss-spring-int-vfs.jar

    4. 性能调优:根据JBoss AS的特点进行性能调优,例如调整内存设置、线程池大小等。 5. 日志整合:确保应用的日志输出与JBoss AS的日志系统兼容,如使用JBoss Logging。 6. 安全性:检查并配置JBoss AS的安全策略,如...

    Jboss 4.0 the official guide 标准教材

    10. **性能调优**:提供性能优化的建议和实践,包括内存管理、线程池配置等。 随书的源代码压缩包"examples.zip"通常包含书中示例项目的源代码,这为读者提供了实践操作的机会。通过这些实例,读者可以更直观地了解...

    jboss-4.0.5.GA.zip

    JBoss是著名的开源Java应用服务器,它基于Java EE(Enterprise Edition)规范,为开发者提供了全面的中间件...此外,了解如何管理和调优JVM参数,以及如何处理常见的错误和警告,也是成功运行和维护JBoss服务器的关键。

Global site tag (gtag.js) - Google Analytics