`

LOG4J的配置范例

阅读更多
常用log4j配置,一般可以采用两种方式,.properties和.xml,下面举两个简单的例子:

一、log4j.properties

### 设置com.unmi域对应的级别INFO,DEBUG,WARN,ERROR和输出地A1,A2 ##
log4j.category.com.unmi=ERROR,A1
log4j.category.com.unmi=INFO,A2

### 一般把上面两行写如下方式,统一控制日志输出,再用log4j.logger设置包独立的输出级别 ##
log4j.rootLogger=DEBUG,A1
log4j.logger.com.unmi.special = ERROR

### 设置输出地A1,为ConsoleAppender(控制台) ##
log4j.appender.A1=org.apache.log4j.ConsoleAppender

### 设置A1的输出布局格式PatterLayout,(可以灵活地指定布局模式)##
log4j.appender.A1.layout=org.apache.log4j.PatternLayout

### 配置日志输出的格式##
log4j.appender.A1.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss,SSS} [%c]-[%p] %m%n

### 设置输出地A2到文件(文件大小到达指定尺寸的时候产生一个新的文件)##
log4j.appender.A2=org.apache.log4j.RollingFileAppender

### 文件位置##
log4j.appender.A2.File=E:/study/log4j/zhuwei.html

### 文件大小##
log4j.appender.A2.MaxFileSize=500KB

log4j.appender.A2.MaxBackupIndex=1

##指定采用html方式输出
log4j.appender.A2.layout=org.apache.log4j.HTMLLayout


二、log4j.xml

<?xml version="1.0" encoding="GB2312" ?>
<!DOCTYPE log4j:configuration SYSTEM "log4j.dtd">

<log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/">

   <appender name="com.unmi.all" class="org.apache.log4j.RollingFileAppender">
  
      <!-- 设置通道ID:com.unmi.all和输出方式:org.apache.log4j.RollingFileAppender -->
      <param name="File" value="E:/study/log4j/all.output.log" /><!-- 设置File参数:日志输出文件名 -->
      <param name="Append" value="false" /><!-- 设置是否在重新启动服务时,在原有日志的基础添加新日志 -->
      <param name="MaxBackupIndex" value="10" />
      <layout class="org.apache.log4j.PatternLayout">
          <param name="ConversionPattern" value="%p (%c:%L)- %m%n" /><!-- 设置输出文件项目和格式 -->
      </layout>
   </appender>
  
   <appender name="com.unmi.zcw" class="org.apache.log4j.RollingFileAppender">
      <param name="File" value="E:/study/log4j/unmi.output.log" />
      <param name="Append" value="true" />
      <param name="MaxFileSize" value="10240" /> <!-- 设置文件大小 -->
      <param name="MaxBackupIndex" value="10" />
      <layout class="org.apache.log4j.PatternLayout">
          <param name="ConversionPattern" value="%p (%c:%L)- %m%n" />
      </layout>
   </appender>
  
   <logger name="unmi.log"> <!-- 设置域名限制,即zcw.log域及以下的日志均输出到下面对应的通道中 -->
      <level value="debug" /><!-- 设置级别 -->
      <appender-ref ref="com.unmi.zcw" /><!-- 与前面的通道id相对应 -->
   </logger>
  
   <root> <!-- 设置接收所有输出的通道 -->
      <appender-ref ref="com.unmi.all" /><!-- 与前面的通道id相对应 -->
   </root>

</log4j:configuration>


三、配置文件加载方法:

对于properties文件,一般都不用手工去加载,由Log4j第一次初始化时自动就加载了

import org.apache.log4j.Logger;
import org.apache.log4j.PropertyConfigurator;
import org.apache.log4j.xml.DOMConfigurator;

public class Log4jApp {
   public static void main(String[] args) {
       DOMConfigurator.configure("E:/study/log4j/log4j.xml");//加载.xml文件
       //PropertyConfigurator.configure("E:/study/log4j/log4j.properties");//加载.properties文件

       Logger log=Logger.getLogger("com.unmi.test");
       log.info("测试");
   }
}

四、项目使用log4j

在web应用中,可以将配置文件的加载放在一个单独的servlet中,并在web.xml中配置该servlet在应用启动时候加载。对于在多人项目中,可以给每一个人设置一个输出通道,这样在每个人在构建Logger时,用自己的域名称,让调试信息输出到自己的log文件中。


五、常用输出格式

# -X号:X信息输出时左对齐;
# %p:日志信息级别
# %d{}:日志信息产生时间
# %c:日志信息所在地(类名)
# %m:产生的日志具体信息
# %n:输出日志信息换行



关于Log4j比较全面的配置
LOG4J的配置之简单使它遍及于越来越多的应用中了:Log4J配置文件实现了输出到控制台、文件、回滚文件、发送日志邮件、输出到数据库日志表、自定义标签等全套功能。择其一二使用就够用了,

log4j.rootLogger=DEBUG,CONSOLE,A1,im
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=[framework] %d - %c -%-4r [%t] %-5p %c %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=file.log
log4j.appender.FILE.Append=false
log4j.appender.FILE.layout=org.apache.log4j.PatternLayout
log4j.appender.FILE.layout.ConversionPattern=[framework] %d - %c -%-4r [%t] %-5p %c %x - %m%n
# Use this layout for LogFactor 5 analysis



# 应用于文件回滚

log4j.appender.ROLLING_FILE=org.apache.log4j.RollingFileAppender
log4j.appender.ROLLING_FILE.Threshold=ERROR
log4j.appender.ROLLING_FILE.File=rolling.log
log4j.appender.ROLLING_FILE.Append=true
log4j.appender.ROLLING_FILE.MaxFileSize=10KB
log4j.appender.ROLLING_FILE.MaxBackupIndex=1
log4j.appender.ROLLING_FILE.layout=org.apache.log4j.PatternLayout
log4j.appender.ROLLING_FILE.layout.ConversionPattern=[framework] %d - %c -%-4r [%t] %-5p %c %x - %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=xxx@www.xxx.com
log4j.appender.MAIL.SMTPHost=www.wusetu.com
log4j.appender.MAIL.Subject=Log4J Message
log4j.appender.MAIL.To=xxx@www.xxx.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


输出到2000NT日志
把Log4j压缩包里的NTEventLogAppender.dll拷到WINNT\SYSTEM32目录下

log4j.logger.NTlog=FATAL, A8
# APPENDER A8
log4j.appender.A8=org.apache.log4j.nt.NTEventLogAppender
log4j.appender.A8.Source=JavaTest
log4j.appender.A8.layout=org.apache.log4j.PatternLayout
log4j.appender.A8.layout.ConversionPattern=%-4r %-5p [%t] %37c %3x - %m%n


#自定义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 = xxx@xxx.net

log4j.appender.im.layout=org.apache.log4j.PatternLayout
log4j.appender.im.layout.ConversionPattern =[framework] %d - %c -%-4r [%t] %-5p %c %x - %m%n

分享到:
评论

相关推荐

    log4j配置范例

    log4j配置范例,完全手写会遇到困难吗,这是个例子供大家参考

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

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

    Log4j使用实例

    配置 Log4j 环境可以通过多种方式进行,常见的有 BasicConfigurator、PropertyConfigurator 和 DOMConfigurator。 - **BasicConfigurator**: 快速配置,默认使用控制台输出。 ```java import org.apache.log4j....

    spring-log4j.xml

    log4j.xml配置范例log4j.xml配置范例log4j.xml配置范例log4j.xml配置范例log4j.xml配置范例

    log4j中文手册(中文版)

    配置范例 - 提供了具体的配置示例,如如何在Tomcat服务器中配置`log4j`等。 #### 8. Nested Diagnostic Contexts (NDCC) - `NDCC`是`log4j`中的一项高级特性,允许开发者在特定上下文中记录日志,这对于调试复杂的...

    Log4J-config.rar_log4j java

    描述"LOG4J的配置范例常用log4j配置,log4j配置手册"表明这个压缩包提供了Log4J的常见配置示例和完整的配置手册,帮助开发者理解和使用Log4J进行日志管理。 **Log4J核心概念** 1. **日志级别**:Log4J支持多个日志...

    Log4j手册

    配置范例与优化 配置文件可以非常复杂,涵盖多个Logger、Appender和Layout的组合。例如,在Tomcat环境下,可能需要配置专门的日志输出,以满足特定的需求。 **优化**是Log4j使用过程中的一个重要方面。当日志级别...

    log4j手册

    - **参考文档**:了解更多的log4j配置细节和技术文档,请参考官方文档或其他技术文章。 - **全面配置文件**:为了更好地理解和使用log4j,建议阅读完整的配置文件示例,这有助于深入理解log4j的工作原理和配置选项。...

    Log4j中文手册

    - **比较全面的配置文件**:给出了一个完整的Log4j配置文件示例,方便开发者参考。 - **日志乱码的解决**:解释了如何解决日志输出时可能出现的乱码问题。 综上所述,Log4j为Java应用程序提供了高度可定制的日志...

    log4cxx-win32src

    使用这个范例工程,开发者可以学习如何在Windows XP上配置Log4cxx,包括设置日志级别(DEBUG、INFO、WARN、ERROR等)、定义日志输出目的地(如文件、控制台、网络等)、创建自定义布局格式以及实现日志滚动策略。...

    Java项目设计与开发范例

    13. **日志记录**:通过Log4j或SLF4J等日志框架记录程序运行状态,便于问题排查和性能分析。 14. **持续集成/持续部署(CI/CD)**:使用Jenkins、Git等工具实现自动化构建和部署,加速开发流程。 15. **项目管理**:...

    springboot配置druid连接池的方法示例

    4. SQL 执行日志,Druid 提供了不同的 LogFilter,能够支持 Common-Logging、Log4j 和 JdkLog。 5. 扩展 JDBC,如果你要对 JDBC 层有编程的需求,可以通过 Druid 提供的 Filter 机制,很方便编写 JDBC 层的扩展插件...

    java吐血精华大奉送,你要的都能找到(最新版本)

    技术人员也过个年吧,java_吐血奉献_超值大礼包(最新版本)_含struts,hibernate,spring,log4j,web.xml配置详解,java分页大全,cvs教程,tomcat,swing教程,jboss,及各种框架的配置文件范例

    java吐血精华大奉送,你要的都能找到

    java_吐血奉献_超值大礼包_含struts,hibernate,spring,log4j,web.xml配置详解,java分页大全,cvs教程,tomcat,swing教程,及各种框架的配置文件范例

    loglady:Scala的疯狂简单日志记录

    主要特点薄型SLF4J包装纸简单的API 没有配置支持Scala 2.9.1、2.9.2和2.10.0使用范例 import org . eintr . loglady . Loggingclass MyClass extends Logging { log.info( " Hello, Log Lady " ) log.warn( " We all...

    springboot-demo.zip

    SpringBoot默认使用Logback或Log4j2进行日志管理,并提供健康检查接口,可以查看应用的运行状态。 9. **Thymeleaf模板引擎** 如果项目涉及视图渲染,可能会使用到Thymeleaf,它是一个HTML模板引擎,与SpringBoot...

    Spring mvc+hibernate+freemarker(开源项目)

    4. **配置文件设置**:在web.xml中配置Spring, log4j, struts, hibernate等。 5. **国际化支持**:资源文件配置,支持多语言。 6. **视图配置**:定义视图路径和登录地址。 7. **单元测试**:使用JUnit 4进行业务层...

    基于Springboot的车辆违章信息管理系统(有报告) Javaee项目,springboot项目

    - 日志管理:Log4j或Logback,记录系统运行日志。 为了便于开发者快速理解和使用,项目可能包含详细的开发文档、使用教程,以及预设的示例数据和测试用例。通过这些资料,开发者可以迅速上手,了解系统的架构设计和...

    Java语言编码规范

    - **log4j.properties**:日志框架Log4j的配置文件。 - **hibernate.cfg.xml**:Hibernate持久化框架的配置文件。 - **ApplicationResources.properties**:存储多语言资源的属性文件。 - **struts-config-*.xml**:...

    基于SSM的品牌银饰售卖平台(有报告) Javaee项目 ssm项目

    8. **日志记录**:通过Log4j或Logback记录系统运行日志,便于问题排查和性能优化。 9. **异常处理**:全局异常处理机制,确保系统在遇到错误时能优雅地处理,提供友好的用户体验。 通过阅读和分析提供的资源,学习...

Global site tag (gtag.js) - Google Analytics