如何将Hibernate从jboss-logging切换到logback?

时间:2014-11-23 18:34:21

标签: java hibernate logback jboss-logging

我发现,我的hibernate依赖依次导致依赖jboss-logging

是否可以切换到我已经使用的logback日志记录?

更新

我尝试了三个地方设置org.jboss.logging.provider

1)在Spring中使用JPA属性:

.setJpaProperties(additionalProperties());

2)在main()中设置属性:

System.setProperty("org.jboss.logging.provider", "slf4j");

3)在命令行中设置属性:

-Dorg.jboss.logging.provider="slf4j"

两者都没有。

我得到一个例外:

Caused by: java.lang.ClassNotFoundException: org.jboss.logging.Logger
    at java.net.URLClassLoader$1.run(URLClassLoader.java:372)
    at java.net.URLClassLoader$1.run(URLClassLoader.java:361)
    at java.security.AccessController.doPrivileged(Native Method)
    at java.net.URLClassLoader.findClass(URLClassLoader.java:360)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:424)
    at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:308)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:357)
    ... 32 more

请注意,我已从依赖项中排除了jboss日志记录:

 <dependency>
        <groupId>org.hibernate</groupId>
        <artifactId>hibernate-entitymanager</artifactId>
        <version>4.3.7.Final</version>
        <exclusions>
            <exclusion>
                <groupId>org.jboss.logging</groupId>
                <artifactId>jboss-logging</artifactId>
            </exclusion>
            <exclusion>
                <groupId>org.jboss.logging</groupId>
                <artifactId>jboss-logging-annotations</artifactId>
            </exclusion>
        </exclusions>
    </dependency>

1 个答案:

答案 0 :(得分:3)

我在standalone.conf.bat文件中设置了该属性:

SET "JAVA_OPTS=%JAVA_OPTS% -Dorg.jboss.logging.provider=slf4j"

可以在JBOSS_HOME \ modules \ org \ jboss \ logging \ main文件夹中的jboss-logging jar中找到Logger.class。该模块默认存在。

我最近遇到了类似的问题。如果你解决了Logger.class问题,我想你会遇到这个问题。

我遇到了这个例外:

ClassNotFoundException: org.slf4j.LoggerFactory from [Module "org.jboss.logging:main"

我在JBOSS_HOME \ modules \ org \ jboss \ logging \ main \ module.xml

中添加了对slf4j的依赖性
<module xmlns="urn:jboss:module:1.1" name="org.jboss.logging">
  <resources>
      <resource-root path="jboss-logging-3.1.0.GA.jar"/>
  </resources>

  <dependencies>
     <module name="org.jboss.logmanager"/>
     <module name="org.slf4j" slot="1.7.5" />
  </dependencies>
</module>