log4j系统日志

 

log4j的日志配置

 

1.  配置记录器(logger)

 

    Log4j的记录器包含两种,一个根记录器它必须且永远存在,且不能通过名字检索或引用,在配置文件中,根记录器定义方法如下:

 

  log4j.rootLogger = [ level ] , appenderName, appenderName,

 

注:Level是记录器的级别,它是日志记录的优先级,分为OFFFATALERRORWARNINFODEBUGALL或者您定义的级别。Log4j建议只使用四个级别:ERRORWARNINFODEBUG( DEBUG < INFO < WARN < ERROR < FATAL)

 

如果一条log信息的级别,大于等于记录器的级别值,那么记录器就会记录它。例如level被设置为INFO级别,那么应用程序中所有的DEBUG的日志信息将不被打印出来。通过在这里定义的级别,您可以控制到应用程序中相应级别的日志信息的开关。

 

    appenderName是输出源的名字,它指定日志信息输出到哪个地方。您可以为一个记录器指定多个输出源。

 

 

 

配置日志信息输出(Appender)
    log4j 还允许日志记录请求打印到多个输出目的地,按 log4j 的叫法是输出源。一个记录器可以有多个输出源。一条log信息如果可被这个记录器处理,则该记录器会把这条信息送往每个它所拥有的输出源,以及层次结构中更高级的输出源。例如,根记录器以控制台作为输出源,则所有可被纪录的日志都将至少打印到控制台。

 

配置日志信息输出源,其语法如下:
log4j.appender.appenderName = fully.qualified.name.of.appender.class
      log4j.appender.appenderName.option1 = value1   …   
log4j.appender.appenderName.option = valueN

 

Log4j提供的appender有以下几种 

 

org.apache.log4j.ConsoleAppender控制台

 

org.apache.log4j.FileAppender文件 

 

org.apache.log4j.DailyRollingFileAppender每天产生一个日志文件

 

org.apache.log4j.RollingFileAppender(文件大小到达指定尺寸的时候产生一个新的)

 

org.apache.log4j.WriterAppender将日志信息以流格式发送到任意指定的地方 

 

org.apache.log4j.SocketAppender (Socket)

 

org.apache.log4j.NtEventLogAppender   (NTEvent Log) 

 

org.apache.log4j.JMSAppender   (电子邮件

 

2.  配置日志信息的格式(layout)

 

其语法如下:

 

log4j.appender.appenderName.layout = fully.qualified.name.of.layout.class       log4j.appender.appenderName.layout.option1 = value1   …     log4j.appender.appenderName.layout.option = valueN

 

其中,Log4j提供的layout包含以下几种:

 

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

 

org.apache.log4j.PatternLayout(可以灵活地指定布局模式)

 

org.apache.log4j.SimpleLayout(包含日志信息的级别和信息字符串)

 

org.apache.log4j.TTCCLayout(包含日志产生的时间、线程、类别等等信息)

 

如果采用了PatternLayout, Log4J采用类似C语言中的printf函数的打印格式格式化日志信息,打印参数如下:

 

%m 输出代码中指定的消息

 

%p 输出优先级,即DEBUGINFOWARNERRORFATAL 

 

%r 输出自应用启动到输出该log信息耗费的毫秒数 

 

%c 输出所属的类目,通常就是所在类的全名 

 

%t 输出产生该日志事件的线程名 

 

%n 输出一个回车换行符,Windows平台为“\r\n”,Unix平台为“\n

 

%d 输出日志时间点的日期或时间,默认格式为ISO8601,也可以在其后指定格式,比如:%d{yyy MMM dd HH:mm:ss,SSS},输出类似:20021018 221028921 

 

%l 输出日志事件的发生位置,包括类目名、发生的线程,以及在代码中的行数。

 

 

 

例子:建一个名为demo数据库,建一个表T_Syslog。如下: 

 

if exists (select * from dbo.sysobjects where id = object_id(N'[dbo].[T_Syslog]') and OBJECTPROPERTY(id, N'IsUserTable') = 1)
drop table [dbo].[T_Syslog]
GO

CREATE TABLE [dbo].[T_Syslog] (
	[syslogID] [numeric](18, 0) IDENTITY (1, 1) NOT NULL ,
	[logType] [varchar] (10) COLLATE Chinese_PRC_CI_AS NULL ,
	[menuCode] [varchar] (50) COLLATE Chinese_PRC_CI_AS NULL ,
	[content] [varchar] (1000) COLLATE Chinese_PRC_CI_AS NULL ,
	[uDate] [datetime] NOT NULL 
) ON [PRIMARY]
GO

 

log4j.properties

 

log4j.rootLogger=info,db,logone
#日志输出到控制台
log4j.appender.logone=org.apache.log4j.ConsoleAppender
log4j.appender.logone.layout=org.apache.log4j.PatternLayout
#日志的输出格式
log4j.appender.logone.layout.ConversionPattern=%d{yy-MM-dd HH\:mm\:ss} %5p %c{1}\:%L - %m%n 

#每天生成一个新的日志
log4j.appender.db=org.apache.log4j.DailyRollingFileAppender
#路径
log4j.appender.db.File=/logs/syslog.log
log4j.appender.db.Append = true
log4j.appender.db.layout=org.apache.log4j.PatternLayout
#日志的输出格式
log4j.appender.db.layout.ConversionPattern=%d{yyyy.MM.dd HH\:mm\:ss} %p %c{1}(%L)\:? %m%n 

#配置数据源
log4j.appender.db=org.apache.log4j.jdbc.JDBCAppender
log4j.appender.logFtwo.BufferSize=10  
log4j.appender.db.driver=com.microsoft.sqlserver.jdbc.SQLServerDriver
log4j.appender.db.URL=jdbc:sqlserver://192.168.0.116:1433;databaseName=market
log4j.appender.db.user=sa
log4j.appender.db.password=sa
#将日志写入数据库
log4j.appender.db.sql=insert into T_Syslog (menuCode,logType,content) values ('%c','%p','%l,%m')

Log4jUtil.java

import org.apache.log4j.Logger;


public class Log4jUtil{
	private static Logger log=Logger.getLogger(Log4jUtil.class.getClass());
	public static void main(String[] args) {
		log.debug("12312321321");
		log.info("1231");
		log.error("1231231");
	}
}

 

 

 

 

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值