内容转自多篇文章:
http://afront.bokee.com/6157060.html
http://blog.csdn.net/lcazxc/archive/2007/06/01/1634743.aspx
一般情况下 Log4j 总是和 Apache Commons-logging 一起用的。
一、Log4j的简单思想
Log4j真的很简单,简单到令人发指的地步。不是要记录日志吗?那就给你一个Log,然后你用Log来写东西就行了,先来一个完整类示例:
举个例子
package test;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
public class Test {
static Log log = LogFactory.getLog (Test. class );
public void log(){
log .debug( "Debug info." );
log .info( "Info info" );
log .warn( "Warn info" );
log .error( "Error info" );
log .fatal( "Fatal info" );
}
public static void main(String[] args) {
Test test = new Test();
test.log();
}
}
ps:要想运行这个程序,需要先部署,详见第三点,在下面
别怕,看完这篇文章你就会觉得很简单了。
Log4j 默认把日志信息分为五个等级(日志可以分为OFF、FATAL、ERROR、WARN、INFO、DEBUG、ALL七个等级)
debug < info < warn < error < fatal
虽然可以自己添加等级,但是我觉得没有必要,五个够用了吧!你要写入信息的时候就把信息归为五个等级中的一个,然后调用相应的函数即可。
分五个等级到底有什么用呢?日志信息到底写到哪里去了?
“ LogFactory.getLog (Test. class ) ”又是什么意思捏?接着往下看吧!
Log4j 的关键之处在于它的继承思想。也就是一个 Log 可以继承另外一个 Log 的属性(输出到哪里,日志等级,日志格式等等)。怎么继承?
Log4j 是根据 Log 的名字来判断继承关系的,比如:
名字为“ com.zhlmmc.lib ”的 Log 就是“ com.zhlmmc.lib.log ”的 parent ,明白了吧! Log4j 还有一个 rootLogger ,相当于 Java 的 Object 。
回过头来看“ LogFactory.getLog (Test. class ) ”这里的“ Test. class ”事实上传进去的是 Test 这个类的完整路径(包名 + 类名),“ test.Test ”。这样如果存在“ test ”这个 Log 那么 Test 这个 Log 就继承它,否则就继承 rootLogger 。
那具体的 Log 属性是在哪里定义的呢?
二、常见的配置文件
虽然可以用 xml 或者在运行时用 Java 来配置 Log4j ,但还是 properties 文件好用啊!
log4j.rootLogger= info, stdout
log4j.appender.stdout= org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout= org.apache.log4j.PatternLayout
# Pattern to output the caller's file name and line number.
log4j.appender.stdout.layout.ConversionPattern= %5p [%t] (%F : %L) - %m%n
分析一下:
第一行,配置 log4j.rootLogger 你明白吧。应为它是根,总得配置一下,否则别的 Log 继承什么啊。其他的 Log 可以配置也可以不配置。等号后面的第一个参数表示日志级别,可以填五个级别中的一种,后面的参数都是让 Log 知道输出到哪里,如果你想让日志输出到两个地方就加两个输出参数,比如:
log4j.rootLogger= info, stdout, file
这里的 info 表示,该 Log 的日志级别为 info ,所有级别小于 info 的日志都不会被记录。比如使用这个配置文件的话,我刚开始举的那个类中
log .debug( "Debug info." );
这句话是不起作用的,因为 debug 的级别小于 info 。这样就很容易控制什么信息在调试的时候要显示,什么信息在发布的时候要去掉。这些都不用改代码,很方便吧。
但, stdout 和 file 又是什么呢?
接着往下看,就是配置 stdout 了,这个名字是随便取的,你可以叫它 A :
log4j.appender.A= org.apache.log4j.ConsoleAppender
那么上面的 rootLogger 的参数 stdout 也要改成 A ,其他用到的地方当然也要改。这里的关键不是名字,而是 appender 类型,比如这里的“ ConsoleAppender ”,看明白了吧,输出到 Console 。后面两行都是设置日志格式的,一般情况下你就照抄吧。既然是最简入门关注于理解 Log4j 的工作原理,我就不介绍 file 类型的 appender 了,一搜一大把。
在实际的项目开发中,很可能遇到所引用的包用 Log4j 来记录日志,比如 Hibernate 。那么在这里你可以很容易的控制这个包如何记录日志。比如在上面的配置文件中加一行:
log4j.logger.org.hibernate= fatal
那么所有 org.hibernate 包下面的类就只会显示很少的信息,因为 fatal 的级别最高啊。
下面写一个配置实例:
第一步、下载log4j-1.2.14.jar文件包,放入lib目录下。
第二步、写配置文件log4j.properties
#指定根Logger,及日志输出级别,大于等于该级别的日志将被输出( DEBUG < INFO < WARN < ERROR < FATAL ) 设为OFF可以关闭日志
log4j.rootLogger=DEBUG, A1,A2
#指定log输出目的,这里设为输出日志到指定目录的文件my.log中
log4j.appender.A1=org.apache.log4j.FileAppender
log4j.appender.A1.File=d:\\my.log
#指定日志信息的格式
log4j.appender.A1.layout=org.apache.log4j.PatternLayout
log4j.appender.A1.layout.ConversionPattern=%r %d{yyyy-MM-dd HH:mm:ss} %c %p -%m%n
#把A2输出到控制台
log4j.appender.A2=org.apache.log4j.ConsoleAppender
log4j.appender.A2.layout=org.apache.log4j.SimpleLayout
#还可以单独指定输出某个包的日志级别
#log4j.logger.com.study.HelloLog4j=INFO
第三步、编写log4j类:
import org.apache.log4j.Logger;
import org.apache.log4j.PropertyConfigurator ;
public class Log4j {
static public Logger logger=Logger.getLogger(Log4j.class.getClass());
public Log4j()
{
//使用配置文件来配置Log4j
PropertyConfigurator.configure ( "D:\\workspace\\addressbook1\\WebRoot\\WEB-INF\\log4j.properties" ) ;
//插入日志信息
logger.info("HelloLog4j开始执行");
}
public Logger getlog(){return Log4j.logger;}
}
第四部、在程序中调用
Log4j log=new Log4j();
log.getlog().info("this is in action");
三、部署
别怕,这可不是部署 Tomcat 。把 log4j 的包和 commons-logging 的包(加在一起才两个)放到 classpath 下面。然后把配置文件保存为 log4j.properties ,也放在 classpath 下面(如果用 Eclipse 的话,放在 src 目录下即可)。然后你就可以跑了。
分享到:
相关推荐
基于MBD开发手册的《Application Modeling Guideline:辅助驾驶系统中的数学模型设计与应用》,Application Modeling Guideline 文档57页 基于MBD开发手册包含: 1. MBD概述:文档可能会介绍MBD的基本概念,解释为什么它在辅助驾驶系统开发中至关重要。 MBD允许工程师使用数学模型来描述系统行为,这有助于早期发现问题,减少硬件原型制作的需求。 2. 工具选择:在辅助驾驶开发中,常用的MBD工具有MATLAB Simulink、MathWorks的Simulink Design Verifier、Vector的CANoe等。 文档可能涵盖这些工具的特点和适用场景,帮助开发者选择合适的工具。 3. 模型设计:MBD的核心是模型设计,文档会详细说明如何创建和组织模型结构,包括输入 输出接口定义、状态机设计、算法实现等。 对于辅助驾驶系统,这可能涉及到视觉处理、传感器融合、路径规划、决策制定等多个模块。 4. 仿真与验证:MBD工具支持动态仿真,开发者可以运行模型以验证其功能。 文档会介绍如何设置仿真条件,进行时序分析,以及如
springboot学生答题练习在线平台,含有完整的源码和报告文档
动力电池用导热硅胶材料研制及性能研究.pdf
2022年12月50430考试真题
输电线路单相接地故障测距:不同短路时刻与位置对双端测距法的影响分析,输电线路单相接地测距 搭建如图1所示的35kV输电网模型,输电侧发电机出口电压10.5kV经过升压变压器变至38.5kV,受电侧经降压变压器降压至6.6kV。输电线路全长100km,架空线路线路正负序参数为:,,,,,。经过计算可得行波线模速度:。通过故障模块设置A相不同短路时刻与过渡电阻发生单相接地,并根据双端行波测距原理进行故障测距,每次设置故障发生点距离首端距离分别为20km、40km、60km、80km,模型仿真步长为秒。 (1)短路时刻对故障测距的影响 分别设置A相电压正峰值、负峰值、过零值以及任意时刻发生单相接地,对应时刻分别为0.0467s、0.0567s、0.0517s和0.0490s,仿真及计算结果入表2-1所示: 由表1可以看出,在使用双端测距方法时,短路时刻对测量结果无影响,只需两侧时钟保持高度同步计时即可。 (2)过渡电阻对故障测距的影响 分别设置A相在任意时刻(0.049s)发生单接地,接地电阻分别为0Ω、10Ω、100Ω、1000Ω,仿真及计算结果入表2所示: 由表2和图4可知,在使用双端
2022年03月C语言六级
2020年09月Scratch一级实操
安装教程: 打开config.php文件,填写自己数据库的名称和密码,再访问域名即可安装 源码简介: 彩虹聚合登录系统源码开心版 一站式社会化账号登录系统 彩虹聚合登录是彩虹旗下的社交账号聚合登录系统,为网站提供一站式社交账号登录选项,包括微信、微博、QQ、百度等账号。简化了用户注册和登录流程,提高了用户在网站的浏览体验,快速增加了网站的注册量和用户数据量。系统还提供完整的开发文档和SDK,方便开发者快速接入。 系统特点 全新的用户中心界面,可以查看整体统计数据和公告。 支持会员级别在线购买,并可根据不同会员级别设置可用的登录方式和账号上限。 方便查看应用统计信息,包括不同登录方式占比、新增账户数、请求数等统计信息。 所有登录的账号都可以清晰显示。 搭建说明: 确保您的PHP 版本为7.1 或更高版本。只需访问域名后跟“/install”即可开始安装。 后台管理地址为“/admin”,默认帐号为“admin”,默认密码为“123456”。 通过使用彩虹聚合登录系统,您可以轻松增加网站用户数量,提高用户注册率,为用户提供更好的登录体验。
TiO2纳米管阵列的制备和应用最新研究进展.pdf
淘宝上买的,分享给大家了,并不是什么值钱的物件。东西还是不错的,带流量主激励广告,电视投屏,分享防封技术场景设置功能等,功能比较多。 安装教程:见压缩包内
2021年03月Python四级理论
CCAA 2016年3月产品认证基础
vivado32位乘法器实现
"探索光子晶体的神秘魅力:揭示能带与光束位移之下的偏振转换与连续域束缚态",光子晶体正入射光束位移; - 复现:2021子刊NC,这里本质上有关于k空间和实空间的对应,很有趣的物理。 - 关键词:光子晶体,能带,远场偏振椭圆分布 (偏振场),连续域束缚态 (BIC),光束位移,偏振转 - 软件:comsol,matlab (也可以不用,可comsol内出图),FDTD (仅用于位移部分,3D大尺寸计算更高效) ,核心关键词:光子晶体; 能带; 远场偏振椭圆分布; 连续域束缚态; 光束位移; 偏振转换; 正入射; k空间; 实空间; comsol; matlab; FDTD。,光子晶体中的能带偏振场与光束位移现象研究
本项目是一款综合运用SpringBoot、Spring、SpringMVC、Nginx、MySQL、MybatisPlus和Redis技术栈构建的点餐系统源码。项目包含206个文件,涵盖71个Java源文件、22个JavaScript文件、21个HTML文件、18个CSS文件、8个XML配置文件、6个字体文件、3个字体格式文件、2个Git忽略文件和2个ICO图标文件,旨在为开发者提供一个实用的练手项目,助力掌握后端开发技能。
2021年09月机器人五级实操
基于富士通单片机控制的VF变频器方案:适应多种功率与电压输出需求,源码及电路原理图齐全,一款纯VF控制的变频器方案方案说明:可做0.2KW7.5KW 220V,0.2KW75KW 380V,富士通MB90F462A LQFP64单片机控制,可提供源码及电路原理图,PCB图 这是一种基于纯VF控制的变频器方案。它可以在220V电压下提供0.2KW到7.5KW的功率输出,或者在380V电压下提供0.2KW到75KW的功率输出。该方案采用了富士通MB90F462A LQFP64单片机进行控制,并且提供了源码、电路原理图和PCB图。 知识点和领域范围: - 变频器:变频器是一种电力电子设备,用于控制交流电机的转速和输出功率。它通过改变输入电压的频率和幅值,实现对电机的调速控制。 - VF控制:VF控制是一种变频器控制方式,通过同时改变电压和频率的比例,实现对电机转速的精确控制。 - 单片机控制:单片机是一种集成电路芯片,具有处理器、存储器和输入输出接口等功能。它可以用于控制和管理各种电子设备,包括变频器。 - 源码:源码是计算机程序的原始代码,通常以文本形式表示。它包含了程序的逻辑
基于YOLOv5技术的实时作弊行为检测,Python和PyCharm结合操作界面的可视化检测新系统,基于YOLOv5的作弊行为检测系统,Python和pycharm实现,可实时检测,有方便操作的图形化界面 ,核心关键词:基于YOLOv5; 作弊行为检测系统; Python和pycharm实现; 实时检测; 方便操作的图形化界面。,"基于YOLOv5的实时作弊检测系统:Python与PyCharm的图形化界面实现"
2023年03月Scratch二级理论
MFI沸石分子筛膜研究进展.pdf