apache log4j实现日志插入mysql数据库

本文介绍如何将Log4j日志记录到MySQL数据库中,包括创建数据库表、配置log4j.properties文件及实现代码等内容。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

最近做项目时,出现了一个bug,环境为was,出现一次请求,返回多次处理结果,最终查询原因为was配置的超时转发(server1超时自动转发server2,3,4..)引起的.

为了快速定位问题的根源,所以希望能把log4j的输入写入到数据库中,因此才有了本此的文章。

1.创建mysql数据库log4j,数据表ibs_log

01--建库
02CREATE DATABASE `log4j`;
03--建表
04CREATE TABLE `ibs_log` (                                                             
05           `log_id` int(10) NOT NULL AUTO_INCREMENT,                                          
06           `log_date` datetime NOT NULL COMMENT '日期',                                     
07           `log_file` varchar(255) DEFAULT NULL COMMENT '文件名',                          
08           `log_line` varchar(255) DEFAULT NULL COMMENT '行号',                             
09           `log_thread` varchar(255) DEFAULT NULL COMMENT '线程',                           
10           `log_level` varchar(255) DEFAULT NULL COMMENT 'Log级别 info warndebug error等'
11           `log_message` varchar(2048) DEFAULT NULL COMMENT 'Log信息',                      
12           PRIMARY KEY (`log_id`,`log_date`),                                                 
13           KEY `INDEX_LOG_DATE` (`log_date`) USING BTREE                                      
14         ) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=utf8

2.新建一个java project工程。

  • 引入jar包

      apache log4j实现日志插入mysql数据库

  • 配置log4j.properties
01log4j.rootLogger=INFO,appender1,appender2,appender3
02log4j.logger.org.springframework=ERROR
03log4j.appender.appender1=org.apache.log4j.ConsoleAppender
04log4j.appender.appender1.layout=org.apache.log4j.PatternLayout
05log4j.appender.appender1.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss:SSS}[%p]: %m%n
06log4j.appender.appender2=org.apache.log4j.FileAppender
07log4j.appender.appender2.File=log/IceColdMonitor.log
08log4j.appender.appender2.layout=org.apache.log4j.PatternLayout
09log4j.appender.appender2.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss:SSS}[%p]: %m%n
10#database
11log4j.appender.appender3=org.apache.log4j.jdbc.JDBCAppender
12log4j.appender.appender3.driver=com.mysql.jdbc.Driver
13log4j.appender.appender3.URL=jdbc:mysql://127.0.0.1:3306/log4j
14log4j.appender.appender3.user=root
15log4j.appender.appender3.password=root
16log4j.appender.appender3.sql=INSERT INTO ibs_log (log_date,log_file,log_line,log_thread,log_level,log_message) VALUES ('%d{yyyy-MM-dd hh:mm:ss}','%c','%l','%t','%p','%m')
  • 编写测试类
    01package com.log4j.test;
    02import org.apache.log4j.Logger;
    03 
    04/**
    05 * @author kisn
    06 *
    07 */
    08public class Test {
    09    public static void main(String[] args) {
    10        Logger logger = Logger.getLogger(Test.class);
    11        logger.info("test logger info");
    12        logger.debug("test logger debug");
    13        logger.error("test logger error");
    14        logger.fatal("test logger fatal");
    15    }
    16}

     

项目截图:

  apache log4j实现日志插入mysql数据库

运行截图:

  apache log4j实现日志插入mysql数据库apache log4j实现日志插入mysql数据库

转载于:https://my.oschina.net/glenxu/blog/725558

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值