slf4j输入日志到mongodb



引子

   Java中记录日志我们通常用log4j,可以帮助我们记录日志信息,调试信息,并可以输出到控制台.但是如果在项目中,可能根据需求变更,引入其他日志系统来记录日志的话,这样就需要更改大量的代码,比较费劲。此时我们就引入了 slf4j, slf4j是一个日志接口,定义了一组api,不负责记录日志的具体实现,其他日志都实现 slf4j接口,比如 NOP, Simple, log4j version 1.2, log4j version 1.3, JDK 1.4 logging,这些组件都可以实现.

 必备工具

 本节我们使用slf4j其中的一个实现 log4j来演示记录日志,并把日志写入mongodb,  log4j是使用非常普遍的一个日志组件。使用slf4j我们需要引入以下几个jar包
    slf4j-api-1.7.13.jar  定义一组api接口
    slf4j-log4j12-1.7.12.jar  是slf4j与各种log4j日志实现层的连接转换层,相当于java和数据库连接的时候的jdbc,如果没有这个 slf4j-api与log4j就不能产生关系。
   log4j-1.2.17.jar 日志记录具体实现
   log4mongo-java- 0.7.4  用于连接mongodb数据库

环境搭建

   首先引入上面的java包

  

    org.log4mongo
    log4mongo-java
    0.7.4


  
    org.slf4j  
    slf4j-log4j12  
    1.7.2  



    log4j
    log4j
    1.2.17
配置日志文件 log4j.properties
#log4j.rootLogger=debug,appender1
#log4j.rootLogger=info,appender1
#log4j.rootLogger=warn,appender1
#log4j.rootLogger=error,appender1

log4j.rootLogger=info, stdout, log, errorlog,MongoDB


###Console ###
log4j.appender.stdout = org.apache.log4j.ConsoleAppender
log4j.appender.stdout.Target = System.out
log4j.appender.stdout.layout = org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern =  %d{ABSOLUTE} [ %t ] [ %p ]:%L - %m%n

### Log ###  

log4j.appender.log = org.apache.log4j.DailyRollingFileAppender  
log4j.appender.log.File = log/log.log
log4j.appender.log.Append = true
log4j.appender.log.Threshold = INFO
log4j.appender.log.DatePattern='.'yyyy-MM-dd'.log' 
log4j.appender.log.layout = org.apache.log4j.PatternLayout
log4j.appender.log.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss} [ %t ] %m%n

### Error ###
log4j.appender.errorlog = org.apache.log4j.DailyRollingFileAppender
log4j.appender.errorlog.File = log/errorlog.log
log4j.appender.errorlog.Append = true
log4j.appender.errorlog.Threshold = ERROR 
log4j.appender.errorlog.DatePattern='.'yyyy-MM-dd
log4j.appender.errorlog.layout = org.apache.log4j.PatternLayout
log4j.appender.errorlog.layout.ConversionPattern =%-d{yyyy-MM-dd HH:mm:ss} [ %t ] %m%n

#mongodb 单机配置
#log4j.appender.MongoDB=org.log4mongo.MongoDbAppender
#log4j.appender.MongoDB.databaseName=ce
#log4j.appender.MongoDB.collectionName=log
#log4j.appender.MongoDB.hostname=192.168.1.131
#log4j.appender.MongoDB.port=27017
#log4j.appender.MongoDB.userName=dba
#log4j.appender.MongoDB.password=dba

#mongodb 集群配置
log4j.appender.MongoDB=org.log4mongo.MongoDbAppender
log4j.appender.MongoDB.databaseName=scm
log4j.appender.MongoDB.collectionName=log
log4j.appender.MongoDB.hostname=192.168.1.131 192.168.1.132 192.168.1.133
log4j.appender.MongoDB.port=27017 27017 27017
log4j.appender.MongoDB.userName=dba
log4j.appender.MongoDB.password=dba
日志可以连接到mongdb单机,也可以连接到集群模式
spring.xml


    
    
    
    

记录日志代码,运行程序,然后连接mongodb数据库,就可以看到日志信息了
package com.mongodb;
import java.awt.List;
import java.util.ArrayList;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
import org.springframework.data.mongodb.core.MongoTemplate;
public class App 
{
    private static final Logger logger =LoggerFactory.getLogger(App.class);

    public static void main( String[] args )
    {
        try
        {
              System.out.println("开始运行");
              logger.info("456");
              logger.warn("1233");
        }
        catch(Exception e)
        {

            System.out.println("执行异常"+e.getMessage());
        }

    }
}
项目结构图
slf4j输入日志到mongodb_第1张图片


demo下载http://download.csdn.net/detail/zx13525079024/9666678





你可能感兴趣的:(Java)