找回密码
 立即注册

本文来自

电脑/上网

电脑/上网

订阅|关注

致力于提供软件新闻发布,和软件知识学习,包括常用软件应用技巧及评测,创意设计相关的图文及视频教程

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

[复制链接]
230 temp001ww 发表于 2017-9-13 21:24:52
通过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标记,这条日志会被写入数据库

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?立即注册

x
温馨提示:
1、在论坛里发表的文章仅代表作者本人的观点,与本网站立场无关。
2、论坛的所有内容都不保证其准确性,有效性,时间性。阅读本站内容因误导等因素而造成的损失本站不承担连带责任。
3、若因线路及非本站所能控制范围的故障导致暂停服务期间造成的一切不便与损失,论坛不负任何责任。
4,本网站内容均摘自其他网站,如涉及侵权定当第一时间删除
5、如侵犯您的权益请联系936144721@qq.com



上一篇:研 究 生( 专业实习实践)报 告
下一篇:vivoX9原装充电器 充不进去电 别的充电器能充进去 原装充电器充别的手机
转载请说明出处,本文地址:http://bbs.imicun.com/thread-15464758-1-1.html
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

快速回复 返回顶部 返回列表