### Log4j配置与加载方法详解 Log4j是一款由Apache出品的日志记录工具,它提供了灵活的日志级别控制和多样化的日志输出方式,广泛应用于Java应用的开发中。本文将深入解析log4j的配置与加载机制,帮助开发者更好地理解和应用log4j。 #### Log4j配置文件格式 Log4j支持多种配置文件格式,包括`.properties`和`.xml`。两种格式在功能上并无本质区别,选择哪种取决于个人或团队的偏好。 1. **.properties格式**: 在`.properties`文件中,配置信息通过键值对的形式呈现,如示例中的`log4j.category.org.zblog=ERROR,A1`,这里指定了`org.zblog`这个logger的日志级别为`ERROR`,并关联到名为`A1`的appender。 2. **.xml格式**: `.xml`配置文件则采用XML结构来组织配置信息,示例中的`<appender>`、`<logger>`等元素定义了不同的日志组件和它们之间的关系。这种格式更易于阅读和理解,尤其是在配置复杂的情况下。 #### Appender详解 Appender是log4j中负责实际日志输出的部分,可以是控制台、文件、数据库等多种类型。示例中用到了`ConsoleAppender`和`RollingFileAppender`。 1. **ConsoleAppender**: 控制台输出器,用于将日志输出到控制台。配置时,通过`log4j.appender.A1=org.apache.log4j.ConsoleAppender`指定。 2. **RollingFileAppender**: 文件滚动输出器,当文件大小超过设定值时会自动创建新文件。例如`log4j.appender.A2=org.apache.log4j.RollingFileAppender`,并且指定了文件路径、最大文件大小以及备份索引,以实现日志文件的滚动存储。 #### 日志级别与转换模式 日志级别包括`DEBUG`、`INFO`、`WARN`、`ERROR`等,用于控制日志的详细程度。示例中的`log4j.category.org.zblog=ERROR,A1`指定了`org.zblog`类的日志级别最低为`ERROR`。 转换模式(ConversionPattern)则用于定义日志输出的格式。例如`%d{yyyy-MM-dd HH:mm:ss,SSS}`表示日期时间格式,`%c`表示输出产生日志的类名,`%p`表示日志级别,`%m`表示日志消息,`%n`表示换行符。这些代码组合起来,形成了一套完整的日志输出样式。 #### 加载配置方法 1. **PropertyConfigurator**: 通过`PropertyConfigurator.configure("path/to/log4j.properties")`来加载`.properties`配置文件。 2. **DOMConfigurator**: 使用`DOMConfigurator.configure("path/to/log4j.xml")`来加载`.xml`配置文件。 在示例代码中,`import org.apache.log4j.Logger;`、`import org.apache.log4j.PropertyConfigurator;`、`import org.apache.log4j.xml.DOMConfigurator;`表明了加载配置文件所必需的导入语句。 通过上述分析,我们可以看出log4j的配置与加载方法具有高度的灵活性和扩展性,能够满足不同场景下的日志管理需求。开发者应根据具体的应用环境和日志管理策略,合理配置log4j,以提升应用的稳定性和可维护性。


























一、log4j.properties
### 设置org.zblog域对应的级别INFO,DEBUG,WARN,ERROR和输出地A1,A2 ##
log4j.category.org.zblog=ERROR,A1
log4j.category.org.zblog=INFO,A2
log4j.appender.A1=org.apache.log4j.ConsoleAppender
### 设置输出地A1,为ConsoleAppender(控制台) ##
log4j.appender.A1.layout=org.apache.log4j.PatternLayout
### 设置A1的输出布局格式PatterLayout,(可以灵活地指定布局模式)##
log4j.appender.A1.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss,SSS} [%c]-[%p] %m%n
### 配置日志输出的格式##
log4j.appender.A2=org.apache.log4j.RollingFileAppender
### 设置输出地A2到文件(文件大小到达指定尺寸的时候产生一个新的文件)##
log4j.appender.A2.File=E:/study/log4j/zhuwei.html
### 文件位置##
log4j.appender.A2.MaxFileSize=500KB
### 文件大小##
log4j.appender.A2.MaxBackupIndex=1
log4j.appender.A2.layout=org.apache.log4j.HTMLLayout
##指定采用html方式输出
二、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="org.zblog.all" class="org.apache.log4j.RollingFileAppender">
<!-- 设置通道ID:org.zblog.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">


- 粉丝: 0
我的内容管理 展开
我的资源 快来上传第一个资源
我的收益
登录查看自己的收益我的积分 登录查看自己的积分
我的C币 登录后查看C币余额
我的收藏
我的下载
下载帮助


最新资源
- 杭州市权力阳光电子政务系统安全技术规范.doc
- 移动网北向接口技术规范基于技术的大数据量配置管理接口设计.doc
- 多绳摩擦式提升机恒减速制动系统安全调试.doc
- 电气专业考试改革方案及课程纲要工业电气自动化.doc
- 一张图5种photoshop扣图方法(实例教程).docx
- 银行防范治理电信网络新型违法犯罪典型案例.pdf
- 基于Android的手机应用开发连连看游戏的开发与实现毕业论文.doc
- 项目管理自测作业答案样本.doc
- 算法与程序框图汇总(20211130142852).pdf
- 人教版:《21.3广播、电视和移动通信》.ppt
- 高温气冷实验堆项目管理系统的框架设计.doc
- 人脸识别:一种简单的特征提取算法.ppt
- 竞争性谈判采购洛阳职业技术学院解剖软件系统.doc
- 网络营销策划工作总结及工作计划建议.docx
- 多媒体计算机教室建设方案培训资料.doc
- 推行节能环保施工提高群体项目管理水平.doc


