引子
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