log4j日志写入数据库
首先创建一数据库表:
字段 描述 GUID 流水号 IDENTITY (1, 1) DATE 时间 THREAD 当前线程 LEVEL 当前级别 CLASS 当前类的java程序/方法 MESSAGES 当前输出信息 EXCEPTION 异常信息
log4j.properties如下配置:
log4j.rootLogger=DEBUG,CONSOLE,DATABASE
log4j.addivity.org.apache=true ######################## # JDBC Appender ####################### log4j.appender.DATABASE.Threshold=INFO log4j.appender.DATABASE=org.apache.log4j.jdbc.JDBCAppender #log4j.appender.DATABASE.BufferSize=10 log4j.appender.DATABASE.URL=you jdbcurl log4j.appender.DATABASE.driver=you jdbc driver log4j.appender.DATABASE.user= log4j.appender.DATABASE.password= log4j.appender.DATABASE.sql=INSERT INTO YOU_LOG_TABLE VALUES ('%d{yyyy-MM-dd HH:mm:ss}',
'%t', '%p', '%l', '%m', '') log4j.appender.DATABASE.layout=org.apache.log4j.PatternLayout 下面我们对“%d %t %p %l %m %n”一一讲解: l %d输出日志时间点的日期或时间,默认格式为ISO8601,也可以在其后指定格式,
比如:%d{yyyy-MM-dd HH:mm:ss},输出类似:2006-01-18 17:50:22',刚好适合插入SQLServer; l %t 产生该日志事件的线程名; l %p 日志的log_level,如DEBUG、WARN或者INFO; l %c 输出所属的类目,通常就是所在类的全名,如“com.eking.TestLog”; l %m 日志的内容; l %l 输出日志事件的发生位置,包括类目名、发生的线程,以及在代码中的行数。
如Wite2Database.main(Wite2Database.java:18); l %n 输出一个回车换行符,Windows平台为“ ”,Unix平台为“ ” 程序代码:
import sun.jdbc.odbc.*;
import java.sql.*;
文章来源于领测软件测试网 https://www.ltesting.net/