• log4j配置


    记录一下log4j基础配置

    一:基础配置参数

    每个Logger都被了一个日志级别(log level),用来控制日志信息的输出。日志级别从高到低分为:
    A:off 最高等级,用于关闭所有日志记录。
    B:fatal 指出每个严重的错误事件将会导致应用程序的退出。
    C:error 指出虽然发生错误事件,但仍然不影响系统的继续运行。
    D:warm 表明会出现潜在的错误情形。
    E:info 一般和在粗粒度级别上,强调应用程序的运行全程。
    F:debug 一般用于细粒度级别上,对调试应用程序非常有帮助。
    G:all 最低等级,用于打开所有日志记录。
    
    上面这些级别是定义在org.apache.log4j.Level类中。Log4j只建议使用4个级别,优先级从高到低分别是error,warn,info和debug。
    通过使用日志级别,可以控制应用程序中相应级别日志信息的输出。例如,如果使用b了info级别,则应用程序中所有低于info级别的日志信息(如debug)将不会被打印出来。
    
    appender
    org.apache.log4j.ConsoleAppender(控制台),  
    org.apache.log4j.FileAppender(文件),  
    org.apache.log4j.DailyRollingFileAppender(每天产生一个日志文件),  
    org.apache.log4j.RollingFileAppender(文件大小到达指定尺寸的时候产生一个新的文件),  
    org.apache.log4j.WriterAppender(将日志信息以流格式发送到任意指定的地方)
    实现自定义Appender继承AppenderSkeleton
    
    Log4J最常用的日志输出格式为:org.apache.log4j.PatternLayOut,其主要参数为:
    
        %n - 换行
        %m - 日志内容
        %p - 日志级别(FATAL, ERROR,WARN, INFO,DEBUG or custom)
        %r - 程序启动到现在的毫秒数
        %t - 当前线程名
        %d - 日期和时间, 一般使用格式 %d{yyyy-MM-dd HH:mm:ss, SSS}
        %l - 输出日志事件的发生位置, 同 %F%L%C%M
        %F - java 源文件名
        %L - java 源码行数
        %C - java 类名,%C{1} 输出最后一个元素
        %M - java 方法名
        
    日志信息格式中几个符号所代表的含义:
    -X号: X信息输出时左对齐;  
    %p: 输出日志信息优先级,即DEBUG,INFO,WARN,ERROR,FATAL,  
    %d: 输出日志时间点的日期或时间,默认格式为ISO8601,也可以在其后指定格式,比如:%d{yyy MMM dd HH:mm:ss,SSS},输出类似:2002年10月18日 22:10:28,921  
    %r: 输出自应用启动到输出该log信息耗费的毫秒数  
    %c: 输出日志信息所属的类目,通常就是所在类的全名  
    %t: 输出产生该日志事件的线程名  
    %l: 输出日志事件的发生位置,相当于%C.%M(%F:%L)的组合,包括类目名、发生的线程,以及在代码中的行数。举例:Testlog4.main (TestLog4.java:10)  
    %x: 输出和当前线程相关联的NDC(嵌套诊断环境),尤其用到像java servlets这样的多客户多线程的应用中。  
    %%: 输出一个"%"字符  
    %F: 输出日志消息产生时所在的文件名称  
    %L: 输出代码中的行号  
    %m: 输出代码中指定的消息,产生的日志具体信息  
    %n: 输出一个回车换行符,Windows平台为"/r/n",Unix平台为"/n"输出日志信息换行  
    可以在%与模式字符之间加上修饰符来控制其最小宽度、最大宽度、和文本的对齐方式。如:  
    1)%20c:指定输出category的名称,最小的宽度是20,如果category的名称小于20的话,默认的情况下右对齐。  
    2)%-20c:指定输出category的名称,最小的宽度是20,如果category的名称小于20的话,"-"号指定左对齐。  
    3)%.30c:指定输出category的名称,最大的宽度是30,如果category的名称大于30的话,就会将左边多出的字符截掉,但小于30的话也不会有空格。  
    4)%20.30c:如果category的名称小于20就补空格,并且右对齐,如果其名称长于30字符,就从左边较远输出的字符截掉。
    

     二:log4j.properties

    log4j.rootLogger = stdout,debug,info,warn,error,jdbc,source
    
    
    log4j.appender.stdout=org.apache.log4j.ConsoleAppender
    log4j.appender.stdout.Target=System.out
    log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
    log4j.appender.stdout.layout.ConversionPattern= [%5p] [BYSXXGLXT] %d{yyyy-MM-dd HH:mm:ss}: %-4r [%-5p] [%t] ( %F,%L ) - %m%n
    
    log4j.appender.debug = org.apache.log4j.DailyRollingFileAppender
    log4j.appender.debug.File = log/debug.log
    log4j.appender.debug.Append = true
    log4j.appender.debug.Threshold = DEBUG 
    log4j.appender.debug.layout = org.apache.log4j.PatternLayout
    log4j.appender.debug.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss}  [ %t:%r ] - [ %p ]  %m%n
    
    log4j.appender.info = org.apache.log4j.DailyRollingFileAppender
    log4j.appender.info.File = log/info.log
    log4j.appender.info.Append = true
    log4j.appender.info.Threshold = INFO 
    log4j.appender.info.layout = org.apache.log4j.PatternLayout
    log4j.appender.info.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss}  [ %t:%r ] - [ %p ]  %m%n
    
    
    log4j.appender.warn = org.apache.log4j.DailyRollingFileAppender
    log4j.appender.warn.File = log/warn.log
    log4j.appender.warn.Append = true
    log4j.appender.warn.Threshold = WARN
    log4j.appender.warn.layout = org.apache.log4j.PatternLayout
    log4j.appender.warn.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss}  [ %t:%r ] - [ %p ]  %m%n
    
    log4j.appender.error = org.apache.log4j.DailyRollingFileAppender
    log4j.appender.error.File = log/error.log
    log4j.appender.error.Append = true
    log4j.appender.error.Threshold = ERROR 
    log4j.appender.error.layout = org.apache.log4j.PatternLayout
    log4j.appender.error.layout.ConversionPattern = %d{yyyy MMM dd HH:mm:ss} %-5p %c - %m%n 
    
    #JDBC
    #log4j.appender.jdbc=org.apache.log4j.jdbc.JDBCAppender
    #log4j.appender.jdbc.driver=com.mysql.jdbc.Driver
    #log4j.appender.jdbc.URL=jdbc:mysql://127.0.0.1:3306/test?characterEncoding=utf8&useSSL=true&serverTimezone=UTC
    #log4j.appender.jdbc.user=root
    #log4j.appender.jdbc.password=
    #log4j.appender.jdbc.sql=insert into log_info(level,category,thread,time,location,note) values('%p','%c','%t','%d{yyyy-MM-dd HH:mm:ss:SSS}','%l','%m')
    
    log4j.appender.source=com.jachs.log4j.datasource.DataSourceAppender
    log4j.appender.source.dataSource=dbcp
    log4j.appender.source.configerfile=/dbcp.properties
    #log4j.appender.source.dataSource=c3p0
    #log4j.appender.source.configerfile=/c3p0.properties
    log4j.appender.source.sql=insert into log_info(level,category,thread,time,location,note) values(?,?,?,?,?,?)
    log4j.appender.source.layout = org.apache.log4j.PatternLayout
  • 相关阅读:
    npm 常用指令
    跨域详解
    模板
    Set-Cookie
    哈佛大学公开课 幸福课 积极心理学
    Token Authentication vs. Cookies
    Using Cookieless Forms Authentication Tickets
    What Is Token-Based Authentication and Who Uses It?
    Types of authentication wiz. oauth, digest, basic, token-based
    Session Authentication vs Token Authentication
  • 原文地址:https://www.cnblogs.com/zhanchaohan/p/14690563.html
Copyright © 2020-2023  润新知