当前位置:Gxlcms > 数据库问题 > log4j日志存储到数据库

log4j日志存储到数据库

时间:2021-07-01 10:21:17 帮助过:39人阅读

TABLE `reslog` ( `LOGID` int(20) NOT NULL AUTO_INCREMENT, `CLASS` varchar(200) DEFAULT NULL, `METHOD` varchar(100) DEFAULT NULL, `CREATETIME` date DEFAULT NULL, `LOGLEVEL` varchar(50) DEFAULT NULL, `MSG` varchar(4000) DEFAULT NULL, PRIMARY KEY (`LOGID`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8;

    因为存储的类为类的全部路径,所以CLASS字段长度需要比较大。

2、日志管理配置

            LOG4J主要有两种配置文件.properties和.xml,这里以properties文件为基础来讲

      述,关于XML文件的配置,相信大家看完下面的介绍也一样能轻松完成。

            通常在LOG4J.PROPERTIES文件的第一行是:

            log4j.rootLogger= XXX,这句是控制日志的输出,如果想吧日志输出到数据库,

      则需要在XXX中添加“database”,如log4j.rootLogger=INFO,stdout,database。上面

      这句就是把日志中级别为INFO的信息输出到STDOUT和database中。

            配置好如上的信息,LOG4J就知道用户是想把信息存入数据库,接下来我们就要来

      配置数据库的相关信息(包括缓存,数据库连接信息,和执行SQL),配置信息如下:

log4j.appender.database=org.apache.log4j.ConsoleAppender
log4j.appender.database.layout=org.apache.log4j.PatternLayout  
log4j.appender.database.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss:SSS}[%p]: %m%n  
log4j.appender.database=org.apache.log4j.jdbc.JDBCAppender
log4j.appender.database.driver=com.mysql.jdbc.Driver
log4j.appender.database.URL=jdbc:mysql://127.0.0.1:3306/tax_sjz?useUnicode=true&characterEncoding=UTF-8
log4j.appender.database.user=root
log4j.appender.database.password=123456
log4j.appender.database.sql=insert into reslog (class,method,createtime,loglevel,msg) VALUES (‘%C‘,‘%M‘,‘%d{yyyy-MM-dd hh:mm:ss}‘,‘%p‘,‘%m‘)  
log4j.appender.database.layout=org.apache.log4j.PatternLayout

log4j的配置中不允许有空格出现,

如果系统中的部分组件打印信息中包含"‘"(单引号),系统会报“确实逗号”的错误,搞了半天也解决不了,还好打印的都是INFO,把打印级别设为“WARN”就OK了

log4j日志存储到数据库

标签:ogg   user   utf-8   primary   auto   method   values   基础   weight   

人气教程排行