log4cxx
2020-09-23 09:56:23 0 举报
AI智能生成
log4cxx 使用教程
作者其他创作
大纲/内容
编译安装
1. 编译安装 apr-1.7.0
tar zxvf apr-1.7.0.tar.gz<br>cd apr-1.7.0<br>./configure && make && make install
2. 编译安装apr-util-1.6.1
tar zxvf apr-util-1.6.1.tar.gz<br>cd apr-util-1.6.1<br>./configure --with-apr=/usr/local/apr && make && make install
3. 编译安装 log4cxx
unzip logging-log4cxx-master.zip<br>cd logging-log4cxx-master<br>./autogen.sh && ./configure && make && make install
组件介绍
记录器:Loggers
特点
Logger是有一个String类的名字识别的,且大小写敏感
名字之间具有继承关系,其中,子名有父名做前缀,用"."分隔。<br> 如, x.y是x.y.z的父名
root logger是所有logger的祖先,是一直存在的,<br> 通过Logger.getRootLogger()获得,并且不能通过名字获得
public static Logger Logger.getLogger(String name)<br> 获得或者创建一个Logger
日志级别
每个logger都被分配了一个日志级别(log level),用来控制日志信息的输出
未被分配level的logger可以继承它最近的父logger的level。<br> 若父logger也没有设置level,则将继承root logger的level
每条输出到logger的日志请求(logging request)也都有一个level,如LOG4CXX_DEBUG
如果logging request的level大于等于该logger的level,则该request将被处理,否则将被忽略<br> eg. logger的level是ERROR,request的level是DEBUG,则request的内容不会在日志中输出。<br> 但若request的level是ERROR,则会在日志中输出
所有的logger level及大小关系:<br> Level.ALL < Level.DEBUG < Level.INFO < Level.WARN < Level.ERROR < Level.FATAL < Level.OFF
输出源:Appenders
把日志输出到不同地方,如控制台、文件等,根据天数或文件大小产生新的文件,再或者可以以流的形式发送到其他地方等。
常见类
org.apache.log4j.ConsoleAppender (控制台)
org.apache.log4j.FileAppender (文件)
org.apache.log4j.DailyRollingFileAppender(每天产生一个日志文件)
org.apache.log4j.RollingFileAppender (文件大小达到指定尺寸时产生一个新的文件)
org.apache.log4j.WriterAppender (将日志信息以流格式发送到任意指定的地方)
配置模式
log4j.appender.appenderName = className<br>log4j.appender.appenderName.Option1 = value1<br>...<br>log4j.appender.appenderName.optionN = valueN
配置模式实例
log4j.rootLogger=INFO,stdout<br>log4j.appender.stdout=org.apache.log4j.ConsoleAppender<br>log4j.appender.stdout.Target=System.out<br>log4j.appender.stdout.layout=org.apache.log4j.PatternLayout<br>log4j.appender.stdout.layout.ConversionPattern=%d{ABSOLUTE} %5p %c{1}:%L - %m%n
appender的option解析
ConsoleAppender
Threshold = WARN : 指定日志信息的最低输出级别,默认为DEBUG<br>ImmediateFlush = true : 表示所有消息都被立即输出,设为false则不输出, 默认值为true<br>Target = System.err : 默认值是System.out
FileAppender
Threshold = WARD <br>ImmediateFlush = true<br>Append = false : true表示消息增加到指定文件中,false则将消息覆盖指定的文件内容,默认值是true<br>File = D:/logs/logging.log4j : 指定消息输出的文件目录名
DailyRollingFileAppender
Threshold = WARD <br>ImmediateFlush = true<br>Append = false<br>File = D:/logs/logging.log4j<br>DatePattern = '.'yyyy-MM : 每个月生成一个新的日志文件<br> '.'yyyy-ww : 每周<br> '.'yyyy-MM-dd:每天<br> '.'yyyy-MM-dd-a:每天2次<br> '.'yyyy-MM-dd-HH:每小时<br> '.'yyyy-MM-dd-HH-mm : 每分钟
RollingFileAppender
Threshold = WARD <br>ImmediateFlush = true<br>Append = false<br>File = D:/logs/logging.log4j<br>MaxFileSize = 100KB :文件达到该大小时,会自动滚动,即将原来的内容移到logging.log4j.1文件中<br>MaxBackupIndex = 2 : 指定可以产生滚动文件的最大数,例如,设为2则可以产生logging.log4j.1, logging.log4j.2两个滚动文件和一个log
布局(输出格式):layout
有时用户希望自定义日志输出格式,log4j.appender.appenderName后附加layouts来完成。
Layouts提供四种日志输出格式:
1. HTML样式 : org.apache.log4j.HTMLLayout
LocaltionInfo = true : 输出java文件名和行号,默认值是false<br>Title = My Logging : 默认值是Log4j Log Messages
2. 自由指定样式:org.apache.log4j.PatternLayout
ConversionPattern = %m%n : 设定以怎样的格式显示消息
格式化符号说明:<br><br>%p: 输出日志信息的优先级,即DEBUG,INFO,WARN,ERROR,FATAL<br>%d: 输出日志时间点的日期或时间,默认格式为ISO8601,也可以指定格式,eg.%d{yyyy/MM/dd HH:mm:ss,SSS}。<br>%r: 输出自应用程序启动到输出到该log信息耗费额毫秒数<br>%t: 输出产生该日志事件的线程名<br>%l: 输出日志事件的发生位置,相当于%c.%M(%F:%L)的组合,包括类全名、方法、文件名及在代码行中的行数。<br> eg.test.TestLog4j.main(TestLog4j.java:10)。<br>%c: logger所属类的全名,最小长度是20,若名称长度小于20,默认右对齐。<br>%M: 输出产生日志信息的方法名<br>%F: 输出日志消息产生时所在的文件名称<br>%L: 输出代码中的行号<br>%m:输出logger的日志消息,eg.LOG4CXX_DEBUG(m_logger,"日志消息")<br>%n:输出一个回车换行符,windows平台为"\r\n",Unix平台为"\n"<br>%x: 输出和当前线程相关联的NDC(嵌套诊断环境),尤其用到像java servlets这样的多客户多线程的应用中<br>%%:输出一个"%"字符<br><br>另外,还可以在%与格式字符之间加上修饰符,来控制器最小长度、最大长度、文本对齐方式。如:<br>1) %-20c : "-"号表示左对齐<br>2) %.30c : 指定%c最大长度为30,若大于30,会将左边多出来的字符截掉,但小于30也不会补空格<br>
3. 包含日志级别和信息字符串的样式: org.apache.log4j.SimpleLayout
4. 包含日志产生的时间、线程、类别等信息:org.apache.log4j.TTCCLayout
Layouts使用实例
log4j.appender.appenderName.layout = className<br>log4j.appender.appenderName.layout.Option1 = value1<br>...<br>log4j.appender.appenderName.layout.OptionN = valueN
配置文件详解
1. 配置root logger
log4j.rootLogger = [level],appenderName1,appenderName2,...
**level**: 设定日志记录的最低级别,可设的值有OFF、FATAL、ERROR、WARN、INFO、DEBUG、ALL或者自定义的级别。<br>**appenderName**:就是指日志信息要输出到哪里,可以同时指定多个输出目的,用逗号隔开,appenderName可以自定义。<br><br> eg. log4j.rootLogger=INFO,A1,B2,C3<br>
提示
log4j.logger.cn.com.Test = DEBUG,test<br>log4j.appender.test=org.apache.log4j.FileAppender<br>log4j.appender.test.File=${myweb.root}/WEB-INF/log/test.log<br>log4j.appender.test.layout=org.apache.log4j.PatternLayout<br>log4j.appender.test.layout.ConversionPattern=%d %p [%c] - %m%n<br><br>这是对名字为cn.com.Test的logger进行配置,从原有日志中分离,形成单独的日志文件<br>
2. 使用多个logger,并配置在一个配置文件中
1. log4cxx库对日志流设置,只需要更改配置文件中的appender属性<br>2. log4cxx支持Logger继承机制,但由于要将日志流输出到多个文件,需要在配置文件中,将子Logger的继承属性设置为false
// 假设子logger的name为childLogger<br><br>// 在配置文件中定义一个子logger的代码,apname为childlogger使用的appender<br>log4j.logger.childLogger = DEBUG,apname <br><br>// 设置子logger的继承属性设置为false<br>log4j.additivity.childLogger = false<br><br>// 设置子logger所使用的日志文件<br>log4j.appender.apname.File = ./0.log
3. 特别的appender应用
应用于socket
log4j.appender.socket=org.apache.log4j.RollingFileAppender<br>log4j.appender.socket.RemoteHost=localhost<br>log4j.appender.socket.Port=5001<br>log4j.appender.socket.LocationInfo=true
发送日志到指定邮件
log4j.appender.mail=org.apache.log4j.net.SMTPAppender<br>log4j.appender.mail.Threshold=FATAL<br>log4j.appender.mail.BufferSize=10<br>log4j.appender.mail.From = xxx@mail.com<br>log4j.appender.mail.SMTPHost=mail.com<br>log4j.appender.mail.Subject=Log4J Message<br>log4j.appender.mail.To= xxx@mail.com<br>log4j.appender.mail.layout=org.apache.log4j.PatternLayout<br>log4j.appender.mail.layout.ConversionPattern=[%-5p] %d(%r) --> [%t] %l: %m %x %n
应用于数据库
log4j.appender.database=org.apache.log4j.jdbc.JDBCAppender<br>log4j.appender.database.URL=jdbc:mysql://localhost:3306/test<br>log4j.appender.database.driver=com.mysql.jdbc.Driver<br>log4j.appender.database.user=root<br>log4j.appender.database.password=<br>log4j.appender.database.sql=INSERT INTO LOG4J (Message) VALUES('=[%-5p] %d(%r) --> [%t] %l: %m %x %n')<br>log4j.appender.database.layout=org.apache.log4j.PatternLayout<br>log4j.appender.database.layout.ConversionPattern=[%-5p] %d(%r) --> [%t] %l: %m %x %n
自定义Appender
log4j.appender.im = net.cybercorlin.util.logger.appender.IMAppender<br>log4j.appender.im.host = mail.cybercorlin.net<br>log4j.appender.im.username = username<br>log4j.appender.im.password = password<br>log4j.appender.im.recipient = corlin@cybercorlin.net<br>log4j.appender.im.layout=org.apache.log4j.PatternLayout<br>log4j.appender.im.layout.ConversionPattern=[%-5p] %d(%r) --> [%t] %l: %m %x %n
0 条评论
下一页