使用JBoss 5.1.0.GA部署项目可能遇到的问题汇总


专治文章 http://www.tuicool.com/articles/MJ7rI3n

1、java.lang.IllegalArgumentException: Invalid 'log4jConfigLocation' parameter

原因就是Jboss对于log4jConfigLocation这个参数的支持似乎并不好(可能导致启动log4j时卡死),故需要如下配置:

<!-- Tomcat使用 -->
<!-- <context-param>
  <param-name>log4jConfigLocation</param-name>
  <param-value>
    classpath:config/log4j.xml
  </param-value>
</context-param>
<context-param>
  <param-name>contextConfigLocation</param-name>
  <param-value>
    classpath:config/applicationContext.xml
  </param-value>
</context-param> -->
<!-- JBoss使用 -->
<context-param>
  <param-name>contextConfigLocation</param-name>
  <param-value>
    classpath:config/log4j.xml
    classpath:config/applicationContext.xml
  </param-value>
</context-param>

主要分为两个部分,分别在Tomcat和JBoss下使用,但需要注意使用contextConfigLocation时,不支持log4j的properties配置文件,只可以使用xml。

列出一个范例的log4j.xml:

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE log4j:configuration SYSTEM "http://logging.apache.org/log4j/1.2/apidocs/org/apache/log4j/xml/doc-files/log4j.dtd">
<log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/">
  <!-- 控制台配置 -->
  <appender name="console" class="org.apache.log4j.ConsoleAppender">
    <layout class="org.apache.log4j.PatternLayout">
      <param name="ConversionPattern" value="%d{yyyy-MM-dd HH:mm:ss} %-5p %c{1}:%L - %m%n" />
    </layout>
  </appender>
  <!-- 文件配置 -->
  <!-- <appender name="file" class="org.apache.log4j.RollingFileAppender">
    <param name="append" value="false" />
    <param name="maxFileSize" value="10MB" />
    <param name="maxBackupIndex" value="10" />
    <param name="file" value="${catalina.home}/logs/pro.log" />
    <layout class="org.apache.log4j.PatternLayout">
      <param name="ConversionPattern" value="%d{yyyy-MM-dd HH:mm:ss} %-5p %c{1}:%L - %m%n" />
    </layout>
  </appender> -->
  <root>
    <level value="WARN" />
    <appender-ref ref="console" />
    <!-- <appender-ref ref="file" /> -->
  </root>
</log4j:configuration>

其中需要注意下,使用网上经常能搜到的<!DOCTYPE log4j:configuration SYSTEM "log4j.dtd">是会报错的。

2、java.lang.IllegalStateException: Could not detect JBoss VFS infrastructure

这是使用Spring4会出现的问题,原因就是在Spring4中已经去掉了对JBoss5的VFS支持,解决方法也很简单,使用Spring3即可。

3、java.lang.RuntimeException: mapped-name is required for

简单说,就是JBoss对@Resource支持并不好,使用@Autowired和@Qualifier("beanName")代替(具体用法自行搜索)

4、JBoss错误:log4j:ERROR A "org.jboss.logging.appender.FileAppender" object is not assignable to a "org.apache.log4j.Appender" variable.

经过搜索,总结下来就是说JBoss已经集成好了log4j,再次加入log4j的jar会出现冲突,所以去掉log4j的jar即可,如果使用Maven进行项目管理,在log4j上配置<scope>provided</scope>即可(如果使用Tomcat会报错,所以最好是在JBoss部署后手动删除log4j的jar文件)。

5、JBoss错误:SLF4J: Class path contains multiple SLF4J bindings.

就是说有多个slf4j的jar,继续查看信息可以发现JBoss目录下common/lib/slf4j-jboss-logging.jar与项目中的冲突,最好的做法就是删除slf4j-jboss-logging.jar,删除后错误消失,但可能会触发未知问题(暂时没发现)。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值