本文是在[url=http://solarisxb.cublog.cn]SOLARIS小兵[/url]的[url=http://blog.chinaunix.net/u/504/showart_1146022.html]文章[/url]基础上总结修改而成的:
[b]一、设置Connector[/b] 修改server/default/deploy/jboss-web.deployer/server.xml
<Connector port="80" address="0.0.0.0" maxThreads="250" maxHttpHeaderSize="8192" emptySessionPath="true" protocol="HTTP/1.1" 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" />
prot="80" 修改端口为80 address="0.0.0.0" 任何IP都可以访问 compression="on" compressableMimeType="..." 启动GZIP压缩 maxThreads等优化待续... [b]二、调整JVM[/b] 修改bin/run.conf
if [ "x$JAVA_OPTS" = "x" ]; then JAVA_OPTS="-server -Xms6g -Xmx6g -XX:PermSize=128m -XX:MaxPermSize=1024m -XX:+UseParallelGC -XX:+UseParallelOldGC" fi
-server 使用服务器模式 -Xms6g -Xmx6g 使用6G内存 最大最小相同 避免每次垃圾回收完成后重新分配内存 -XX:+UseParallelGC 并行垃圾回收 避免长时间的服务中断 -XX:+UseParallelOldGC 并行回收年老代(从JDK6.0开始支持) -XX:PermSize=128m -XX:MaxPermSize=1024m 持久代大小 需要根据实际情况配置 hibernate,seam,spring等项目需要设置大些 [b]三、去除不必要的日志输出[/b] 修改server/default/conf/jboss-log4j.xml [quote] <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="[color=red]true[/color]"/> [color=red]<param name="Threshold" value="ERROR"/>[/color] [/quote] [quote] <root> [color=red]<appender-ref ref="CONSOLE"/>[/color] <!-- 删除此行 --> <appender-ref ref="FILE"/> </root> [/quote] Append设置为true 重启服务不覆盖日志 添加<param name="Threshold" value="ERROR"/> 只有ERROR级别以上才记录日志 删除<appender-ref ref="CONSOLE"/> 不在控制台输出日志 [b]四、Jboss数据库连接池优化[/b]
<datasources> <local-tx-datasource> <jndi-name>datasource</jndi-name> <connection-url>jdbc:mysql://localhost:3306/db?useUnicode=true&characterEncoding=utf8</connection-url> <driver-class>com.mysql.jdbc.Driver</driver-class> <user-name>root</user-name> <password>root</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> <metadata> <type-mapping>mySQL</type-mapping> </metadata> </local-tx-datasource> </datasources>
[b]五、安全[/b] 1、关闭jmx-console 删除server/default/deploy/jmx-console.war和server/default/deploy/management 2、关闭web-console和status统计 删除server/default/deploy/jboss-web.deployer/ROOT.war 3、测试: http://127.0.0.1/jmx-console http://127.0.0.1/web-console http://127.0.0.1/status