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包

  <!-- https://mvnrepository.com/artifact/org.log4mongo/log4mongo-java -->
<dependency>
    <groupId>org.log4mongo</groupId>
    <artifactId>log4mongo-java</artifactId>
    <version>0.7.4</version>
</dependency>

<dependency>  
    <groupId>org.slf4j</groupId>  
    <artifactId>slf4j-log4j12</artifactId>  
    <version>1.7.2</version>  
</dependency>

<dependency>
    <groupId>log4j</groupId>
    <artifactId>log4j</artifactId>
    <version>1.2.17</version>
</dependency>
配置日志文件 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
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:tx="http://www.springframework.org/schema/tx"
    xmlns:jdbc="http://www.springframework.org/schema/jdbc" xmlns:context="http://www.springframework.org/schema/context"
    xsi:schemaLocation="
     http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.0.xsd
     http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
     http://www.springframework.org/schema/jdbc http://www.springframework.org/schema/jdbc/spring-jdbc-3.0.xsd
     http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-3.0.xsd">
    <import resource="classpath:log4j.properties" />
    <context:annotation-config/>
    <import resource="classpath:spring-mongodb.xml" />
    <context:component-scan base-package="com.mongodb" />
</beans>
记录日志代码,运行程序,然后连接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());
        }

    }
}
项目结构图


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





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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值