java日志操作

本文介绍了Log4j的基本概念,包括其核心组件Logger、Appender和Layout的功能,以及如何通过log4j.properties文件配置不同输出级别和目标。此外,还提供了在Java项目中加载和使用Log4j的具体步骤。

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

一、Log4j的概念

Log4j中有三个主要的组件,它们分别是 Logger、Appender和Layout,Log4j 允许开发人员定义多个Logger,每个Logger拥有自己的名字,Logger之间通过名字来表明隶属关系。有一个Logger称为Root,它永远存在,且不能通过名字检索或引用,可以通过Logger.getRootLogger()方法获得,其它Logger通过 Logger.getLogger(String name)方法。

 1) Appender则是用来指明将所有的log信息存放到什么地方,Log4j中支持多种appender,如 console、files、GUI components、NT Event Loggers等,一个Logger可以拥有多个Appender,也就是你既可以将Log信息输出到屏幕,同时存储到一个文件中。

输出到控制台:org.apache.log4j.ConsoleAppender

输出到文件:org.apache.log4j.FileAppender

2) Layout的作用是控制Log信息的输出方式,也就是格式化输出的信息。

3) Log4j中将要输出的Log信息定义了5种级别,从低到高依次为DEBUG、INFO、WARN、ERROR和FATAL,当输出时,只有级别高过配置中规定的级别的信息才能真正的输出,这样就很方便的来配置不同情况下要输出的内容,而不需要更改代码,这点实在是方便啊。

二、log4j.properties

# level : 是日志记录的优先级,分为OFF、FATAL、ERROR、WARN、INFO、DEBUG、ALL或者您定义的级别。Log4j建议只使用四个级别,优先级从高到低分别是ERROR、WARN、INFO、DEBUG。
log4j.rootLogger=DEBUG,CONSOLE,File
log4j.addivity.org.apache=true


# 应用于控制台
log4j.appender.CONSOLE=org.apache.log4j.ConsoleAppender
# 本处设置为"INFO"以上级别在控制台输出(默认情况使用rootLogger中的设置)
log4j.appender.CONSOLE.Threshold=INFO
log4j.appender.CONSOLE.Target=System.out
log4j.appender.CONSOLE.Encoding=UTF-8
log4j.appender.CONSOLE.layout=org.apache.log4j.PatternLayout
log4j.appender.CONSOLE.layout.ConversionPattern=[%t] %m%n


# 每天新建日志
log4j.appender.File=org.apache.log4j.FileAppender
log4j.appender.File.File=./my.log
log4j.appender.File.Encoding=utf-8
log4j.appender.File.Threshold=DEBUG
log4j.appender.File.layout=org.apache.log4j.PatternLayout
log4j.appender.File.layout.ConversionPattern=[%-5p] [%t] %d{yyyy-MM-dd HH:mm:ss:SSS} - %c %l %x - %m%n


#邮件提醒Error
log4j.appender.MAIL=org.apache.log4j.net.SMTPAppender
#日志的错误级别  
log4j.appender.MAIL.Threshold=ERROR 
#缓存文件大小,日志达到2时发送Email  
#log4j.appender.MAIL.BufferSize=2  
#发送邮件的服务器  
log4j.appender.MAIL.SMTPHost=smtp.126.com
#邮件主题  
log4j.appender.MAIL.Subject=ZhihuSpiderErrorMessage
#发送邮件箱的用户  
log4j.appender.MAIL.SMTPUsername=
#发送邮件箱的密码  
log4j.appender.MAIL.SMTPPassword=
#发送邮件箱  
log4j.appender.MAIL.From=
#接受邮件箱  
log4j.appender.MAIL.To=
#发送邮件的格式  
log4j.appender.MAIL.layout=org.apache.log4j.HTMLLayout
三、加载配置

web.xml

<context-param>
		<param-name>log4jConfigLocation</param-name>
		<param-value>classpath:log4j.properties</param-value>
	</context-param>
注意:如果是javaproject文件,其实这个是不用写的,log4j架包会自动找到这个文件并加载的

四、使用

package com.lei.test;


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


public class Log4jTest {
	static Logger logger = null;
	static {
		PropertyConfigurator.configure("log4j.properties");
		logger = Logger.getLogger(Log4jTest.class);	
	}
	public static void main(String[] args) {
		logger.info("测试一下");
	}
}

看一下放的位置:



log4j架包下载:http://pan.baidu.com/s/1kVvEyAN

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值