转载自:http://wallimn.iteye.com/blog/1525819

Log4J日志输出到数据库中,且保存些用户自定义的参数,如用户ID,且配置仅输出指定级别的日志。 



配置文件如下:  

log4j.rootLogger=DEBUG,logfile,stdout 



log4j.logger.SYSTEM = INFO,JDBC 

#也可以使用包名或类名,这样可以用JAVA的class来初始化logger 

log4j.logger.com.wallimn.test=INFO,JDBC 

#不继承父appender的配置,如果取消注释,rootCategory指定的appender将不再输出 

#log4j.additivity.SYSTEM=false 



#stdout configure 

log4j.appender.stdout=org.apache.log4j.ConsoleAppender 

log4j.appender.stdout.Threshold=DEBUG 

log4j.appender.stdout.layout=org.apache.log4j.PatternLayout 

log4j.appender.stdout.layout.ConversionPattern= %d %5p [%c] - %m%n 



#logfile configure 

log4j.appender.logfile=org.apache.log4j.DailyRollingFileAppender 

log4j.appender.logfile.File=./wallimn.log 

log4j.appender.logfile.layout=org.apache.log4j.PatternLayout 

log4j.appender.logfile.layout.ConversionPattern= %d{yyyy MM dd HH:mm:ss} %5p [%c] - %m%n 



#JDBC configure 

log4j.appender.JDBC=org.apache.log4j.jdbc.JDBCAppender 

#此处优先级高于log4j.logger.SYSTEM指定级别, 

log4j.appender.JDBC.Threshold=INFO 

log4j.appender.JDBC.driver=oracle.jdbc.driver.OracleDriver 

log4j.appender.JDBC.URL=jdbc:oracle:thin:@127.0.0.1:1521:swdb 

log4j.appender.JDBC.user=scott 

log4j.appender.JDBC.password=tiger 

log4j.appender.JDBC.layout=org.apache.log4j.PatternLayout 

log4j.appender.JDBC.sql=INSERT INTO XT_SYS_LOG(USERID,LOGTIME,LOGLEVEL,LOGACTION,MESSAGE)VALUES('%X{userId}',sysdate,'%p','%l','%m')

log4j.appender.JDBC.filter.F1=org.apache.log4j.varia.LevelRangeFilter 

#只接收ERROR级别的日志,这是很有用的技术 

#这功能在1.2.8版本时,不支持这样配置,好像仅支持XML方式配置,我试了好多次才发现这个问题 

#可多个Filter组合共同限制 

log4j.appender.JDBC.filter.F1.levelMin=ERROR 

log4j.appender.JDBC.filter.F1.levelMax=ERROR 

log4j.appender.JDBC.filter.F1.acceptOnMatch=true 



建测试表的SQL: 

create table xt_sys_log( 

userid number, 

logtime date, 

logaction varchar2(100), 

loglevel varchar2(100), 

message varchar2(255)); 



测试类:

  1. package com.wallimn.test;
  2. import org.apache.log4j.Logger;
  3. import org.apache.log4j.MDC;
  4. import junit.framework.TestCase;
  5. public class Log4JTest extends TestCase {
  6. public void testLog1(){
  7. Logger logger = Logger.getLogger("SYSTEM");
  8. //Logger logger = Logger.getLogger(Log4JTest.class);
  9. MDC.put("userId", "11");
  10. logger.fatal("test_fatal");
  11. logger.error("test_Error");
  12. logger.warn("test_warn");
  13. logger.info("test_Info");
  14. logger.debug("test_debug");
  15. MDC.remove("userId");
  16. }
  17. }

控制台输出: 

2012-05-12 22:08:01,156 FATAL [SYSTEM] - test_fatal 

2012-05-12 22:08:01,156 ERROR [SYSTEM] - test_Error 

2012-05-12 22:08:01,421 WARN [SYSTEM] - test_warn 

2012-05-12 22:08:01,421 INFO [SYSTEM] - test_Info 



数据库记录查询: 

SQL> select userid,loglevel,message from xt_sys_log; 



    USERID LOGLEVEL             MESSAGE 

---------- -------------------- -------------------- 

        11 ERROR                test_Error 



注意:仅记录了一条日志。

log4j输出到数据库(输出自定义参数、分级保存)的更多相关文章

  1. log4j配置输出到数据库+自定义字段

    Log4j.properties配置 log4j.rootLogger = info,stdout,D,E,A3 log4j.appender.Threshold=info ### 控制台输出### ...

  2. log4j 输出到 数据库

    # LOG4J配置 log4j.rootCategory=ERROR,stdout,errorfile,jdbc # 控制台输出 log4j.appender.stdout=org.apache.lo ...

  3. log4j.xml配置,包含自定义log4j日志级别及输出日志到不同文件

      一.配置 <?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE log4j:configura ...

  4. 使用log4j配置不同文件输出不同内容

    敲代码中很不注意写日志,虽然明白很重要.今天碰到记录日志,需要根据内容分别输出到不同的文件. 参考几篇文章: 感觉最详细:http://blog.csdn.net/azheng270/article/ ...

  5. Asp.Net Core NLog 将日志输出到数据库以及添加LayoutRenderer的支持

    在这之前打算用Apache的Log4Net,但是发现其AdoNetAppender方法已经不存在了,无法使用配置文件直接输出到数据库了,因此我便改用了NLog框架. 一.对项目添加NLog 通过Nug ...

  6. 《手把手教你》系列基础篇(八十七)-java+ selenium自动化测试-框架设计基础-Log4j 2实现日志输出-上篇(详解教程)

    1.简介 Apache Log4j 是一个非常古老的日志框架,并且是多年来最受欢迎的日志框架. 它引入了现代日志框架仍在使用的基本概念,如分层日志级别和记录器. 2015 年 8 月 5 日,该项目管 ...

  7. log4net 控制台和文件和数据库输出三种方式

    1.新建console应用项目SendEvaluateDataToProvinceConsole 2.选择SendEvaluateDataToProvinceConsole项目右键 选择 管理NuGe ...

  8. Log4j 输出的日志中时间比系统时间少了8小时的解决方法,log4j日志文件重复输出

    1. 第一个问题:时间少了8小时 Log4j 输出的日志中,时间比系统时间少了8小时,但是 eclipse 控制台输出的日志的时间却是对的. log4j配置如下: #all logger output ...

  9. log4net:保存自定义参数到数据库

    log4net:保存日志到数据库 自定义参数 新建一个类,继承于PatternLayoutConverter public class CustomerPatternConverter : Patte ...

随机推荐

  1. sql STUFF 分组

    ---将sql想关的数据放到一个字段里 select r.Region_Name, )) [text()] from City c2 inner join Region as r2 on c2.Reg ...

  2. 卸载CDH5.7

    CDH5.7卸载1.记录用户数据目录2.关闭所有服务2.1在CM中,选择某个集群,然后停止集群.2.2逐个关闭CDH中的服务3.删除parcels4.删除集群5.卸载Cloudera manager ...

  3. win10 死机

    其实Win10系统还是不错的,如果你的电脑升级Win10后中招经常死机,可以用下面的方案来应对. 1.下载安装支持兼容Win10的软件版本,下载软件之前看一下兼容列表里是否有Win10系统.虽然Win ...

  4. 【week2】四人小组项目(WBS、NABCD)

    项目选题:东北师范大学论坛 小组名称:nice! 项目组长:李权 组员:于淼 刘芳芳 杨柳 本周任务:要求给出需求概述.功能列表.痛点或亮点.NABCD及WBS模型在此项目中的应用. 作为东北师范大学 ...

  5. mysql学习之主从复制

    该文使用mysql5.5 centos6.5 64位 一.主从复制的作用 1.如果主服务器出现问题,可以快速切换到从服务器. 2.对与实时性要求不高或者更新不频繁的应用可以在从服务器上执行查询操作,降 ...

  6. Bootstrap 按钮,图片,辅助类

    Bootstrap 按钮 任何带有 class .btn 的元素都会继承圆角灰色按钮的默认外观.但是 Bootstrap 提供了一些选项来定义按钮的样式,具体如下表所示: 以下样式可用于<a&g ...

  7. 【Python】python文件名和文件路径操作

    Readme: 在日常工作中,我们常常涉及到有关文件名和文件路径的操作,在python里的os标准模块为我们提供了文件操作的各类函数,本文将分别介绍“获得当前路径”“获得当前路径下的所有文件和文件夹, ...

  8. Hessian矩阵【转】

    http://blog.sina.com.cn/s/blog_7e1ecaf30100wgfw.html 在数学中,海塞矩阵是一个自变量为向量的实值函数的二阶偏导数组成的方块矩阵,一元函数就是二阶导, ...

  9. 【bzoj1798】[Ahoi2009]Seq 维护序列seq 线段树

    题目描述 老师交给小可可一个维护数列的任务,现在小可可希望你来帮他完成. 有长为N的数列,不妨设为a1,a2,…,aN .有如下三种操作形式: (1)把数列中的一段数全部乘一个值; (2)把数列中的一 ...

  10. select模型的原理、优点、缺点

    关于I/O多路复用: I/O多路复用(又被称为“事件驱动”),首先要理解的是,操作系统为你提供了一个功能,当你的某个socket可读或者可写的时候,它可以给你一 个通知.这样当配合非阻塞的socket ...