转自 log4J 日志信息log4j.properties配置说明

使用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日志信息配置文件详解相关推荐

  1. java log4j基本配置及日志级别配置详解,java基础面试笔试题

    我总结出了很多互联网公司的面试题及答案,并整理成了文档,以及各种学习的进阶学习资料,免费分享给大家. 扫描二维码或搜索下图红色VX号,加VX好友,拉你进[程序员面试学习交流群]免费领取.也欢迎各位一起 ...

  2. Linux日志系统-03:logrotate主配置文件详解

    logrotate主配置文件详解 一.logrotate主配置文件/etc/logrotate.conf # see "man logrotate" for details # r ...

  3. Debian操作系统的源配置信息详解--Source.list配置文件详解

    转载来源:https://wiki.debian.org/SourcesList#Repository_URL Debian操作系统的源配置信息详解--Source.list配置文件详解 Debian ...

  4. logback配置文件详解_Log4j2使用详解

    日志框架简单比较(slf4j.j.u.l.log4j.logback.log4j2 ) slf4j:slf4j是对所有日志框架制定的一种规范.标准.接口,并不是一个框架的具体的实现,因为接口并不能独立 ...

  5. .NET版开源日志框架Log4Net详解

    来源:Yaopengfei 链接:http://www.cnblogs.com/yaopengfei/p/9428206.html 一.Log4Net简介 Log4net是从Java中的Log4j迁移 ...

  6. Elasticsearch基础2——es配置文件、jvm配置文件、log4j2.properties配置文件详解

    文章目录 一.配置文件详解 1.1 elasticsearch.yml文件 1.1. 1 基础参数 1.1.1.1 自定义数据/日志目录 1.1.1.2 锁定物理内存 1.1.1.3 跨域设置 1.1 ...

  7. 【ZooKeeper】配置文件详解

    ZooKeeper的配置文件详解 zkServer.sh读取的默认配置文件是$ZOOKEEPER_HOME/conf/zoo.cfg.如果要用其它配置文件.如下传递配置文件参数: zkServer.s ...

  8. vsftpd配置文件详解

      1.默认配置: 1>允许匿名用户和本地用户登陆.      anonymous_enable=YES      local_enable=YES 2>匿名用户使用的登陆名为ftp或an ...

  9. BIND9配置文件详解模板

    在CU上看到了一篇关于BIND9配置文件详解的文章,感觉不错,现转载了分享一下. //named.conf 注释说明 by shellyxz@163.com // 此文件对bind9的默认配置文件的说 ...

最新文章

  1. Android 生成keystore和ecplise 发布release apk
  2. Python基础教程:3个方面理解Python的类方法与静态方法
  3. unity 半透明混合问题_Unity Shader 透明度混合的双面渲染(十八)
  4. 使用windows命令行查看mySQL应用的安装路径
  5. 在Swift中使用C语言的指针
  6. php this validate,php扩展ZF——Validate扩展
  7. mysql 查询前一个月数据_mysql 查询当天、本周,本月,上一个月的数据......
  8. Android ViewStub
  9. WordPress Citizen Space插件跨站请求伪造漏洞
  10. Flask消息闪现及日志记录
  11. 如何实现用户认证授权系统
  12. 陈纪修老师《数学分析》 第12章:多元函数微分学 笔记
  13. android 远程windows7,将Android手机屏幕快速投影至WIN7的PC和投影仪
  14. C语言-数组-读入学生信息统计各分数段人数并打印
  15. 数据库-SQL Server数据库查询速度慢(连接超时)原因及优化方法
  16. 一级建造师课件下载建筑工程行业会计分录汇总非常全建议收藏!
  17. ubantu下载SSH,使用butty连接自己Windows10和uabntu虚拟机
  18. 中华英才网全年亏损1.75亿 招聘行业不行了?
  19. 微信小程序支付java服务端集成采坑总结
  20. 加载linux驱动模块时,终端提示一堆内存错误

热门文章

  1. 英文文献翻译的几款实用工具
  2. WPF 编程入门 --WPF概述
  3. Android Mms短信的发送流程,短信发送源码解析
  4. 选取单元格区域和选中整个单元格的技巧:
  5. 达梦数据库更换key文件的方法
  6. 市场调研-全球与中国VR和AR光学器件市场现状及未来发展趋势
  7. java inputstream read_Java学习之输入输出流
  8. python 清空表格_python 清空表数据库表
  9. 棋盘覆盖问题——详解(C++)
  10. gerrit 描述信息批量导入导出