`

Log4j 将日志保存到数据库

阅读更多

log4j.rootLogger=INFO,DATABASE

 

# ************************************************* #
# log put into database
# ************************************************* #
log4j.appender.DATABASE=org.apache.log4j.jdbc.JDBCAppender
log4j.appender.DATABASE.URL=jdbc:mysql://localhost:3306/lsoba
log4j.appender.DATABASE.driver=com.mysql.jdbc.Driver
log4j.appender.DATABASE.user=root
log4j.appender.DATABASE.password=lijian
log4j.appender.DATABASE.sql=INSERT INTO loginfo (date,thread,level,logclass,message,user) values ('%d{yyyy-MM-dd HH:mm:ss}', '%t', '%p', '%l', '%m','%X{user}')
log4j.appender.DATABASE.layout=org.apache.log4j.PatternLayout

 

 

 

但是要按找自己所想的随心所遇的记录,那还是要费一番功夫的。

^_^,经过我一下午的折腾。终于彻底玩转log4j

首先准备log4j.properties文件,内容如下,至于每句话都代表什么意思,我就不多解释了。GOOGLE一下,满山遍野的都是

结果:

1.日志路径记录到当前应用的WEB-INF/logs目录下,分10个大小为1M的文件记录JFrame.log,JFrame.log.0...

2.控制台的日志,可以直接点击导航到源码位置!

log4j.rootLogger=DEBUG, CONSOLE,ROLLING_FILE
log4j.addivity.org.apache=true
# 应用于控制台
log4j.appender.CONSOLE=org.apache.log4j.ConsoleAppender
log4j.appender.Threshold=DEBUG
log4j.appender.CONSOLE.Target=System.out
log4j.appender.CONSOLE.layout=org.apache.log4j.PatternLayout
log4j.appender.CONSOLE.layout.ConversionPattern=------------------ %d{yyyy-MM-dd HH:mm:ss} ------------------%nlevel: %p%nrooter: %C.%M(%c{1}.java:%L) %nmessage: %m%n
#log4j.appender.CONSOLE.layout.ConversionPattern=[JFrame] %d at %c.%M(%L)   %-5p  %x - %m%n
#log4j.appender.CONSOLE.layout.ConversionPattern=[start]%d{DATE}[DATE]%n%p[PRIORITY]%n%x[NDC]%n%t[THREAD] n%c[CATEGORY]%n%m[MESSAGE]%n%n

#应用于文件
#log4j.appender.FILE=org.apache.log4j.FileAppender
#log4j.appender.FILE.File=${webapp.root}/WEB-INF/logs/JFrame.log
#log4j.appender.FILE.Append=false
#log4j.appender.FILE.layout=org.apache.log4j.PatternLayout
#log4j.appender.FILE.layout.ConversionPattern=------------------ %d{yyyy-MM-dd HH:mm:ss} ------------------%nlevel: %p%nrooter: %C.%M(%c{1}.java:%L) %nmessage: %m%n
# Use this layout for LogFactor 5 analysis

# 应用于文件回滚
log4j.appender.ROLLING_FILE=org.apache.log4j.RollingFileAppender
log4j.appender.ROLLING_FILE.Threshold=DEBUG
#webapp.root变量为spring设定的,指向当前应用的根目录,绝对路径
log4j.appender.ROLLING_FILE.File=${webapp.root}/WEB-INF/logs/JFrame.log
log4j.appender.ROLLING_FILE.Append=true
#log4j.appender.ROLLING_FILE.Encoding=GBK
log4j.appender.ROLLING_FILE.MaxFileSize=1MB
log4j.appender.ROLLING_FILE.MaxBackupIndex=10
log4j.appender.ROLLING_FILE.layout=org.apache.log4j.PatternLayout
log4j.appender.ROLLING_FILE.layout.ConversionPattern=------------------ %d{yyyy-MM-dd HH:mm:ss} ------------------%nlevel: %p%nrooter: %C.%M(%c{1}.java:%L) %nmessage: %m%n
#应用于循环文件
#log4j.appender.R=org.apache.log4j.RollingFileAppender
#log4j.appender.R.File=${webapp.root}/WEB-INF/logs/JFrame.log
#log4j.appender.R.MaxFileSize=100KB
#log4j.appender.R.MaxBackupIndex=10
#log4j.appender.R.layout=org.apache.log4j.PatternLayout
#log4j.appender.R.layout.ConversionPattern=------------------ %d{yyyy-MM-dd HH:mm:ss} ------------------%nlevel: %p%nrooter: %C.%M(%c{1}.java:%L) %nmessage: %m%n

#应用于socket
#log4j.appender.SOCKET=org.apache.log4j.RollingFileAppender
#log4j.appender.SOCKET.RemoteHost=localhost
#log4j.appender.SOCKET.Port=5001
#log4j.appender.SOCKET.LocationInfo=true
# Set up for Log Facter 5
#log4j.appender.SOCKET.layout=org.apache.log4j.PatternLayout
#log4j.appender.SOCET.layout.ConversionPattern=[start]%d{DATE}[DATE]%n%p[PRIORITY]%n%x[NDC]%n%t[THREAD]%n%c[CATEGORY]%n%m[MESSAGE]%n%n
# Log Factor 5 Appender
#log4j.appender.LF5_APPENDER=org.apache.log4j.lf5.LF5Appender
#log4j.appender.LF5_APPENDER.MaxNumberOfRecords=2000

# 发送日志给邮件
#log4j.appender.MAIL=org.apache.log4j.net.SMTPAppender
#log4j.appender.MAIL.Threshold=FATAL
#log4j.appender.MAIL.BufferSize=10
#log4j.appender.MAIL.From=service@vondef.com
#log4j.appender.MAIL.SMTPHost=www.vondef.com
#log4j.appender.MAIL.Subject=Log4J Message
#log4j.appender.MAIL.To=service@vondef.com
#log4j.appender.MAIL.layout=org.apache.log4j.PatternLayout
#log4j.appender.MAIL.layout.ConversionPattern=[framework] %d - %c -%-4r [%t] %-5p %c %x - %m%n
# 用于数据库
#log4j.appender.DATABASE=org.apache.log4j.jdbc.JDBCAppender
#log4j.appender.DATABASE.URL=jdbc:mysql://localhost:3306/test
#log4j.appender.DATABASE.driver=com.mysql.jdbc.Driver
#log4j.appender.DATABASE.user=root
#log4j.appender.DATABASE.password=
#log4j.appender.DATABASE.sql=INSERT INTO LOG4J (Message) VALUES ('[framework] %d - %c -%-4r [%t] %-5p %c %x - %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
#log4j.appender.A1=org.apache.log4j.DailyRollingFileAppender 
#log4j.appender.A1.File=SampleMessages.log4j 
#log4j.appender.A1.DatePattern=yyyyMMdd-HH'.log4j' 
#log4j.appender.A1.layout=org.apache.log4j.xml.XMLLayout
##自定义Appender
#log4j.appender.im = net.cybercorlin.util.logger.appender.IMAppender
#log4j.appender.im.host = mail.cybercorlin.net 
#log4j.appender.im.username = username 
#log4j.appender.im.password = password
#log4j.appender.im.recipient = service@vondef.com  
#log4j.appender.im.layout=org.apache.log4j.PatternLayout 
##log4j.appender.im.layout.ConversionPattern =[framework] %d - %c -%-4r [%t] %-5p %c %x - %m%n

 

然后,在你的web.xml中配置如下东东

 <!--由Sprng载入的Log4j配置文件位置-->
 <context-param>
  <param-name>log4jConfigLocation</param-name>

  <param-value>classpath:log4j.properties</param-value>
 </context-param>
 <!--Spring log4j Config listener-->
 <listener>
  <listener-class>org.springframework.web.util.Log4jConfigListener</listener-class>
 </listener>

<!-- 必须放在classpath下,不然启动的时候会有一两个警告信息,看着很不爽,不过也不影响后面的使用 -->

如果没有采用spring,可以自己编写一个listerner获取context-param参数,

然后将参数set到System中去。

这样在log4j.properties中就可以${xxx}方式引用该变量了。

分享到:
评论

相关推荐

    log4j2.xml记录日志到到数据库

    总结,Log4j2通过XML配置文件实现了与MySQL数据库的集成,允许开发者将日志信息存储在数据库中,便于长期保存和分析。理解Log4j2的配置和使用是每个Java开发者必备的技能,这对于日后的故障排查和系统维护至关重要。...

    log4j按功能保存日志

    在“log4j按功能保存日志”的场景中,我们通常会利用Log4j的配置灵活性,将不同功能的日志分别写入不同的文件,以便于后期分析、排查问题和监控系统状态。 1. **Log4j基本概念** - **Logger**: 日志记录器,是Log4...

    Log4j生成日志保存

    3. **Appender**: 输出端,负责将日志信息输出到指定的地方,比如控制台、文件、网络、数据库等。 4. **Layout**: 格式化器,定义了日志信息的输出格式,如时间戳、线程名、级别、日志消息等。 二、Log4j在Android...

    log4j写入数据库配置

    总结来说,Log4j写入数据库的配置涉及到创建适应的数据库表结构、配置`log4j.properties`文件以指定数据库连接信息和日志格式,并通过`JDBCAppender`将日志数据持久化到数据库中。这样的配置有助于收集和分析大量...

    log4j 配置mysql 数据库 demo

    本篇将详细介绍如何配置Log4j来将日志信息存储到MySQL数据库中,以实现日志的集中管理和分析。 首先,我们需要了解Log4j的基本结构。Log4j主要由三个组件构成:Logger(日志器)、Appender(输出端)和Layout(布局...

    log4j将记录日志保存到数据库

     系统必须是使用LOG4J进行日志管理,否则方法无效。 系统必须包含commons-logging-xxx.jar,log4j-xxx.jar这两个JAR包,XXX为版本号。  二、操作步骤  1、创建日志表 要把日志持久化,必须在数据库中创建一张...

    日志配置文件log4j.xml以及MySql数据库驱动文件

    本篇文章将深入探讨这两个关键组件:日志配置文件`log4j.xml`和MySQL数据库驱动文件`mysql-connector-java-5.1.39-bin.jar`。 首先,我们来了解`log4j.xml`。Log4j是Apache组织提供的一款开源的日志记录框架,广泛...

    log4j.properties完整版本

    log4j.properties log4j log4j日志保存到邮件 log4j保存到数据库

    log4j 写多个日志文件,按照日期每天都记

    本文将深入探讨如何利用`log4j`实现按照日期每天写入不同日志文件的功能,以及涉及到的相关知识点。 首先,我们要理解`log4j.properties`配置文件的作用。它是`log4j`的配置中心,通过这个文件我们可以定制日志输出...

    log4j按照不同appender生成日志例子

    在Log4j中,Appender是负责将日志信息输出到特定目的地的组件,如控制台、文件、网络、数据库等。通过配置多个Appender,我们可以让日志信息分散存储,便于管理和分析。 要实现按接口生成各自日志文件的目标,我们...

    简单java操作log4j+Mysql存储日志信息

    总结起来,通过使用Log4j与MySQL的集成,我们可以实现对日志的详细控制,并将这些日志安全地保存在数据库中,便于后期分析和排查问题。SLF4J提供了一层抽象,使得我们可以轻松地切换不同的日志实现,而自定义的...

    log4j.zip 项目日志

    本文将围绕“log4j.zip”项目日志,详细介绍Log4j的基本概念、配置、使用方法以及优化策略。 一、Log4j简介 Log4j是由Apache软件基金会开发的一款开源日志组件,适用于Java平台。它的设计理念是提供一个灵活且高效...

    log4j简单范例 日志文件是相对路径的

    这个“log4j简单范例 日志文件是相对路径的”示例将展示如何配置Log4j来记录日志,并将日志文件保存在程序运行时的相对路径下。 首先,Log4j的核心组件包括Logger(日志器)、Appender(输出目的地)和Layout(格式...

    一种基于Log4J的日志输出组件的设计

    ### 基于Log4J的日志输出组件设计的关键知识点 #### 1. 引言:日志管理的重要性 在软件开发与系统运行过程中,日志管理占据着至关重要的地位。据统计,在一个软件系统中,日志输出相关的代码量约占总代码量的4%...

    log4j2 jdbc appender 实现将日志保存到 mysql。

    总的来说,Log4j2的JDBC Appender提供了一种高效且灵活的方式来将日志数据持久化到MySQL数据库中,这对于日志分析、故障排查和性能监控都极其有用。通过适当的配置和优化,你可以确保日志数据的安全存储,并且方便...

    log4j 数据库,邮件,html 等配置

    Log4j允许我们直接将日志信息存储到数据库中,这对于需要长期保存和分析大量日志数据的系统来说尤其有用。首先,你需要配置一个Appender(输出端),例如使用JDBCAppender。在配置文件中,定义数据库连接参数,包括...

    log4j2用户指南

    Appender 是 Log4j2 中的核心组件之一,负责将日志事件输出到不同的目的地: - **Console Appender**:输出到控制台。 - **File Appender**:将日志记录写入文件。 - **DB Appender**:记录到数据库。 - **SMTP ...

    深入学习log4J

    Log4J支持将日志信息存储在数据库中,这对于需要长期保存和分析日志数据的情况非常有用。通过配置Appender为JDBCAppender,开发者可以将日志信息写入关系型数据库,如MySQL、Oracle等。这样,日志数据可以进行SQL...

    SpringBoot Logback日志记录到数据库的实现方法

    在本文中,我们将详细介绍SpringBoot Logback日志记录到数据库的实现方法。Logback是一个流行的日志记录框架,能够帮助开发者轻松地记录和管理应用程序中的日志信息。下面,我们将通过示例代码,介绍如何将Logback...

    log4j教程

    2. **日志目的地配置**:Log4j支持将日志信息输出到多种目的地,包括控制台、文件、数据库等,甚至可以通过网络发送日志。这意味着开发者可以根据实际需求选择最合适的日志存储方式,比如在生产环境中可能更倾向于将...

Global site tag (gtag.js) - Google Analytics