`

log4j.properties 全部应用

阅读更多

log4j.rootLogger=DEBUG,CONSOLE,database,FILE,mail, //这里可以命名无数个别名,用于下面的操作。
log4j.addivity.org.apache=true

# 应用于控制台
log4j.appender.CONSOLE=org.apache.log4j.ConsoleAppender
log4j.appender.CONSOLE.Threshold=INFO
log4j.appender.CONSOLE.Target=System.out
log4j.appender.CONSOLE.Encoding=GBK
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.database=org.apache.log4j.jdbc.JDBCAppender
log4j.appender.database.URL=jdbc:mysql://127.0.0.1:3306/log4j #特别注意这里URL
#不要写成小写的url不然就报错了哈
#还要注意的是log4后面不要
#打个空格不然就会报错说次数据库
#名称错误 所以各方面都要小心对待啦
log4j.appender.database.driver=com.mysql.jdbc.Driver
log4j.appender.database.user=root
log4j.appender.database.password=root
log4j.appender.database.Threshold=error
log4j.appender.database.sql=insert into tb_log(date,priority,message,classname)values('%d','%p','%m','%n')
# INSERT INTO LOG4J (Message) VALUES ('[framework] %d - %c -%-4r [%t] %-5p %c %x - %m%n')
# 写入数据库中的表LOG4J的Message字段中,内容%d(日期)%c: 日志信息所在地(类名)%p: 日志信息级别%m: 产生的日志具体信息 %n: 输出日志信息换行
log4j.appender.database.layout=org.apache.log4j.PatternLayout
log4j.appender.database.layout.ConversionPattern=%m

##这里要创建数据库log4j 创建表tb_log 创建字段id date priority message classname (id设置自增) 导入mysql驱动jar包即可
#小提示: 由于JDBC 输出可能会因为短时间内大量连接数据库而导致连接失败,因此要谨慎使用JDBC输出。


# 每天新建日志
log4j.appender.A1=org.apache.log4j.DailyRollingFileAppender
log4j.appender.A1.File=C:/log4jDalliyFile.log
log4j.appender.A1.Encoding=GBK
log4j.appender.A1.Threshold=DEBUG
log4j.appender.A1.DatePattern='.'yyyy-MM-dd
log4j.appender.A1.layout=org.apache.log4j.PatternLayout
log4j.appender.A1.layout.ConversionPattern=%d{ABSOLUTE} %5p %c{1}:%L : %m%n

#应用于文件
log4j.appender.FILE=org.apache.log4j.FileAppender
log4j.appender.FILE.File=C:/log4jfile.log
log4j.appender.FILE.Append=false
log4j.appender.FILE.Encoding=GBK
log4j.appender.FILE.layout=org.apache.log4j.PatternLayout
log4j.appender.FILE.layout.ConversionPattern=[framework] %d - %c -%-4r [%t] %-5p %c %x - %m%n

# 应用于文件回滚
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.CONSOLE_FILE.Encoding=GBK
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.net.SocketAppender
#远程机器
log4j.appender.socket.RemoteHost=localhost
#超时时间
log4j.appender.socket.ReconnectionDelay=30000
#端口
log4j.appender.socket.Port=2008
#本地信息
log4j.appender.socket.LocationInfo=true
log4j.appender.socket.layout=org.apache.log4j.PatternLayout
log4j.appender.socket.layout.ConversionPattern=%-d{yyyy-MM-dd HH:mm:ss,SSS}[%C]-[%p] %m%n
这里你需要编写一个测试类
package com.dk.socket;
import org.apache.log4j.net.SimpleSocketServer;
public class SocketTest {
/**
* @param args
*/
public static void main(String[] args) {
String port = "2008";
String file = "c:/socket.log";

SimpleSocketServer.main(new String[]{port,file});
}
}

##
## 应用于输出到SMTP邮件
##

#log4j.appender.mail=org.apache.log4j.net.SMTPAppender
#设置info以上才使用
#log4j.appender.mail.Threshold=info
#缓存文件大小 日志达到100K时候发送E-mail
#log4j.appender.mail.BufferSize=100
#发送邮件服务器
#log4j.appender.mail.SMTPHost=smtp.163.com
#log4j.appender.mail.Subject=Log4J Message
#log4j.appender.mail.SMTPUsername=dengkui01@163.com
#log4j.appneder.mail.SMTPPassword=467529125
#log4j.appender.mail.From=dengkui01@163.com
#log4j.appender.mail.To=467529125@qq.com
#log4j.appender.mail.layout=org.apache.log4j.PatternLayout
#log4j.appender.mail.layout.ConversionPattern=%-d{yyyy-MM-dd HH:mm:ss,SSS}[%C]-[%p] %m%n
#如果在短时间内发送大量的邮件,
#会被网易,GMail等大多数的邮件服务器封掉IP,
#导致发送邮件失败。因此,要谨慎使用SMTPAppender
###
###自定义Log4j
###

 

log4j.appender.counting=com.dk.selfdefined.Self_DefinedLog4j #自定义类路径

log4j.appender.counting.limit=10

log4j.appender.counting.layout=org.apache.log4j.PatternLayout

log4j.appender.counting.layout.ConversionPattern=%-d{yyyy-MM-dd HH:mm:ss,SSS}[%C]-[%p] %m%n

 

这是自定义类

package com.dk.selfdefined;

import org.apache.log4j.AppenderSkeleton;
import org.apache.log4j.spi.ErrorCode;
import org.apache.log4j.spi.LoggingEvent;

public class Self_DefinedLog4j extends AppenderSkeleton{

int counter = 0;//记录日志次数
int limit = 6;//极限次数


public int getLimint() {
return limit;
}

public void setLimint(int limint) {
this.limit = limint;
}


@Override
protected void append(LoggingEvent event) {
if(this.layout==null){
//没有设置布局输出
errorHandler.error("没有设置["+name+"]输出布局.",null,ErrorCode.MISSING_LAYOUT);
System.out.println("已经进入append return函数");
System.out.println(counter);
return;
}
if(counter >= limit){
errorHandler.error("输出次数["+limit+"]达到了["+this.getName()+"]的极限",null,ErrorCode.WRITE_FAILURE);
return ;
}
System.out.println(this.layout.format(event));
if(layout.ignoresThrowable()){
String[] t = event.getThrowableStrRep();
if(t != null){
int len = t.length;
for(int i = 0;i < len;i++){
System.out.println(t[i]);
}
}
}
counter++;//记录下次日志

}

public void close() {

if(this.closed){
return;
}
this.closed=true;
}

public boolean requiresLayout() {//需要使用布局
return false;
}

}

 

 

附件:

把我写的测试压缩之后,供大家一起参考。

  • 大小: 89.9 KB
分享到:
评论

相关推荐

    log4j.properties(完整版) log4j.properties(精简版)

    Log4j是Apache组织开发的一个强大的、灵活的日志记录框架,被广泛应用于各种Java应用中。本文将围绕Log4j的核心配置文件`log4j.properties`进行详细讲解,分为完整版和精简版两个部分。 **1. Log4j基础概念** Log4...

    log4j.jar包,和log4j.properties配置文件下载

    在实际应用中,将`log4j.jar`添加到项目的类路径中,并根据项目需求定制`log4j.properties`,即可实现有效的日志管理。这不仅有助于问题排查,也有利于系统维护和性能优化,因为过多的日志可能会占用大量磁盘空间,...

    log4j.properties配置文件

    正确配置`log4j.properties`对于应用程序的日志管理和调试至关重要。 #### 二、日志级别 Log4j支持以下几种级别的日志输出:OFF、FATAL、ERROR、WARN、INFO、DEBUG、ALL。这些级别按照从高到低的顺序排列,其中OFF...

    log4j.properties 的使用详解(含log4j.properties)

    《log4j.properties 使用详解》 在Java开发中,日志记录是一项不可或缺的工作,它能够帮助开发者追踪程序运行状态,定位错误,优化性能。而log4j作为一款强大的日志框架,广泛应用于各种Java项目中。本文将详细介绍...

    log4j.properties配置详解

    ### Log4j.properties配置详解 #### 一、Log4j配置文件基本概念 Log4j是一种广泛应用于Java应用程序的日志框架,它可以帮助开发者轻松管理应用程序的日志记录过程。Log4j支持多种配置方式,其中.properties文件...

    log4j与log4j.properties的配置.doc

    1. 在应用程序中使用 Log4j,需要将 Log4j 库文件(log4j-*.jar)添加到 CLASSPATH 变量中。 2. 新建一个配置文件 log4j.properties,放于 bin 文件下。 二、log4j.properties 配置文件 log4j.properties 配置文件...

    log4j使用jar包和log4j.properties配置文件

    Log4j作为Java日志处理的重要工具,通过其灵活的配置和强大的功能,可以帮助开发者更好地理解和管理应用的运行状态。1.2.17版本的Log4j jar包和`log4j.properties`配置文件是实现这一目标的基础。正确地引入和配置这...

    log4j.properties的简单运用

    《log4j.properties的简单运用》 在Java开发中,日志记录是一项至关重要的任务,它可以帮助开发者追踪程序运行过程中的错误、调试信息以及其他关键事件。Log4j是一款广泛使用的日志框架,它允许我们自定义日志级别...

    MANIFEST.MF的应用以及如何读取jar包外的log4j.properties

    Log4j是一个强大的日志处理库,它允许开发者通过配置文件(如log4j.properties或log4j.xml)来定制日志记录级别、输出格式和目的地。通常,开发者不希望将日志配置文件打包到JAR中,因为这样可以方便地在生产环境中...

    Log4j+使用方法+配置文件log4j.properties

    Log4j是Apache组织开发的一款强大的Java日志记录框架,被广泛应用于各种Java项目中,以提供灵活的日志输出和管理。它允许开发者控制日志信息的输出级别、格式以及输出位置,帮助调试和监控系统运行状态。Log4j的核心...

    log4j.properties详解与例子

    Log4j是一个广泛使用的日志记录框架,尤其在Java应用程序中。它允许开发者灵活地配置日志输出,以便根据需要捕获和管理不同级别的信息。本文将深入解析`log4j.properties`配置文件,以及如何配置Logger、Appender和...

    log4j配置实例(含配log4j.properties及jar包)

    本教程将深入探讨如何配置和使用Log4j,包括`log4j.properties`配置文件的编写以及相应的Java代码示例。 1. **Log4j的核心组件** - **Logger**: 日志记录器,用于生成日志事件。 - **Appender**: 输出目标,负责...

    Log4j.properties配置详解

    Log4j 是一个广泛使用的...正确配置Log4j.properties文件能够帮助开发者更好地管理和监控应用程序的运行状态,通过调整日志级别和输出方式,可以在开发、测试和生产环境中获得合适的日志信息,从而提升问题排查效率。

    Log - Log4j - log4j.properties配置文件

    在实际应用中,`log4j.properties`的配置应根据项目需求进行调整,比如根据日志级别过滤不必要的信息,根据业务模块划分日志文件,或者添加日志监控系统等。记住,良好的日志管理能够极大地提升开发效率和系统稳定性...

    log4j的详细配置,log4j.xml和log4j.properties,日志输出到文件,邮件,数据库,控制台等

    Log4j提供了多种配置方式,其中最常用的有两种:XML格式的`log4j.xml`和properties格式的`log4j.properties`。接下来,我们将深入探讨如何通过这两种配置文件来设置日志输出的目标、级别以及格式。 1. **XML配置** ...

    log4j.properties配置实例

    在 Java 应用程序中, Log4j 是一个非常流行的日志记录工具,它能够帮助开发者快速地记录和跟踪应用程序中的日志信息。log4j.properties 文件是 Log4j 的核心配置文件,它控制着 Log4j 的行为和日志记录的方式。 在...

    [SSH+Maven+Bootstrap视频教程]_17. 添加 log4j.properties 配置文件.zip

    在本节视频教程中,我们将深入探讨如何在Java项目中集成SSH(Struts、Spring、Hibernate)框架,并结合Maven构建工具以及Bootstrap前端框架,来添加和配置`log4j.properties`日志文件。这个过程对于任何Java开发人员...

    Log4j.properties详细说明

    Log4j.properties 配置详解 Log4j.properties 文件是 Log4j 框架的核心配置文件,用于设置记录器的级别、存放器和布局。通过配置,可以创建出 Log4J 的运行环境。下面是 Log4j.properties 文件的详细配置解释。 ...

Global site tag (gtag.js) - Google Analytics