本文根据实战经验复写SpringBoot+slf4j+log4j的日志集成方式,并配置相关控制台、文件、密码加密数据库输出打印等方式。
1、SpringBoot项目中的log4j maven相关依赖和原logback(SpringBoot自带)解除:
org.springframework.boot
spring-boot-starter-web
ch.qos.logback
logback-classic
org.springframework.boot
spring-boot-starter
org.springframework.boot
spring-boot-starter-logging
commons-logging
commons-logging
1.2
2、application.properties或yml文件的配置如下加入一行:
#log4j2配置路径
logging.config=classpath:log4j.properties
3、log4j文件的配置,详细参数及说明如下,错误日志会打印到单独的一个文件,普通级别打印则会输出到普通文件并每日产生一个新文件:
# The five logging levels used by Log are (in order):
# 1. DEBUG 2. INFO 3. WARN 4. ERROR 5. FATAL (the most serious)
# Set root logger level to WARN and append to S
log4j.rootLogger=INFO,S,R,E,D
#######################
# 控制台打印
log4j.appender.S=org.apache.log4j.ConsoleAppender
log4j.appender.S.layout=org.apache.log4j.PatternLayout
log4j.appender.S.layout.ConversionPattern=%d %5p (%c:%L) - %m%n
#######################
# 每天新增一个文件
log4j.appender.R=org.apache.log4j.DailyRollingFileAppender
log4j.appender.R.File=D:\\pingan\\log\\sentiAnalys.log
log4j.appender.R.Append=true
log4j.appender.R.DatePattern='.'yyyy-MM-dd'.log'
##输出INFO级别以上的日志
log4j.appender.R.Threshold=INFO
log4j.appender.R.layout=org.apache.log4j.PatternLayout
log4j.appender.R.layout.ConversionPattern=[%d] %5p (%c:%L) - %m%n
#######################
# 保存异常信息到单独文件
log4j.appender.E=org.apache.log4j.DailyRollingFileAppender
## 异常日志文件名
log4j.appender.E.File=D:\\pingan\\log\\sentiAnalysErr.log
log4j.appender.E.Append=true
log4j.appender.E.Threshold=ERROR
## 只输出ERROR级别以上的日志!!!
log4j.appender.E.layout=org.apache.log4j.PatternLayout
log4j.appender.E.layout.ConversionPattern=%-d{yyyy-MM-dd HH:mm:ss} [ %t:%r ] - [ %p ] %m%n
#######################
# 数据库输出 加密psd
log4j.appender.D=com.pa.data.log.JDBCAppenderFix
log4j.appender.D.URL=jdbc:mysql://localhost:3306/padata
log4j.appender.D.driver=com.mysql.jdbc.Driver
log4j.appender.D.user=root
log4j.appender.D.password=NcOVb4IWFVw=
log4j.appender.D.sql=INSERT INTO syslog(CREATEDATE,THREAD,GRADE,CLASS,MESSAGE,PID,CURRENTSTATE) values('%d','%t','%-5p','%c','%m','%X{pid}',%X{currentstate})
log4j.appender.D.layout=org.apache.log4j.PatternLayout
log4j.appender.D.Threshold=ERROR
log4j.appender.D.layout.ConversionPattern=%-d{yyyy-MM-dd HH:mm:ss} [ %t:%r ] - [ %p ] %m%n
###注意,pid,和currentstate是要在日志在输入给数据库之前,必须先设置好,在logger.ERROR(“…”)之前传入MDC自定义的参数值:
###MDC.put("pid", pid);
###MDC.put("currentstate", 1);
###不追加字段则可用 log4j.appender.D.layout.ConversionPattern=[framework] %d - %c -%-4r [%t] %-5p %c %x - %m%n
#
# Print only messages of level ERROR or above in the package noModule.
log4j.logger.noModule=FATAL
log4j.logger.com.pa=DEBUG
注意 log4j.rootLogger=INFO,S,R,E,D 中,先写入INFO是能让控制台打印所有日志。
4、如上数据库打印所用的jdbc密码采用的是DES+base64转换的加密方式,实现方法网上比较多。目标表创建sql如下,
DROP TABLE IF EXISTS `syslog`;
CREATE TABLE `syslog` (
`CREATEDATE` varchar(128) default NULL,
`THREAD` varchar(128) default NULL,
`GRADE` varchar(128) default NULL,
`CLASS` varchar(128) default NULL,
`MESSAGE` text,
`PID` bigint(20) default NULL,
`CURRENTSTATE` varchar(255) default NULL,
`AUTOID` bigint(20) NOT NULL auto_increment,
PRIMARY KEY (`AUTOID`)
) ENGINE=InnoDB DEFAULT CHARSET=gbk;
同时,需要重写JDBCAppender日志appender,如这里继承实现类JDBCAppenderFix,并设置
log4j.appender.D=com.pa.data.log.JDBCAppenderFix
重写类步骤如下。
5、复写JDBCAppender(继承)为JDBCAppenderFix,该类的具体作用就是给log4j配置文件中的jdbc密码解密:
package com.pa.data.log;
import com.pa.analysis.utils.DESUtil;
import org.apache.log4j.jdbc.JDBCAppender;
public class JDBCAppenderFix extends JDBCAppender {
@Override
public void setPassword(String password) {
try {
password = DESUtil.decryptStr(password);
} catch (Exception e) {
e.printStackTrace();
}
this.databasePassword = password;
}
}
注意,DESUtil.decryptStr(password) 就是对上面配置密码的解密。
6、项目中使用,如上配置,普通的debug、info等日志输出会打印到相关控制台或文件,但是error级别会打印到另外文件和数据库,打印到控制台和记录文件的使用如下:
private final Logger logger = LoggerFactory.getLogger(getClass());
……………………
logger.info("XX Factory create YY bean OK!");
这里设置的是,如果为error级别则会打印到另外一个文件和数据库:
private final Logger logger = LoggerFactory.getLogger(getClass());
………………………………
try {
afterEnc = DESUtil.encryptStr(str);//异常则打印错误
} catch (Exception e) {
MDC.put("pid", "123");
MDC.put("currentstate", "1");
logger.error(e.getMessage().toString());
return "error:" + e.getMessage();
}
—————————————————————————————
普通的文件和控制台打印正常,数据库打印的日志查看效果如下:
分普通日志和错误日志的文件打印效果如下:
over!
log4j部分配置参考:https://www.cnblogs.com/tapt/p/8056457.html