Log4J 基本使用
Log4j由三个重要的组件 构 成:日志 信息 的优先级,日志信息的输出目的地,日志信息的输出格式。
日志信息的优先级 从高到低有ERROR 、 WARN 、 INFO 、 DEBUG ,分别用来指定这条日志信息的重要程度。
日志信息的输出目的 地指定了日志将打印到控制台还是文件中;而输出格式则控制了日志信息的显示内容。
# 配置根 Logger ,其语法为:
log4j.rootLogger = [ level ] , appenderName, appenderName, …
※ level 是日志记录的优先级,分为OFF 、 FATAL 、 ERROR 、 WARN 、 INFO 、 DEBUG 、 ALL 或者您定义的级别。 Log4j 建议只使用四个级别,优 先级从高到低分别是 ERROR 、 WARN 、 INFO 、 DEBUG 。通过在这里定义的级别,您可以控制到应用程序中相应级别的日志信息的开关。指定输出只显 示比该级别以上的信息,所有比该级别低的信息都不会被显示。比如在这里定义了 INFO 级别,则应用程序中所有 DEBUG 级别的日志信息将不被打印出来。
※ appenderName 就是指定日志信息输出到哪个地方。您可以同时指定多个输出目的地。
# 配置日志信息输出目的地 Appender ,其语法为:
log4j.appender.appenderName = fully.qualified.name.of.appender.class
※ Log4j提供的 appender 有以下几种:
org.apache.log4j.ConsoleAppender(控制台)
org.apache.log4j.FileAppender(文件)
org.apache.log4j.DailyRollingFileAppender(每天产生一个日志文件)
org.apache.log4j.RollingFileAppender(文件大小到达指定尺寸的时候产生一个新的文件)
org.apache.log4j.WriterAppender(将日志信息以流格式发送到任意指定的地方)
# 配置日志信息的格式(布局),其语法为:
log4j.appender.appenderName.layout = fully.qualified.name.of.layout.class
※ Log4j提供的 layout 有以下几种:
org.apache.log4j.HTMLLayout(以 HTML 表格形式布局),
org.apache.log4j.PatternLayout(可以灵活地指定布局模式),
org.apache.log4j.SimpleLayout(包含日志信息的级别和信息字符串),
org.apache.log4j.TTCCLayout(包含日志产生的时间、线程、类别等等信息)
※ 当layout 为 PatternLayout 时, ConversionPattern 的格式有下面选项:
%r: 自程序开始后消耗的毫秒数
%t: 表示日志记录请求生成的线程
%p: 表示日志语句的优先级
%r: 与日志请求相关的类别名称
%c: 信息所在的类名
%m%n: 表示消息的内容
*************************代码中的使用 *******************************
1. import中加入以下几行:
import org.apache.log4j.PropertyConfigurator ;
import org.apache.log4j.Logger ;
import org.apache.log4j.Level ;
2. 定义 Logger 变量 :
static Logger logger = Logger.getLogger(ServerWithLog4j.class.getName ()) ;
3. 读配置文件 :
PropertyConfigurator.configure (String settingfilename) ;
4. 显示日志信息 :
按显示级别显示日志信息 logger.debug(String log_info);
用于显示调试信息 logger.info (String log_info);
用于显示系统提示信息 logger.warn(String log_info);
用于显示警告或特殊提示 logger.error(String log_info);
用于显示错误信息,一般在异常中使用。
********************************************************************************************
java代码中添加如下语句
static {
// 启动日志de
try {
PropertyConfigurator.configure(QuartzTest.class.getClassLoader()
.getResource("").toURI().getPath()
+ "conf/log4j.properties");
} catch (Exception e) {
}
}
src/conf/log4j.properties
log4j.rootLogger=INFO,A1,A2,A3
log4j.appender.A1=org.apache.log4j.ConsoleAppender
log4j.appender.A1.Threshold=INFO
log4j.appender.A2=org.apache.log4j.DailyRollingFileAppender
log4j.appender.A2.Threshold=INFO
log4j.appender.A2.File=./log/dailyLog/ENDailyRollingLog.log
log4j.appender.A2.DatePattern='.'yyyy-MM-dd'.log'
log4j.appender.A3=org.apache.log4j.RollingFileAppender
log4j.appender.A3.Threshold=INFO
log4j.appender.A3.File=./log/ENRollingLog.log
log4j.appender.A3.MaxFileSize=5MB
log4j.appender.A3.MaxBackupIndex=5
log4j.appender.A1.layout=org.apache.log4j.PatternLayout
log4j.appender.A1.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} <# %l> %-5p [%r]:%n%m%n
log4j.appender.A2.layout=org.apache.log4j.PatternLayout
log4j.appender.A2.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} <# %l> %-5p [%r]:%n%m%n
log4j.appender.A3.layout=org.apache.log4j.PatternLayout
log4j.appender.A3.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} <# %l> %-5p [%r]:%n%m%n
最新文章
- Juint整合Log4j
- UIProgressView改变高度
- 简述UIViewControl之间的七种传值方式~~~
- JavaScript学习笔记-循环输出菱形,并可菱形自定义大小
- ActiveMQ之jmscorrelationid与selector
- PrintQueue
- 面试题 IQ
- jquery ajax 后台和前台数据交互 C#
- Never use GetDate() when comparing date timesoffsets, use SYSDATETIMEOFFSET()
- Java 8 Learn Notes - Streams
- 2.如何修改apache的默认端口
- Bootstrap3 代码-变量
- python3之platform模块
- ArcGIS 批量修改数据名称-arcgis案例实习教程
- CF643E. Bear and Destroying Subtrees 期望dp
- React组件的State
- Jmeter AbstractJavaSamplerClient 案例
- SpringBoot 分页处理
- oracle去重试验
- form 表单添加 enctype =";multipart/form-data"; 属性后后台接收中文乱码