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

5月14

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

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

1.创建日志数据表:
  1. CREATE TABLE log (  
  2.   [Id] [int] IDENTITY (1, 1) primary key NOT NULL ,  
  3.   [Lg_Date] [datetime] NOT NULL ,  
  4.   [Lg_Thread] [varchar] (50) COLLATE Chinese_PRC_CI_AS NOT NULL ,  
  5.   [Lg_Level] [varchar] (20) COLLATE Chinese_PRC_CI_AS NOT NULL ,  
  6.   [Lg_Class] [varchar] (200) COLLATE Chinese_PRC_CI_AS NOT NULL ,  
  7.   [Lg_Message] [varchar] (2000) COLLATE Chinese_PRC_CI_AS NOT NULL  
  8. )  
  9. GO  

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

# 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


3.在程序中需要将日志信息写入数据库的地方写入如下代码:
  1. private Log logger = LogFactory.getLog(this.getClass());  
  2. logger.info("信息:......");  
  3. logger.debug("调试:......");  
  4. logger.warn("警告:......");  
  5. logger.error("错误:......");  


来源: Heck's Blog
地址: http://www.hecks.tk/post/44/
转载时须以链接形式注明作者和原始出处及本声明,否则将追究法律责任,谢谢配合!

你可能感兴趣的:(log4j)