log4j简介,应用,配置,举例,具体编程方法。。。不定期更新综合帖

简介:

日志(log):

  1. 主要用来记录系统运行中一些重要操作信息
  2. 便于监视系统运行情况,帮助用户提前发现和避开可能出现的问题,或者出现问题后根据日志找到原因

日志分类:SQL日志、异常日志、业务日志

log4j是一个非常优秀的开源日志记录工具

  1. 控制日志的输出级别
  2. 控制日志信息输送的目的地是控制台、文件等
  3. 控制每一条日志的输出格式

使用log4j记录日志步骤:

1. 在项目中加入log4j的JAR文件 ---》 2. 创建log4j.properties文件 ---》 3. 配置日志信息 ---》 4. 使用log4j记录日志信息

 log4j简介:

log4j是Apache的一个开放源代码项目,通过使用log4j,我们可以控制日志信息输送的目的地是控制台、文件、GUI组件、甚至是套接口服务 器、NT的事件记录器、UNIX Syslog守护进程等;我们也可以控制每一条日志的输出格式;通过定义每一条日志信息的级别,我们能够更加细致地控制日志的生成过程。最令人感兴趣的就 是,这些可以通过一个配置文件来灵活地进行配置,而不需要修改应用的代码。

此外,通过log4j其他语言接口,您可以在C、C+ +、.Net、PL/SQL程序中使用log4j,其语法和用法与在Java程序中一样,使得多语言分布式系统得到一个统一一致的日志组件模块。而且,通 过使用各种第三方扩展,您可以很方便地将log4j集成到J2EE、JINI甚至是SNMP应用中。

log4j有三个主要的组件:Loggers(记录器),Appenders(输出源)和Layouts(布局),这里可简单理解为日志类别,日志要输出的地方和日志以何种形式输出。综合使用这三个组件可以轻松的记录信息的类型和级别,并可以在运行时控制日志输出的样式和位置。下面对三个组件分别进行说明:
  

1、 Loggers
   Loggers组件在此系统中被分为五个级别:DEBUG、INFO、WARN、ERROR和FATAL。这五个级别是有顺序的,DEBUG < INFO < WARN < ERROR < FATAL,分别用来指定这条日志信息的重要程度,明白这一点很重要,这里log4j有一个规则:假设Loggers级别为P,如果在Loggers中发生了一个级别Q比P高,则可以启动,否则屏蔽掉。
假设你定义的级别是info,那么error和warn的日志可以显示而比他低的debug信息就不显示了。
  

Java程序举例来说:  
//建立Logger的一个实例,命名为“com.foo”
   Logger logger = Logger.getLogger("com.foo"); //"com.foo"是实例进行命名,也可以任意
//设置logger的级别。通常不在程序中设置logger的级别。一般在配置文件中设置。
  logger.setLevel(Level.INFO);
  Logger barlogger = Logger.getLogger("com.foo.Bar");

//下面这个请求可用,因为WARN >= INFO
  logger.warn("Low fuel level.");
//下面这个请求不可用,因为DEBUG < INFO
  logger.debug("Starting search for nearest gas station.");
//命名为“com.foo.bar”的实例barlogger会继承实例“com.foo”的级别。因此,下面这个请求可用,因为INFO >= INFO
  barlogger.info("Located nearest gas station.");
//下面这个请求不可用,因为DEBUG < INFO
  barlogger.debug("Exiting gas station search");
这里“是否可用”的意思是能否输出Logger信息。
  在对Logger实例进行命名时,没有限制,可以取任意自己感兴趣的名字。一般情况下建议以类的所在位置来命名Logger实例,这是目前来讲比较有效的Logger命名方式。这样可以使得每个类建立自己的日志信息,便于管理。比如:
  static Logger logger = Logger.getLogger(ClientWithLog4j.class.getName());
  

2、Appenders
  禁用与使用日志请求只是log4j其中的一个小小的地方,log4j日志系统允许把日志输出到不同的地方,如控制台(Console)、文件(Files)、根据天数或者文件大小产生新的文件、以流的形式发送到其它地方等等。
  
其语法表示为:  
  org.apache.log4j.ConsoleAppender(控制台)
  org.apache.log4j.FileAppender(文件)
  org.apache.log4j.DailyRollingFileAppender(每天产生一个日志文件)
        org.apache.log4j.RollingFileAppender(文件大小到达指定尺寸的时候产生一个新的文件)
  org.apache.log4j.WriterAppender(将日志信息以流格式发送到任意指定的地方)
  
  配置时使用方式为:
  log4j.appender.appenderName = fully.qualified.name.of.appender.class
  log4j.appender.appenderName.option1 = value1
  …
        log4j.appender.appenderName.option = valueN
  这样就为日志的输出提供了相当大的便利。
  
3、Layouts
    这时用户希望根据自己的喜好格式化自己的日志输出。log4j可以在Appenders的后面附加Layouts来完成这个功能。Layouts提供了 四种日志输出样式,如根据HTML样式、自由指定样式、包含日志级别与信息的样式和包含日志时间、线程、类别等信息的样式等等。
  
其语法表示为:  
  org.apache.log4j.HTMLLayout(以HTML表格形式布局),
  org.apache.log4j.PatternLayout(可以灵活地指定布局模式),
  org.apache.log4j.SimpleLayout(包含日志信息的级别和信息字符串),
  org.apache.log4j.TTCCLayout(包含日志产生的时间、线程、类别等等信息)
  
配置时使用方式为: 
  log4j.appender.appenderName.layout =fully.qualified.name.of.layout.class
  log4j.appender.appenderName.layout.option1 = value1
  …
  log4j.appender.appenderName.layout.option = valueN

log4j配置文件的基本格式:

#配置根Logger
log4j.rootLogger  =   [ level ]   ,  appenderName1 ,  appenderName2 ,  …

#配置日志信息输出目的地Appender
log4j.appender.appenderName  =  fully.qualified.name.of.appender.class 
log4j.appender.appenderName.option1  =  value1 
… 
log4j.appender.appenderName.optionN  =  valueN 

#配置日志信息的格式(布局)
log4j.appender.appenderName.layout  =  fully.qualified.name.of.layout.class 
log4j.appender.appenderName.layout.option1  =  value1 
… 
log4j.appender.appenderName.layout.optionN  =  valueN 

 [level] 为日志输出级别共有5级:

FATAL         0  
ERROR      3  
WARN        4  
INFO          6  
DEBUG      7 

日志记录器输出级别:fatal > error > warn > info >debug

Appender 为日志输出目的地,log4j提供的appender有:

org.apache.log4j.ConsoleAppender(控制台),
org.apache.log4j.FileAppender(文件),
org.apache.log4j.DailyRollingFileAppender(每天产生一个日志文件),
org.apache.log4j.RollingFileAppender(文件大小到达指定尺寸的时候产生一个新的文件),
org.apache.log4j.WriterAppender(将日志信息以流格式发送到任意指定的地方)

Layout为日志输出格式,log4j的layout有:

org.apache.log4j.HTMLLayout(以HTML表格形式布局),

org.apache.log4j.PatternLayout(可以灵活地指定布局模式),
org.apache.log4j.SimpleLayout(包含日志信息的级别和信息字符串),
org.apache.log4j.TTCCLayout(包含日志产生的时间、线程、类别等等信息)

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},输出类似:2002年10月18日  2002 : 10 : 28 , 921  
%l   输出日志事件的发生位置,包括类目名、发生的线程,以及在代码中的行数。

举例:Testlog4.main(TestLog4.java: 10 ) 

例如我们可以编写如下的例子:

### 设置Logger输出级别和输出目的地 ###

log4j.rootLogger=debug, stdout,logfile

### 把日志信息输出到控制台 ###

log4j.appender.stdout=org.apache.log4j.ConsoleAppender

log4j.appender.stdout.Target=System.err

log4j.appender.stdout.layout=org.apache.log4j.SimpleLayout

### 把日志信息输出到文件jbit.log ###

log4j.appender.logfile=org.apache.log4j.FileAppender

log4j.appender.logfile.File=jbit.log

log4j.appender.logfile.layout=org.apache.log4j.PatternLayout

log4j.appender.logfile.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %l %F %p %m%n

实际应用:

public class Age {
	int age;

	public int getAge() {
		return age;
	}

	public void setAge(int age)throws AgeException{
		if(age>=1&&age<=100){
			this.age=age;
			System.out.println("您的年龄为:"+this.age);
		}else{
			throw new AgeException("年龄必须在1到100之间!");
		}
	}
}


public class AgeException extends Exception{
	public AgeException(){}
	public AgeException(String message){
		super(message);
	}
}


public class Test {
	public static void main(String[] args) {
		Age a=new Age();
		Logger logger=Logger.getLogger("com.ppp");
		PropertyConfigurator.configure("log4j.properties");
		Scanner input=new Scanner(System.in);
		System.out.println("请您输入您的年龄:");
		try{
			int age=input.nextInt();
			a.setAge(age);		
		}catch(AgeException e){
	//		e.printStackTrace();
			logger.debug(e);
		}
	}
}

该例子的log4j配置文件:

### 设置Logger输出级别和输出目的地 ###
log4j.rootLogger=debug, stdout,logfile

### 把日志信息输出到控制台 ###
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.Target=System.err
log4j.appender.stdout.layout=org.apache.log4j.HTMLLayout

### 把日志信息输出到文件:jbit.log ###
log4j.appender.logfile=org.apache.log4j.FileAppender
log4j.appender.logfile.File=jbit.log
log4j.appender.logfile.layout=org.apache.log4j.PatternLayout
log4j.appender.logfile.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss}%l %F %p %m%n

当输出到控制台的日志输出格式为HTMLLayout时输出的异常信息为:

 当输出到文件的日志输出格式为PatternLayout时输出的异常信息为:

猜你喜欢

转载自blog.csdn.net/baidu_29343517/article/details/81192938