Log4J日志信息配置文件详解
原文地址: http://blog.csdn.net/wuxintdrh/article/details/78282097
使用log4j 记录日志甚是方便,其提供了两种日志配置方式,log4j.propertes和log4j.xml,这篇文件先贴出log4j.properties配置方式
1、log4j.properties文件配置简析
下面给出了log4j.properties文件常用的一些信息,在使用时只需拷贝部分过来并把注释放开即可,如有问题 感谢留言指正.
##logger是进行记录的主要类,appender是记录的方式,layout是记录的格式 #Logger - 日志写出器,供程序员输出日志信息
#Appender - 日志目的地,把格式化好的日志信息输出到指定的地方去
#ConsoleAppender - 目的地为控制台的Appender
#FileAppender - 目的地为文件的Appender
#RollingFileAppender - 目的地为大小受限的文件的Appender
#Layout - 日志格式化器,用来把程序员的logging request格式化成字符串
#PatternLayout - 用指定的pattern格式化logging request的Layou #Log4j提供的appender有以下几种:
# org.apache.log4j.ConsoleAppender(控制台),
# org.apache.log4j.FileAppender(文件),
# org.apache.log4j.DailyRollingFileAppender(每天产生一个日志文件),
# org.apache.log4j.RollingFileAppender(文件大小到达指定尺寸的时候产生一个新的文件),
# org.apache.log4j.WriterAppender(将日志信息以流格式发送到任意指定的地方) #Log4j提供的layout有以下几种:
# org.apache.log4j.HTMLLayout(以HTML表格形式布局),
# org.apache.log4j.PatternLayout(可以灵活地指定布局模式),
# org.apache.log4j.SimpleLayout(包含日志信息的级别和信息字符串),
# org.apache.log4j.TTCCLayout(包含日志产生的时间、线程、类别等等信息) #Log4J采用类似C语言中的printf函数的打印格式格式化日志信息,打印参数如下
# %m 输出代码中指定的消息
# %M 输出日志发生的方法名
# %p 输出优先级,即DEBUG,INFO,WARN,ERROR,FATAL
# %r 输出自应用启动到输出该log信息耗费的毫秒数
# %c 输出所属的类目,通常就是所在类的全名
# %t 输出产生该日志事件的线程名
# %n 输出一个回车换行符,Windows平台为“rn”,Unix平台为“n”
# %d 输出日志时间点的日期或时间,默认格式为ISO8601,也可以在其后指定格式,比如:%d{yyyy MMM dd HH:mm:ss,SSS},输出类似:2002年10月18日 22:10:28,921
# %l 输出日志事件的发生位置,包括类目名、发生的线程,以及在代码中的行数。举例:Testlog4.main(TestLog4.java:10)
# %L 输出日志发生的位置
# %F 输出类名 #####################################################################
#设置级别和目的地 -- 把日志等级为debug的日志信息输出到stdout和SYS,QUERY这三个目的地
log4j.rootLogger=debug,STDOUT
# stdout:目的地 -- 打印到屏幕
## org.apache.log4j.ConsoleAppender:控制台
log4j.appender.STDOUT=org.apache.log4j.ConsoleAppender
## org.apache.log4j.PatternLayout:灵活地指定布局模式
log4j.appender.STDOUT.layout=org.apache.log4j.PatternLayout
## 上一句设置了PatternLayout灵活指定格式,则要指定打印参数 [%-5p][%d{HH:mm:ss}][%c-%M] %m%n [%-5p][%d{HH:mm:ss}][%l] %m%n
log4j.appender.STDOUT.layout.ConversionPattern=[%-5p][%d{yyyy-MM-dd HH:mm:ss sss}][%t][%c-%M][%L](%F:%L) - %m%n # QUERY:目的地 -- 输出到文件(限定每个文件大小)
## 凡是 info、warn、error、fatal 级别的数据都会在这里执行输出到 query.log 日志文件中
##log4j.logger.QUERY=INFO,QUERY
log4j.logger.QUERY=INFO
##输出到文件(这里默认为追加方式),使用org.apache.log4j.FileAppender:日志会在一个文件中追加
log4j.appender.QUERY=org.apache.log4j.RollingFileAppender
##设置文件输出路径;html:log/query.html
log4j.appender.QUERY.File=log/query.log
##设置文件输出样式;html格式: org.apache.log4j.HTMLLayout
log4j.appender.QUERY.layout=org.apache.log4j.PatternLayout
## 上一句设置了PatternLayout灵活指定格式,则要指定打印参数 [%-5p][%d{HH:mm:ss}][%l] %m%n
log4j.appender.QUERY.layout.ConversionPattern=[%-5p][%d{yyyy-MM-dd HH:mm:ss}][%c-%M] %m%n
## 指定文件的最大 大小
log4j.appender.QUERY.MaxFileSize=2048KB
## 可被备份的日志数
log4j.appender.QUERY.MaxBackupIndex=100 # SYS:目的地 -- 输出到文件(每天产生一个文件)
## 凡是 error、fatal 级别的数据都会在这里执行输出到 sys.log 日志文件中
#log4j.logger.SYS=error,SYS
log4j.logger.SYS=error
## org.apache.log4j.RollingFileAppender:每天产生一个日志文件
#使用org.apache.log4j.FileAppender:日志会在一个文件中追加
log4j.appender.SYS=org.apache.log4j.DailyRollingFileAppender
##设置文件输出路径 ${user.home}/log/sys.log
log4j.appender.SYS.File=log/sys.log
## org.apache.log4j.PatternLayout:灵活地指定布局模式
log4j.appender.SYS.layout=org.apache.log4j.PatternLayout
## 上一句设置了PatternLayout灵活指定格式,则要指定打印参数 [%-5p][%d{HH:mm:ss}][%l] %m%n
log4j.appender.SYS.layout.ConversionPattern=[%-5p][%d{HH:mm:ss}][%C-%M] %m%n #设置特定包的级别
##com.swh.weixin包下的日志内容显示级别为debug,和目的地
## 把com.swh.weixin.util包下日志等级为debug的信息输出到pack 目的地
#log4j.logger.com.swh.weixin.util=debug,pack
##输出到文件(这里默认为追加方式),使用org.apache.log4j.FileAppender:日志会在一个文件中追加
log4j.appender.pack=org.apache.log4j.RollingFileAppender
##设置文件输出路径 或者 ${user.home}/log/pack.log
log4j.appender.pack.File=log/pack.log
##设置文件输出样式
log4j.appender.pack.layout=org.apache.log4j.PatternLayout
## 上一句设置了PatternLayout灵活指定格式,则要指定打印参数 [%-5p][%d{HH:mm:ss}][%l] %m%n
log4j.appender.pack.layout.ConversionPattern=[%-5p][%d{yyyy MM dd HH:mm:ss}][%c-%M] %m%n
## 指定文件的最大 大小
log4j.appender.pack.MaxFileSize=1024KB
#日志最大备份数目
log4j.appender.pack.MaxBackupIndex=100 ########################################################################
##设置级别和目的地
#log4j.rootLogger=debug,appender1,appender2
##只设置特定包的级别和目的地
#log4j.logger.com.coderdream=debug,appender1
#log4j.logger.com.coderdream.Dao=info,appender1,appender2 ##输出到控制台
#log4j.appender.appender1=org.apache.log4j.ConsoleAppender
##设置输出样式
#log4j.appender.appender1.layout=org.apache.log4j.PatternLayout
##自定义样式
## %r 时间 0
## %t 方法名 main
## %p 优先级 DEBUG/INFO/ERROR
## %c 所属类的全名(包括包名)
## %l 发生的位置,在某个类的某行
## %m 输出代码中指定的讯息,如log(message)中的message
## %n 输出一个换行符号
#log4j.appender.appender1.layout.ConversionPattern=[%d{yy/MM/dd HH:mm:ss:SSS}][%C-%M] %m%n ##输出到文件(这里默认为追加方式)
#log4j.appender.appender2=org.apache.log4j.FileAppender
##设置文件输出路径
##【1】文本文件
#log4j.appender.appender2.File=c:/Log4JCRM_Dao.log
##设置文件输出样式
#log4j.appender.appender2.layout=org.apache.log4j.PatternLayout
#log4j.appender.appender2.layout.ConversionPattern=[%d{HH:mm:ss:SSS}][%C-%M] -%m%n ##把日志文件写入数据库
##########################日志输出到远程数据库########################################
##把日志文件写入数据库
##记录的日志级别
log4j.logger.db=info
##日志输出到数据库
log4j.appender.db = org.apache.log4j.jdbc.JDBCAppender
##缓存
log4j.appender.db.BufferSize = 0
##数据库驱动
log4j.appender.db.Driver = com.mysql.jdbc.Driver
##数据url地址 ,本地可简写:jdbc:mysql:///test
log4j.appender.db.URL = jdbc:mysql://localhost:3306/swh_hibernate4?useUnicode=true&characterEncoding=utf8
##数据库用户名
log4j.appender.db.User = root
##数据库密码
log4j.appender.db.Password = root
##日志布局模式
log4j.appender.db.layout = org.apache.log4j.PatternLayout
##日志插入数据库中,t_logs 表字段可自定义
log4j.appender.db.layout.ConversionPattern = INSERT INTO t_logs(createDate, thread, priority, category,<br />
methodName, message) values('%d', '%t', '%-5p', '%c','%M', '[%l]-%m')
log4j.xml
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE log4j:configuration SYSTEM "log4j.dtd"> <log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/"> <appender name="default" class="org.apache.log4j.ConsoleAppender">
<param name="target" value="System.out"/>
<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern" value="[%-5p] %d{yyyy-MM-dd hh:mm:ss.SSS aa} %t [%c]%n%m%n%n"/>
</layout>
</appender> <appender name="console" class="org.apache.log4j.ConsoleAppender">
<param name="target" value="System.out"/>
<!-- 设置日志文件输出样式 -->
<layout class="org.apache.log4j.PatternLayout">
<!-- 设置日志的输出格式 -->
<param name="ConversionPattern" value="[%-5p] [%d{yyyy-MM-dd HH:mm:ss.SSS z}] [%t] [%c]%n%m%n%n"/>
</layout>
</appender> <!-- 查询级别,输出到文件(限定每个文件大小) -->
<appender name="query" class="org.apache.log4j.RollingFileAppender">
<!-- 设置日志输出文件名 -->
<param name="File" value="E:/user-job-web.log" />
<!-- 设置是否在重新启动服务时,在原有日志的基础添加新日志 -->
<param name="Append" value="true" />
<!-- 指定文件的最大 大小为1MB 单位是B(1024B=1KB) -->
<param name="MaxFileSize" value="1048576" />
<!-- 备份日志文件的个数(默认是10个) -->
<param name="MaxBackupIndex" value="10" />
<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern" value="[%-5p][%d{yyyy-MM-dd HH:mm:ss}][%c-%M] %m%n" />
</layout>
</appender> <!-- 输出到文件(每天产生一个文件) -->
<appender name="sys" class="org.apache.log4j.DailyRollingFileAppender">
<!-- 设置日志输出文件名 -->
<param name="File" value="E:\\user-job-web_warn.log" />
<param name="DatePattern" value="'.'yyyy-MM-dd'.log'" />
<!-- 设置日志文件输出样式 -->
<layout class="org.apache.log4j.PatternLayout">
<!-- 设置日志的输出格式 -->
<param name="ConversionPattern" value="[%-5p] [%d{yyyy-MM-dd HH:mm:ss.SSS}] [%t] [%c-%M]%n%m%n%n"/>
</layout>
</appender> <!-- 日志输出到数据中 -->
<appender name="dblog" class="org.apache.log4j.jdbc.JDBCAppender">
<!-- 设置数据库信息和连接 -->
<param name="Driver" value="com.mysql.jdbc.Driver" />
<param name="URL" value="jdbc:mysql://localhost:3306/swh_hibernate4?useUnicode=true&characterEncoding=utf8" />
<param name="user" value="root" />
<param name="password" value="root" />
<!-- 设置日志文件输出样式 -->
<layout class="org.apache.log4j.PatternLayout">
<!-- 设置输出日志的sql-->
<param name="ConversionPattern" value="INSERT INTO t_logs(createDate, thread, priority, category,methodName, message) values('%d', '%t', '%-5p', '%c','%M', '[%l]-%m')"/>
</layout>
</appender>
<!-- 单独配置,效果和放到logger->root下一样 -->
<category name="com.swh.crm.aop" additivity="false">
<level value="INFO" />
<appender-ref ref="dblog" />
<appender-ref ref="console" />
</category> <logger name="org.quartz">
<level value="warn" />
</logger> <!-- 设置com.swh.crm.service路径下的日志信息级别为info级别 -->
<logger name="com.swh.oa.service" additivity="true">
<level value="info" />
</logger> <!-- 设置级别和目的地 -->
<root>
<!-- 设置根日志级别,指定路径中的日志优先级大于根日志优先级
(com.swh.crm(只会输出info级别以上的日志)>root,
org.quartz(只会输出warn级别以上的日志))
没有指定日志级别的则以root指定的日志级别为准 -->
<level value="debug" />
<!-- 引入appender -->
<!-- <appender-ref ref="sys" /> -->
<appender-ref ref="query" />
<appender-ref ref="console" />
</root> </log4j:configuration>
Log4J日志信息配置文件详解的更多相关文章
- Java学习-007-Log4J 日志记录配置文件详解及实例源代码
此文主要讲述在初学 Java 时,常用的 Log4J 日志记录配置文件详解及实例源代码整理.希望能对初学 Java 编程的亲们有所帮助.若有不足之处,敬请大神指正,不胜感激!源代码测试通过日期为:20 ...
- Log4j 日志操作包配置详解
log4j简介 Log4j是Apache的一个开源项目,通过使用Log4j,我们可以控制日志信息输送的目的地是控制台.文件.GUI组件,甚至是套接口服务器.NT的事件记录器.UNIX Syslog守护 ...
- Log4j之properties配置文件详解
Log4j由三个重要的组件构成:日志信息的优先级,日志信息的输出目的地,日志信息的输出格式.日志信息的优先级从高到低有ERROR.WARN. INFO.DEBUG,分别用来指定这条日志信息的重要程度: ...
- java log4j基本配置及日志级别配置详解
java log4j日志级别配置详解 1.1 前言 说出来真是丢脸,最近被公司派到客户公司面试外包开发岗位,本来准备了什么redis.rabbitMQ.SSM框架的相关面试题以及自己做过的一些项目回顾 ...
- java 日志体系(三)log4j从入门到详解
java 日志体系(三)log4j从入门到详解 一.Log4j 简介 在应用程序中添加日志记录总的来说基于三个目的: 监视代码中变量的变化情况,周期性的记录到文件中供其他应用进行统计分析工作: 跟踪代 ...
- 《手把手教你》系列基础篇(八十六)-java+ selenium自动化测试-框架设计基础-Log4j实现日志输出(详解教程)
1.简介 自动化测试中如何输出日志文件.任何软件,都会涉及到日志输出.所以,在测试人员报bug,特别是崩溃的bug,一般都要提供软件产品的日志文件.开发通过看日志文件,知道这个崩溃产生的原因,至少知道 ...
- log4j 日志信息的引入(通用版)——解决项目运行过程中的日志信息
定义 log4j是Apache的一个开放源代码项目,通过使用Log4j,我们可以控制日志信息输送的目的地是控制台.文件.GUI组件,甚至是套接口服务器.NT的事件记录器.UNIX Syslog守护进程 ...
- log4j.properties 的使用详解
一.log4j.properties 的使用详解 1.输出级别的种类 ERROR.WARN.INFO.DEBUGERROR 为严重错误 主要是程序的错误WARN 为一般警告,比如session丢失IN ...
- Log4j2配置文件详解
目录[-] 1 系列目录 2 默认配置 3 第一个配置例子 4 复杂一点的配置 4.1 Appender之Syslog配置 4.2 Syslog及Syslog-ng相关配置(Fedora) 5 Log ...
随机推荐
- <操作系统>并发
相关术语 进程的交互:根据进程相互之间知道对方的程度分类为如下几个等级. 进程间的资源竞争.并发进程访问同一资源的时候,会发生冲突.当两个进程访问同一资源的时候,由于并不知道对方的存在,两者之间没有信 ...
- WebSocket原理与实践(二)---WebSocket协议
WebSocket原理与实践(二)---WebSocket协议 WebSocket协议是为了解决web即时应用中服务器与客户端浏览器全双工通信问题而设计的.协议定义ws和wss协议,分别为普通请求和基 ...
- PAT A1123 Is It a Complete AVL Tree (30 分)——AVL平衡二叉树,完全二叉树
An AVL tree is a self-balancing binary search tree. In an AVL tree, the heights of the two child sub ...
- PAT A1130 Infix Expression (25 分)——中序遍历
Given a syntax tree (binary), you are supposed to output the corresponding infix expression, with pa ...
- 汇编指令:ldr和str,ldm和stm的区别
(1)LDR:L表示LOAD,LOAD的含义应该理解为:Load from memory into register.下面这条语句就说明的很清楚: LDR R1, [R2] R1<— ...
- 微信小程序案例:获取微信访问用户的openid
在微信开发项目中,获取openid是项目常遇的问题,本文通过主要讲解实现在微信小程序中如何获取用户的openid,案例实现非常简单 具体实现方法是通过登录接口获取登录凭证,然后通过request请求微 ...
- 【php增删改查实例】第十一节 - 部门管理模块(编辑功能)
9. 编辑部门功能的实现 思路:只允许用户勾选一条数据,点击编辑按钮,会跳出一个和新增数据类似的对话框.然后,用户可以修改部门名称和部门编码.点击保存按钮,提示修改成功. 9.1 前台代码编写 < ...
- 《Head First 设计模式》例子的C++实现(2 观察者模式)
最近在学习设计模式,用的是 <Head First 设计模式>这本书.感觉这本书写的还是很不错的,深入浅出的介绍了各种常用的设计模式.唯一有点不方便的地方是这本书的例子全都是用的 Java ...
- Docker网络解决方案 - Weave部署记录
前面说到了Flannel的部署,今天这里说下Docker跨主机容器间网络通信的另一个工具Weave的使用.当容器分布在多个不同的主机上时,这些容器之间的相互通信变得复杂起来.容器在不同主机之间都使用的 ...
- SQL中not in 和not exists
在SQL中倒是经常会用到子查询,而说到子查询,一般用的是in而不是exists,先不谈效率问题,就先说说会遇到哪些问题. 用到in当取反的时候,肯定先想到的就是not in.但是在使用not in的时 ...