0
点赞
收藏
分享

微信扫一扫

java中如何使用log4j将日志信息写入数据库中(转)

芝婵 2023-07-27 阅读 76

    首先将 log4j的 jar包和 Logging的jar包导入到你的工程中,然后在工程src目录创建一个属性文件: log4j.properties,也可以放在某个包中,但是获取这个属性文件的时候就需要制定路径。



1.创建日志数据表:

view plain print ?

1. CREATE TABLE log (  
2. int] IDENTITY (1, 1) primary key NOT NULL ,  
3. NOT NULL ,  
4. varchar] (50) COLLATE Chinese_PRC_CI_AS NOT NULL ,  
5. varchar] (20) COLLATE Chinese_PRC_CI_AS NOT NULL ,  
6. varchar] (200) COLLATE Chinese_PRC_CI_AS NOT NULL ,  
7. varchar] (2000) COLLATE Chinese_PRC_CI_AS NOT NULL  
8. )  
9. GO


2.写log4j.properties文件,这里我的数据库举动是用的 JTDS:

引用


3.在程序中需要将日志信息写入数据库的地方写入如下代码:

# level : 是日志记录的优先级,分为OFF、FATAL、ERROR、WARN、INFO、DEBUG、ALL或者您定义的级别。    
# Log4j建议只使用四个级别,优先级从高到低分别是ERROR、WARN、INFO、DEBUG。    
log4j.rootLogger=ERROR,DATABASE    
log4j.addivity.org.apache=true    

# 用于数据库    
log4j.appender.DATABASE=org.apache.log4j.jdbc.JDBCAppender    
log4j.appender.DATABASE.URL=jdbc:jtds:sqlserver://localhost:1433;DatabaseName=databasename    
log4j.appender.DATABASE.driver=net.sourceforge.jtds.jdbc.Driver    
log4j.appender.DATABASE.user=username    
log4j.appender.DATABASE.password=password    
# 本处设置为"WARN"以上级别在数据库存储(默认情况使用rootLogger中的设置)    
log4j.appender.DATABASE.Threshold=DEBUG    
log4j.appender.DATABASE.sql=INSERT INTO log(optime,thread,infolevel,class,message) VALUES ('%d{yyyy-MM-dd HH:mm:ss}', '%t', '%p', '%l', '%m')    
# 写入数据库中的表LOG4J的Message字段中,    
# 内容%d(日期)%c: 日志信息所在地(类名)%p: 日志信息级别%m: 产生的日志具体信息 %n: 输出日志信息换行    

log4j.appender.DATABASE.layout=org.apache.log4j.PatternLayout    
log4j.appender.DATABASE.layout.ConversionPattern=[framework] %d - %c -%-4r [%t] %-5p %c %x - %m%n

view plain print ?


1. private Log logger = LogFactory.getLog(this.getClass());  
2. logger.info("信息:......");  
3. logger.debug("调试:......");  
4. logger.warn("警告:......");  
5. logger.error("错误:......");



举报

相关推荐

0 条评论