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语句


CREATE TABLE LOGS
(USER_ID VARCHAR(20) NOT NULL,
DATED
DATE NOT NULL,
LOGGER VARCHAR(50) NOT NULL,
LEVEL
VARCHAR(10) NOT NULL,
MESSAGE VARCHAR(1000) NOT NULL
);

log4j.properties文件配置

下面是JDBCAppender的相关配置:


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

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

如果在xml中配置可以参考如下:
<?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE log4j:configuration SYSTEM "log4j.dtd"> <log4j:configuration> <appender name="DB" > <param name="url" value="jdbc:mysql://localhost/DBNAME"/> <param name="driver" value="com.mysql.jdbc.Driver"/> <param name="user" value="user_id"/> <param name="password" value="password"/> <param name="sql" value="INSERT INTO LOGS VALUES('%x','%d','%C','%p','%m')"/> <layout > </layout> </appender> <logger name="log4j.rootLogger" additivity="false"> <level value="DEBUG"/> <appender-ref ref="DB"/> </logger> </log4j:configuration>

代码样例

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


import org.apache.log4j.Logger;
import java.sql.;
import java.io.;
import java.util.;
public class log4jExample{
/ Get actual class name to be printed on */
static Logger log = Logger.getLogger(log4jExample.class.getName());
public static void main(String[] args)throws IOException,SQLException{
log.debug("Debug");
log.info("Info");
}
}

编译和执行

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


mysql > select * from LOGS;
+---------+------------+--------------+-------+---------+
| USER_ID | DATED
| LOGGER
| LEVEL | MESSAGE |
+---------+------------+--------------+-------+---------+
|
| 2010-05-13 | log4jExample | DEBUG | Debug
|
|
| 2010-05-13 | log4jExample | INFO | Info
|
+---------+------------+--------------+-------+---------+
2 rows in set (0.00 sec)

Log4j官方文档翻译(九、输出到数据库)相关推荐

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

    2019独角兽企业重金招聘Python工程师标准>>> 简介 log4j是使用java语言编写的可靠的.快速的.灵活的日志框架,它是基于Apache的license. log4j支持 ...

  2. django 1.8 官方文档翻译: 2-5-6 多数据库

    多数据库 这篇主题描述Django 对多个数据库的支持.大部分Django 文档假设你只和一个数据库打交道.如果你想与多个数据库打交道,你将需要一些额外的步骤. 定义你的数据库 在Django中使用多 ...

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

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

  4. Injective Protocol官方文档翻译(九) -清盘、清算(Liquidation)

    文章目录 一.清盘.清算(Liquidation) 1. 用订单清算头寸(liquidatePositionWithOrders) 一.清盘.清算(Liquidation) liquidation 英 ...

  5. flume可以实时监控mysql嘛_flume使用(三):实时log4j日志通过flume输出到MySql数据库...

    本文在[flume使用(二):采集远程日志数据到MySql数据库]一文基础之上进行测试操作.本文使用到的: flume版本.jdk版本.mysql.数据库表.javaBean.自定义的mysqlSin ...

  6. db4o_8.0对象数据库官方文档翻译_学习笔记三

    紧接上篇:db4o_8.0对象数据库官方文档翻译_学习笔记二 3. Object Manager Enterprise Overview(OME视图)即OME插件的使用 If you did not  ...

  7. Log4j2官方文档翻译--欢迎使用Log4j2!

    官网原文标题<Welcome to Log4j 2!> 官网原文地址http://logging.apache.org/log4j/2.x/manual/index.html 译者:本文介 ...

  8. 【iOS官方文档翻译】iOS蓝牙的基本概念

    之前写了[iOS官方文档翻译]iOS的蓝牙连接.数据接收及发送一文,介绍了怎样进行蓝牙通讯,但是很多基本概念没有进行解释,看起来可能有点吃力,所以现在再翻译一篇苹果对官方蓝牙4.0一些基本概念介绍的文 ...

  9. fastapi官方文档翻译 -目录

    fastapi官方文档翻译 warmsirius 最新发布 最新评论 目录 fastapi教程翻译(前言):安装和运行 fastapi教程翻译(一):了解FastAPI结构 fastapi教程翻译(二 ...

最新文章

  1. socket阻塞与IO多路复用
  2. 盘点几个开源的高仿项目,B站最像~
  3. java分布式面试题之Dubbo部分
  4. NEFU705(数论+DP)
  5. windows server 2008 iis6.0 无法下载.exe
  6. P1-0:项目框架搭建
  7. scanf函数的返回值问题
  8. 搞定面试官:咱们从头到尾再说一次 Java 垃圾回收
  9. pooleddb mysql_使用dbutils的PooledDB连接池,操作数据库
  10. Ubuntu 下 matplotlib 中文乱码
  11. iOS生成图片分享到微信的一种方法
  12. MAC地址到IPV6地址的转换
  13. php购物车页面如何做,HTML代码实现简易购物车
  14. 雷达原理-雷达发射机
  15. java 字节单位换算_【java虚拟机】内存使用单位换算
  16. 谷粒商城-分布式基础篇2
  17. 转:solr 从数据库导入数据,全量索引和增量索引(实例配置原理)
  18. Go语言云原生与微服务(一)云原生架构
  19. 天池龙珠训练营广东工业-林莉子学习笔记-Task1
  20. 计算机组成原理题目透析(2)

热门文章

  1. 浅析几种线程安全模型
  2. Spring Cloud第一篇:服务注册与发现Eureka
  3. 她是直播聊学习成“网红”的北大博士,毕业后入职民办学校,年薪70万
  4. 腾讯35亿美元抄底收购搜狗,产品张小龙和技术王小川双剑合璧
  5. 综述:目标检测二十年
  6. 10 号发工资和 20 号发工资的公司,区别竟然这么大?
  7. 清华理工男,跳了7年舞,来华为一年当了PL,这什么小哥哥
  8. CVPR2020 Oral | 港中文-商汤等开源:自监督场景去遮挡
  9. 全网第一SoTA成绩却朴实无华的PyTorch版EfficientDet
  10. 初学Python,我给你总结了常见的17个错误