2009-10-05 37 views
1

我试图让LogBack在C3P0上使用HSQLDB。鉴于我目前的环境,我坚持使用这种配置。我对Log4J代码有大量投资,并且还需要使用SLF4J Log4J适配器。当我尝试一个简单的日志程序时,它会陷入记录器配置阶段。这里是我的logback.xmlLogback - C3P0和HSQLDB

<configuration> 
    <appender name="DB" class="ch.qos.logback.classic.db.DBAppender"> 
     <connectionSource class="ch.qos.logback.core.db.DataSourceConnectionSource"> 
      <dataSource class="com.mchange.v2.c3p0.ComboPooledDataSource"> 
       <driverClass>org.hsqldb.jdbcDriver</driverClass> 
       <jdbcUrl>jdbc:hsqldb:hsql://localhost:9001/mid_logs</jdbcUrl> 
       <user>sa</user> 
       <password>sa</password> 
      </dataSource> 
     </connectionSource> 
    </appender> 
    <root level="debug"> 
     <appender-ref ref="DB" /> 
    </root> 
</configuration> 

我的类路径是:

bin/.;lib/hsqldb.jar;lib/log4j-over-slf4j-1.5.8.jar;lib/logback-access-0.9.17.jar;lib/logback-classic-0.9.17.jar;lib/logback-core-0.9.17.jar;lib/slf4j-api-1.5.8.jar;lib/slf4j-log4j12-1.5.8.jar;lib/c3p0-0.9.1.2.jar 

这里是我的代码片段:

System.out.println("Starting"); 
Logger logger = Logger.getLogger(TestLogging.class); 
System.out.println("got Logger"); 

的 '开始' 出现在控制台输出,但没有其他的。

任何帮助,将不胜感激!

+0

将此回归到基本知识,以确保您可以首先将LogBack记录到控制台。然后你可以尝试登录数据库。 – SteveD 2009-10-05 19:21:36

+0

如果我从混合中删除C3P0,并使用DBAppender并直接转到HSQLDB驱动程序,则会获得输入到数据库中的行。巨大的问题是HSQLDB驱动程序不会重新使用连接。这就是我尝试使用C3P0连接池的原因。 – 2009-10-05 20:46:45

+0

你有没有试过联系logback-user邮件列表? – Ceki 2009-10-08 07:37:09

回答

0

你会得到什么status messages?你可以让他们通过添加下面的行放在configuraton文件中列出:

<statusListener class="ch.qos.logback.core.status.OnConsoleStatusListener" /> 

由于上述配置文件中没有很好地格式化的,使得它难以阅读。

0

我加入了StatusListenerlogback.xml文件,这里是输出:

07:45:12,816 |-INFO in ch.qos.logback.core.joran.action.AppenderAction - About to instantiate appender of type [ch.qos.logback.classic.db.DBAppender] 
07:45:12,832 |-INFO in ch.qos.logback.core.joran.action.AppenderAction - Naming appender as [DB] 
07:45:12,848 |-INFO in ch.qos.logback.core.joran.action.NestedComplexPropertyIA - Pushing component [connectionSource] on top of the object stack. 
07:45:13,129 |-INFO in ch.qos.logback.core.joran.action.NestedComplexPropertyIA - Pushing component [dataSource] on top of the object stack. 

如果我做了“netstat -a -n”我看到数据库的连接,但没有任何活动。