一、前言

  log4j使用的还是比较多的,但是对于其配置又很难描述清楚要怎么配置,说明我自己对于log4j的配置并不是非常熟悉,所以在网上找了一篇详尽的 博文转载,在此非常感谢原文作者的辛苦付出,如有需要,请参考原文链接~

二、正文

  最近使用log4j写log时候发现网上的写的都是千篇一律,写的好的嘛不全,写的全一点的嘛没有一点格式,看着累。这里把网上收集到的整理了一下,并且全部都在机器上测试成功了。这么好的文档估计没有了吧?

################################################################################ 
#①配置根Logger,其语法为: 

#log4j.rootLogger =[level],appenderName,appenderName2,... 
#level是日志记录的优先级,分为OFF,TRACE,DEBUG,INFO,WARN,ERROR,FATAL,ALL 
##Log4j建议只使用四个级别,优先级从低到高分别是DEBUG,INFO,WARN,ERROR 
#通过在这里定义的级别,您可以控制到应用程序中相应级别的日志信息的开关 
#比如在这里定义了INFO级别,则应用程序中所有DEBUG级别的日志信息将不被打印出来 
#appenderName就是指定日志信息输出到哪个地方。可同时指定多个输出目的 
################################################################################ 
################################################################################ 
#②配置日志信息输出目的地Appender,其语法为: 

#log4j.appender.appenderName =fully.qualified.name.of.appender.class 
#log4j.appender.appenderName.optionN =valueN 

#Log4j提供的appender有以下几种: 
#1)org.apache.log4j.ConsoleAppender(输出到控制台) 
#2)org.apache.log4j.FileAppender(输出到文件) 
#3)org.apache.log4j.DailyRollingFileAppender(每天产生一个日志文件) 
#4)org.apache.log4j.RollingFileAppender(文件大小到达指定尺寸的时候产生一个新的文件) 
#5)org.apache.log4j.WriterAppender(将日志信息以流格式发送到任意指定的地方) 

#1)ConsoleAppender选项属性 
# -Threshold = DEBUG:指定日志消息的输出最低层次 
# -ImmediateFlush = TRUE:默认值是true,所有的消息都会被立即输出 
# -Target = System.err:默认值System.out,输出到控制台(err为红色,out为黑色) 

#2)FileAppender选项属性 
# -Threshold = INFO:指定日志消息的输出最低层次 
# -ImmediateFlush = TRUE:默认值是true,所有的消息都会被立即输出 
# -File = C:\log4j.log:指定消息输出到C:\log4j.log文件 
# -Append = FALSE:默认值true,将消息追加到指定文件中,false指将消息覆盖指定的文件内容 
# -Encoding = UTF-8:可以指定文件编码格式 

#3)DailyRollingFileAppender选项属性 
#-Threshold = WARN:指定日志消息的输出最低层次 
#-ImmediateFlush = TRUE:默认值是true,所有的消息都会被立即输出 
# -File =C:\log4j.log:指定消息输出到C:\log4j.log文件 
# -Append= FALSE:默认值true,将消息追加到指定文件中,false指将消息覆盖指定的文件内容 
#-DatePattern='.'yyyy-ww:每周滚动一次文件,即每周产生一个新的文件。还可以按用以下参数: 
#              '.'yyyy-MM:每月 
#              '.'yyyy-ww:每周 
#              '.'yyyy-MM-dd:每天 
#              '.'yyyy-MM-dd-a:每天两次 
#              '.'yyyy-MM-dd-HH:每小时 
#              '.'yyyy-MM-dd-HH-mm:每分钟 
#-Encoding = UTF-8:可以指定文件编码格式 

#4)RollingFileAppender选项属性 
#-Threshold = ERROR:指定日志消息的输出最低层次 
#-ImmediateFlush = TRUE:默认值是true,所有的消息都会被立即输出 
# -File =C:/log4j.log:指定消息输出到C:/log4j.log文件 
# -Append= FALSE:默认值true,将消息追加到指定文件中,false指将消息覆盖指定的文件内容 
#-MaxFileSize = 100KB:后缀可以是KB,MB,GB.在日志文件到达该大小时,将会自动滚动.如:log4j.log.1 
#-MaxBackupIndex = 2:指定可以产生的滚动文件的最大数 
#-Encoding = UTF-8:可以指定文件编码格式 
################################################################################ 
################################################################################ 
#③配置日志信息的格式(布局),其语法为: 

#log4j.appender.appenderName.layout=fully.qualified.name.of.layout.class 
#log4j.appender.appenderName.layout.optionN= valueN 

#Log4j提供的layout有以下几种: 
#5)org.apache.log4j.HTMLLayout(以HTML表格形式布局) 
#6)org.apache.log4j.PatternLayout(可以灵活地指定布局模式) 
#7)org.apache.log4j.SimpleLayout(包含日志信息的级别和信息字符串) 
#8)org.apache.log4j.TTCCLayout(包含日志产生的时间、线程、类别等等信息) 
#9)org.apache.log4j.xml.XMLLayout(以XML形式布局) 

#5)HTMLLayout选项属性 
#-LocationInfo = TRUE:默认值false,输出java文件名称和行号 
#-Title=Struts Log Message:默认值 Log4JLog Messages 

#6)PatternLayout选项属性 
#-ConversionPattern = %m%n:格式化指定的消息(参数意思下面有) 

#9)XMLLayout选项属性 
#-LocationInfo = TRUE:默认值false,输出java文件名称和行号 

#Log4J采用类似C语言中的printf函数的打印格式格式化日志信息,打印参数如下: 
#%m 输出代码中指定的消息 
#%p 输出优先级,即DEBUG,INFO,WARN,ERROR,FATAL 
#%r 输出自应用启动到输出该log信息耗费的毫秒数 
#%c 输出所属的类目,通常就是所在类的全名 
#%t 输出产生该日志事件的线程名 
#%n 输出一个回车换行符,Windows平台为“\r\n”,Unix平台为“\n” 
#%d 输出日志时间点的日期或时间,默认格式为ISO8601,也可以在其后指定格式 
#    如:%d{yyyy年MM月dd日HH:mm:ss,SSS},输出类似:2012年01月05日 22:10:28,921 
#%l 输出日志事件的发生位置,包括类目名、发生的线程,以及在代码中的行数 
#    如:Testlog.main(TestLog.java:10) 
#%F 输出日志消息产生时所在的文件名称 
#%L 输出代码中的行号 
#%x 输出和当前线程相关联的NDC(嵌套诊断环境),像javaservlets多客户多线程的应用中 
#%% 输出一个"%"字符 

# 可以在%与模式字符之间加上修饰符来控制其最小宽度、最大宽度、和文本的对齐方式。如: 
#  %5c: 输出category名称,最小宽度是5,category<5,默认的情况下右对齐 
#  %-5c:输出category名称,最小宽度是5,category<5,"-"号指定左对齐,会有空格 
#  %.5c:输出category名称,最大宽度是5,category>5,就会将左边多出的字符截掉,<5不会有空格 
#  %20.30c:category名称<20补空格,并且右对齐,>30字符,就从左边交远销出的字符截掉 
################################################################################ 
################################################################################ 
#④指定特定包的输出特定的级别 
#log4j.logger.org.springframework=DEBUG 
################################################################################

#OFF,systemOut,logFile,logDailyFile,logRollingFile,logMail,logDB,ALL 
log4j.rootLogger=ALL,systemOut,logFile,logDailyFile,logRollingFile,logMail,logDB

#输出到控制台 
log4j.appender.systemOut= org.apache.log4j.ConsoleAppender 
log4j.appender.systemOut.layout= org.apache.log4j.PatternLayout 
log4j.appender.systemOut.layout.ConversionPattern= [%-5p][%-22d{yyyy/MM/dd HH:mm:ssS}][%l]%n%m%n 
log4j.appender.systemOut.Threshold= DEBUG 
log4j.appender.systemOut.ImmediateFlush= TRUE 
log4j.appender.systemOut.Target= System.out

#输出到文件 
log4j.appender.logFile= org.apache.log4j.FileAppender 
log4j.appender.logFile.layout= org.apache.log4j.PatternLayout 
log4j.appender.logFile.layout.ConversionPattern= [%-5p][%-22d{yyyy/MM/dd HH:mm:ssS}][%l]%n%m%n 
log4j.appender.logFile.Threshold= DEBUG 
log4j.appender.logFile.ImmediateFlush= TRUE 
log4j.appender.logFile.Append= TRUE 
log4j.appender.logFile.File= ../Struts2/WebRoot/log/File/log4j_Struts.log 
log4j.appender.logFile.Encoding= UTF-8

#按DatePattern输出到文件 
log4j.appender.logDailyFile= org.apache.log4j.DailyRollingFileAppender 
log4j.appender.logDailyFile.layout= org.apache.log4j.PatternLayout 
log4j.appender.logDailyFile.layout.ConversionPattern= [%-5p][%-22d{yyyy/MM/dd HH:mm:ssS}][%l]%n%m%n 
log4j.appender.logDailyFile.Threshold= DEBUG 
log4j.appender.logDailyFile.ImmediateFlush= TRUE 
log4j.appender.logDailyFile.Append= TRUE 
log4j.appender.logDailyFile.File= ../Struts2/WebRoot/log/DailyFile/log4j_Struts 
log4j.appender.logDailyFile.DatePattern= '.'yyyy-MM-dd-HH-mm'.log' 
log4j.appender.logDailyFile.Encoding= UTF-8

#设定文件大小输出到文件 
log4j.appender.logRollingFile= org.apache.log4j.RollingFileAppender 
log4j.appender.logRollingFile.layout= org.apache.log4j.PatternLayout 
log4j.appender.logRollingFile.layout.ConversionPattern= [%-5p][%-22d{yyyy/MM/dd HH:mm:ssS}][%l]%n%m%n 
log4j.appender.logRollingFile.Threshold= DEBUG 
log4j.appender.logRollingFile.ImmediateFlush= TRUE 
log4j.appender.logRollingFile.Append= TRUE 
log4j.appender.logRollingFile.File= ../Struts2/WebRoot/log/RollingFile/log4j_Struts.log 
log4j.appender.logRollingFile.MaxFileSize= 1MB 
log4j.appender.logRollingFile.MaxBackupIndex= 10 
log4j.appender.logRollingFile.Encoding= UTF-8

#用Email发送日志 
log4j.appender.logMail= org.apache.log4j.net.SMTPAppender 
log4j.appender.logMail.layout= org.apache.log4j.HTMLLayout 
log4j.appender.logMail.layout.LocationInfo= TRUE 
log4j.appender.logMail.layout.Title= Struts2 Mail LogFile 
log4j.appender.logMail.Threshold= DEBUG 
log4j.appender.logMail.SMTPDebug= FALSE 
log4j.appender.logMail.SMTPHost= SMTP.163.com 
log4j.appender.logMail.From= xly3000@163.com 
log4j.appender.logMail.To= xly3000@gmail.com 
#log4j.appender.logMail.Cc= xly3000@gmail.com 
#log4j.appender.logMail.Bcc= xly3000@gmail.com 
log4j.appender.logMail.SMTPUsername= xly3000 
log4j.appender.logMail.SMTPPassword= 1234567 
log4j.appender.logMail.Subject= Log4j Log Messages 
#log4j.appender.logMail.BufferSize= 1024 
#log4j.appender.logMail.SMTPAuth= TRUE

#将日志登录到MySQL数据库 
log4j.appender.logDB= org.apache.log4j.jdbc.JDBCAppender 
log4j.appender.logDB.layout= org.apache.log4j.PatternLayout 
log4j.appender.logDB.Driver= com.mysql.jdbc.Driver 
log4j.appender.logDB.URL= jdbc:mysql://127.0.0.1:3306/xly 
log4j.appender.logDB.User= root 
log4j.appender.logDB.Password= 123456 
log4j.appender.logDB.Sql= INSERT INTOT_log4j(project_name,create_date,level,category,file_name,thread_name,line,all_category,message)values('Struts2','%d{yyyy-MM-ddHH:mm:ss}','%p','%c','%F','%t','%L','%l','%m')

三、链接

1、http://blog.csdn.net/zhuyong0722/article/details/8965095

四、联系本人

  为方便没有博客园账号的读者交流,特意建立一个企鹅群(纯公益,非利益相关),读者如果有对博文不明之处,欢迎加群交流:261746360,小杜比亚-博客园

转载于:https://www.cnblogs.com/xdouby/p/7561850.html

【转】log4j.properties文件的配置相关推荐

  1. 如何在log4j.properties文件中使用相对路径

    来源:http://hi.baidu.com/eredlab/blog/item/f6c1a5efe44a1af9cf1b3e17.html 写在最前面: log4j是一个应用非常广泛的Java日志组 ...

  2. log4j.properties文件示例

    In log4j tutorial, we saw how to use log4j xml based configuration. But log4j.xml is verbose, so log ...

  3. log4j.properties文件中的log4j.rootLogger重要性

    log4j.rootLogger is at the top of all the logger hierarchy, just like we have Object in java classes ...

  4. log4j日志文件模板配置整理

    log4j日志文件模板配置整理 模板一 模板二 模板三 log4j配置参数介绍 备注 模板一 以xml文件配置,按照不同的日志级别输出到不同的文件中 <?xml version="1. ...

  5. druid.properties文件的配置

    # druid.properties文件的配置 driverClassName=com.mysql.jdbc.Driver url=jdbc:mysql://127.0.0.1:3306/plan u ...

  6. 02_MyBatis项目结构,所需jar包,ehcache.xml配置,log4j.properties,sqlMapConfig.xml配置,SqlMapGenerator.xml配置

     项目结构(所需jar包,配置文件) sqlMapConfig.xml的配置内容如下: <?xmlversion="1.0"encoding="UTF-8&qu ...

  7. Java web 应用全局变量_将properties文件的配置设置为整个Web应用的全局变量。

    四种作用域: Web应用中的变量存放在不同的jsp对象中,会有不一样的作用域,四种不同的作用域排序是pageContext < request < session < applica ...

  8. 第二章、application.properties文件的配置

    前面讲到了如何搭建一个简单的springboot应用,是不是特别简单.springboot内置了tomcat,这就大大减少了我们自己配置tomcat所产生的各种各样的配置手续包括所出现的问题.通过ma ...

  9. java通过spring获取配置文件_springboot获取properties文件的配置内容(转载)

    1.使用@Value注解读取 读取properties配置文件时,默认读取的是application.properties. application.properties: demo.name=Nam ...

  10. Log4j.properties的简单配置

    一.首先导入jar包:log4j-1.2.17.jar 二.新增log4j.properties配置文件并输入以下内容: 三.在测试代码总中进行测试: @Service public class CK ...

最新文章

  1. A Color Picker based on manifold learning
  2. part.write java_小白向:web中利用request.getPart()上传文件到服务器
  3. 《嵌入式C编程:PIC单片机和C编程技术与应用》一1.2 注释
  4. matlab ode45 二阶微分,matlab关于ode45解二阶微分方程的困惑
  5. Oracle锁机制的总结【转】
  6. LeetCode 1985. 找出数组中的第 K 大整数(排序)
  7. 壁式框架内力计算_4种类型剪力墙的计算要点
  8. python学习网站-关于python学习,最系统的学习网站看这里
  9. 会声会影编辑html,用会声会影剪辑视频快速入门技巧
  10. 第22批符合道路运输车辆卫星定位系统标准 及规范的车载终端
  11. activiti6.0(二)节点处理人
  12. java bfs 迷宫例子_51-迷宫(一)- java版dfs和bfs
  13. microtime() 函数
  14. AI一键抠像工具,轻松完成视频抠像操作
  15. 手撕instanceof
  16. adams建立一绳索不带滑轮_ADAMS绳索仿真
  17. 西门子840D HMI ADVANCED FOR PC 也可用于810D,840DSL中文版。
  18. 在android开发板上测试neon加速实验
  19. Java快速开发平台 Java敏捷开发框架源码
  20. java加载找不到类_Java 找不到或无法加载主类的修复方法

热门文章

  1. 有原则有要求,B站董事长陈睿打造超好的社区环境
  2. flutter floor数据库框架使用
  3. 双塔模型的瓶颈,究竟在哪?
  4. html视频自动播放播放器,支持弹字幕HTML5视频播放器DPlayer
  5. ios 操作通讯录联系人
  6. 动画:二叉树有几种存储方式?(上)
  7. 语音处理工具:sox
  8. 免费和开源引擎的游戏引擎,转载自维基
  9. Efficient Protocols for Set Membership and Range Proof 学习笔记
  10. The credentials mode of request initiated by the XMLHttpRequest is controlled by the withCredentials