log4j.properties 全部应用

本文详细介绍了Log4j的各种配置方法,包括控制台输出、文件输出、数据库输出、日志回滚、邮件通知及自定义输出等。通过具体的配置实例,帮助读者了解如何灵活运用Log4j进行日志管理。

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


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;
}

}

 

 

附件:

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值