SpringBoot配置log4j2的JdbcAppender日志写入数据库,可定义哪些日志写入

原创 2017年09月13日 20:29:42
  • 通过java代码给log4j2配置JdbcAppender,为什么不通过log4j2.xml配置,因为数据源的初始化在log4j2.xml后面,会导致初始化log4j2.xml初始化失败,数据源为空报空指针异常。
注意:@SLF4J是lombok.jar的注解,且使用lombok时需要下载lombok的eclipse插件并安装(官网有介绍)官网: https://projectlombok.org/

1、定义一张存储日志的表
CREATE TABLE logs (
		  ID INT(11) NOT NULL AUTO_INCREMENT,
		  CLASS VARCHAR(100) DEFAULT NULL,
		  FUNCTION VARCHAR(100) DEFAULT NULL,
		  LEVEL VARCHAR(100) DEFAULT NULL,
		  LOGGER VARCHAR(100) DEFAULT NULL,
		  MESSAGE TEXT,
		  LOG_DATE TIMESTAMP NULL DEFAULT NULL,
		  PRIMARY KEY (ID)
		) ENGINE=INNODB AUTO_INCREMENT=4 DEFAULT CHARSET=utf8;
2、定义一个获取数据库连接的bean
import java.sql.Connection;
import java.sql.SQLException;

import javax.sql.DataSource;

import org.apache.logging.log4j.core.appender.db.jdbc.ConnectionSource;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;

import lombok.extern.slf4j.Slf4j;

@Slf4j
@Component
public class Connect implements ConnectionSource {

	@Autowired
	private DataSource mysqlDataSource;
	
	@Override
	public Connection getConnection() throws SQLException {
		log.info("获取一个数据库连接");
		return mysqlDataSource.getConnection();
	}
}
mysqlDataSource是一个数据源,在其他地方定义了,你可以将你定义的数据库在此注入
2、定义一个类用来重写log4j2.xml对象
import javax.annotation.PostConstruct;

import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.core.Appender;
import org.apache.logging.log4j.core.Filter;
import org.apache.logging.log4j.core.Logger;
import org.apache.logging.log4j.core.LoggerContext;
import org.apache.logging.log4j.core.appender.db.jdbc.ColumnConfig;
import org.apache.logging.log4j.core.appender.db.jdbc.JdbcAppender;
import org.apache.logging.log4j.core.config.Configuration;
import org.apache.logging.log4j.core.filter.MarkerFilter;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;

@Component
public class LogAppender {
	
	@Autowired
	private Connect connect;

	@PostConstruct
	public void init(){
		final LoggerContext ctx = (LoggerContext) LogManager.getContext(false);
		final Configuration config = ctx.getConfiguration();
		final Logger interLogger = ctx.getLogger("com.hhaip");  //需要写日志到数据库的包名
		
		ColumnConfig[] cc = {
	            ColumnConfig.createColumnConfig(config, "CLASS", "%C", null, null, "false", null),
	            ColumnConfig.createColumnConfig(config, "FUNCTION", "%M", null, null, "false", null),
	            ColumnConfig.createColumnConfig(config, "LEVEL", "%level", null, null, "false", null),
	            ColumnConfig.createColumnConfig(config, "LOGGER", "%logger", null, null, "false", null),
	            ColumnConfig.createColumnConfig(config, "MESSAGE", "%message", null, null, "false", null),
	            ColumnConfig.createColumnConfig(config, "LOG_DATE", null, null, "true", null, null)
	    } ;  
		
	    //配置Marker过滤器(标记过滤器)
		MarkerFilter filter = MarkerFilter.createFilter("dblog", Filter.Result.ACCEPT, Filter.Result.DENY);
		
		Appender appender = JdbcAppender.createAppender("databaseAppender", "true", filter, connect, "0", "logs", cc);
		config.addAppender(appender);
		interLogger.addAppender(appender);
		appender.start();
	        ctx.updateLoggers();    
	}
}
 MarkerFilter用来定义写入日志到数据库的标记过滤器,只有使用了该标记的log才写入到数据库(后面有代码)
 ColumnConfig.createColumnConfig的第二个参数为数据库字段名,ID为自动增长可以不在这定义
 logs是你定义的表名
注意:Connect不要自己new Connect(),new出来的不能将日志写入数据库
3、定义一个Marker标记类
import org.slf4j.Marker;
import org.slf4j.MarkerFactory;

public class Markers {

	public static final Marker DB = MarkerFactory.getMarker("dblog");  //dblog就是上面MarkerFilter里的标记

}
4、在方法中调用日志打印,自定义哪些日志写入数据库
log.info("helloworld");   //不会被写入数据库
log.info(Markers.DB, "查询所有的售货机,数量为:{}", pageVo.getTotal()); //使用了Maeker标记,这条日志会被写入数据库


版权声明:本文为博主原创文章,未经博主允许不得转载。

Spring Boot 添加Log4j框架

Spring Boot 添加Log4j框架                   Spring boot 默认是使用logback来进行日志记录的,但是好多时候,还是喜欢使用log4j,当然Spr...
  • cb2474600377
  • cb2474600377
  • 2016年12月19日 14:59
  • 3659

SpringBoot配置log4j输出日志

SpringBoot配置log4j,设置每天输出一个日志。主要包括两个步骤:第一步,添加log4j.properties配置文件;第二步,初始化配置文件。...
  • loongshawn
  • loongshawn
  • 2016年03月21日 23:34
  • 32986

SpringBoot+Mybatis事务管理

SpringBoot事务管理配置、注意事项及异常说明
  • loongshawn
  • loongshawn
  • 2017年08月08日 22:42
  • 1731

SpringBoot入门系列:第三篇 日志输出

Java程序,日志输出,我认为是第一位的,把它的应用拿到这里。 Spring-Boot对日志的处理,和我们往常的处理完全可以一致,通过logback.xml进行处理,即使有更先进的东西,我们也不用去...
  • sosfnima
  • sosfnima
  • 2016年07月22日 12:09
  • 10575

Spring Mvc那点事---(42)SSM使用log4j2记录日志到mysql数据库

 引子 在系统开发运行过程中,大多数情况下,把日志都记录到系统文件中,但是有一些重要的日志或者信息,需要记录到数据库中。可以根据日志的重要程度,选择相应的级别将日志信息记录到数据库中。log4...
  • zx13525079024
  • zx13525079024
  • 2016年11月16日 14:47
  • 2132

Spring Boot 日志配置(超详细)

Spring Boot 日志配置(超详细)
  • Inke88
  • Inke88
  • 2017年07月12日 11:37
  • 4895

log4j(二)将日志写入数据库

大家知道,有时候日志会记录一些很重要的信息,而这些信息保存在日志文件中我们很难进行有规律的查看和数据分析,这些信息的流失是损失重大的。        因而,我们需要将一些必要的信息写入数据库。  ...
  • u010191243
  • u010191243
  • 2015年12月30日 22:02
  • 425

log4j2.xml记录日志到到数据库

  • 2016年11月16日 14:35
  • 176KB
  • 下载

log4j2 日志配置实战

followtry 2017-04-27 20:00 1.目的 替换log4j,log4j2是log4j的2.x版本但是在log4j上做了比较大的改变,log4j2的性能比log4j好。该...
  • u011277123
  • u011277123
  • 2017年04月28日 12:02
  • 2620

logback&lombok 简化日志处理

logback&lombok 简化日志处理 1      简介 1.1  Logback 相比较log4j,logback性能较好,且日志展现形式较美观。 1.2  Lombok lombo...
  • fjnpysh
  • fjnpysh
  • 2017年06月16日 11:45
  • 329
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:SpringBoot配置log4j2的JdbcAppender日志写入数据库,可定义哪些日志写入
举报原因:
原因补充:

(最多只允许输入30个字)