log4j提供了org.apache.log4j.JDBCAppender对象,可以把日志输出到特定的数据库。

常用的属性:

  • bufferSize 设置buffer的大小,默认是1
  • driver 设置数据库的驱动字符串,比如sun.jdbc.odbc.OdbcDriver
  • layout 设置使用的layout,默认是org.apache.log4j.PatternLayout
  • password 设置数据的密码
  • sql 设置每次日志产生的时候执行的sql语句,可以是INSERT,UPDATE,DELETE
  • URL 设置JDBC URL
  • user 设置数据库的用户名

在输出日志之前,还应该创建数据库中的表,执行下面的SQL语句


  1. CREATE TABLE LOGS
  2. (USER_ID VARCHAR(20) NOT NULL,
  3. DATED
  4. DATE NOT NULL,
  5. LOGGER VARCHAR(50) NOT NULL,
  6. LEVEL
  7. VARCHAR(10) NOT NULL,
  8. MESSAGE VARCHAR(1000) NOT NULL
  9. );

log4j.properties文件配置

下面是JDBCAppender的相关配置:


  1. log4j.rootLogger = DEBUG, DB
  2. log4j.appender.DB=org.apache.log4j.jdbc.JDBCAppender
  3. log4j.appender.DB.URL=jdbc:mysql://localhost/DBNAME
  4. log4j.appender.DB.driver=com.mysql.jdbc.Driver
  5. log4j.appender.DB.user=user_name
  6. log4j.appender.DB.password=password
  7. log4j.appender.DB.sql=INSERT INTO LOGS VALUES('%x','%d','%C','%p','%m')
  8. log4j.appender.DB.layout=org.apache.log4j.PatternLayout

对于MySQL数据库来说,当创建了LOGS表后你还需要使用dbname,user_name,password。

如果在xml中配置可以参考如下:

``

log4j:configuration

``

代码样例

下面这个例子,在java代码中使用了Log4j输出:


  1. import org.apache.log4j.Logger;
  2. import java.sql.*;
  3. import java.io.*;
  4. import java.util.*;
  5. public class log4jExample{
  6. /* Get actual class name to be printed on */
  7. static Logger log = Logger.getLogger(log4jExample.class.getName());
  8. public static void main(String[] args)throws IOException,SQLException{
  9. log.debug("Debug");
  10. log.info("Info");
  11. }
  12. }

编译和执行

执行后就可以查询结果了:


  1. mysql > select * from LOGS;
  2. +---------+------------+--------------+-------+---------+
  3. | USER_ID | DATED
  4. | LOGGER
  5. | LEVEL | MESSAGE |
  6. +---------+------------+--------------+-------+---------+
  7. |
  8. | 2010-05-13 | log4jExample | DEBUG | Debug
  9. |
  10. |
  11. | 2010-05-13 | log4jExample | INFO | Info
  12. |
  13. +---------+------------+--------------+-------+---------+
  14. 2 rows in set (0.00 sec)

Log4j官方文档翻译(九、输出到数据库)的更多相关文章

  1. Log4j官方文档翻译(八、文件输出)

    使用org.apache.log4j.FileAppender可以把日志写到文件中: FileAppender配置 immediateFlush 这个标志默认为true,是否每次有消息产生都自动flu ...

  2. Log4j官方文档翻译(五、日志输出的方法)

    日志类提供了很多方法用于处理日志活动,它不允许我们自己实例化一个logger,但是提供给我们两种静态方法获得logger对象: public static Logger getRootLogger() ...

  3. Log4j官方文档翻译(四、如何在java中输出日志消息)

    我们已经创建来配置文件,本章详细的介绍下如何生成调试信息,并把他们转化成文本文件. 基本的例子 下面就是创建的一个基本的例子: log4j.properties的内容为: log = /usr/hom ...

  4. Log4j官方文档翻译(二、架构设计)

    log4j遵循层次化架构,每个层都有不同的对象来执行不同的任务.这种层次话的结构灵活设计.易于未来的扩展. log4j框架中有两种对象: 核心对象:框架的支撑对象,是框架必不可少的组成部分. 支撑对象 ...

  5. Log4j官方文档翻译(一、基本介绍)

    简介 log4j是使用java语言编写的可靠的.快速的.灵活的日志框架,它是基于Apache的license. log4j支持c,c++,c#,perl,python,ruby等语言.在运行时通过额外 ...

  6. Log4j官方文档翻译(七、日志格式化)

    apache log4j提供各种layout对象,然后根据自己指定的layouts对象转化日志信息.通常来说都是应用量身定制layout对象转换信息格式. 所有的layout对象从Appender对象 ...

  7. Log4j官方文档翻译(六、日志的级别)

    org.apache.log4j.Level 类提供了下面几种日志级别,你也可以通过继承这些类,自定义级别 ALL 所有日志级别都包括 DEBUG 指定信息事件的粒度是DEBUG,在调试应用的时候会有 ...

  8. Log4j官方文档翻译(三、配置)

    之前的章节介绍了log4j的核心组件,本章将会通过配置文件介绍一下核心组建的配置. 主要在配置文件中配置log4j的日志级别,定义appender.layout等. log4j.properties是 ...

  9. Android官方文档翻译 九 2.2Adding Action Buttons

    Adding Action Buttons 增加动作按钮 This lesson teaches you to 这节课教给你 Specify the Actions in XML 在XML中指定动作 ...

随机推荐

  1. vue登录权限

    登录:当用户填写完账号和密码后向服务端验证是否正确,验证通过之后,服务端会返回一个token,拿到token之后(我会将这个token存贮到cookie中,保证刷新页面后能记住用户登录状态),前端会根 ...

  2. 全面了解linux情况常用命令

    查看linux服务器CPU详细情况1. 显示CPU个数命令 # cat /proc/cpuinfo | grep "physical id" | sort | uniq | wc ...

  3. 深入理解计算机系统_3e 第九章家庭作业 CS:APP3e chapter 9 homework

    9.11 A. 00001001 111100 B. +----------------------------+ | Parameter Value | +--------------------- ...

  4. React后台管理系统-rich-editor组件

    1.Simditor组件的github地址:https://github.com/mycolorway/simditor 网址:http://simditor.tower.im/ 2.在util里边新 ...

  5. mysql查看版本,编码

    SELECT * FROM gps_gpsinfo t WHERE t.reportdate < TO_DATE('2019/4/28 10:05:07', 'yyyy-MM-dd hh24:m ...

  6. vue项目各页面间的传值

    githut地址:https://github.com/liguoyong/vueobj1 一.父子之间主键传值:(主要是在父主件里的子主件传递参数,然后再子主件里用props接收) 例如Father ...

  7. 垂直居中一个img

    { display:table-cell; text-align:center; vertical-align:middle; }

  8. Duizi and Shunzi HDU - 6188 (贪心)2017 广西ACM/ICPC

    Duizi and Shunzi Time Limit: 6000/3000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) ...

  9. BZOJ3398: [Usaco2009 Feb]Bullcow 牡牛和牝牛(dp)

    题意     约翰要带N(1≤N≤100000)只牛去参加集会里的展示活动,这些牛可以是牡牛,也可以是牝牛.牛们要站成一排.但是牡牛是好斗的,为了避免牡牛闹出乱子,约翰决定任意两只牡牛之间至少要有K( ...

  10. neo4j 安装

    查看 http://ip:7474/browser/