美文网首页
log4j配置

log4j配置

作者: Pecksniff1994 | 来源:发表于2019-07-30 14:55 被阅读0次

    使用log4j 记录日志甚是方便,其提供了两种日志配置方式,log4j.propertes和log4j.xml,这篇文件先贴出log4j.properties配置方式

    1、log4j.properties文件配置简析

    ##logger是进行记录的主要类,appender是记录的方式,layout是记录的格式
    
    #Logger - 日志写出器,供程序员输出日志信息 
    #Appender - 日志目的地,把格式化好的日志信息输出到指定的地方去 
    #ConsoleAppender - 目的地为控制台的Appender 
    #FileAppender - 目的地为文件的Appender 
    #RollingFileAppender - 目的地为大小受限的文件的Appender 
    #Layout - 日志格式化器,用来把程序员的logging request格式化成字符串 
    #PatternLayout - 用指定的pattern格式化logging request的Layou
    
    #Log4j提供的appender有以下几种:
    #  org.apache.log4j.ConsoleAppender(控制台),
    #  org.apache.log4j.FileAppender(文件),
    #  org.apache.log4j.DailyRollingFileAppender(每天产生一个日志文件),
    #  org.apache.log4j.RollingFileAppender(文件大小到达指定尺寸的时候产生一个新的文件),
    #  org.apache.log4j.WriterAppender(将日志信息以流格式发送到任意指定的地方)
    
    #Log4j提供的layout有以下几种:
    #  org.apache.log4j.HTMLLayout(以HTML表格形式布局),
    #  org.apache.log4j.PatternLayout(可以灵活地指定布局模式),
    #  org.apache.log4j.SimpleLayout(包含日志信息的级别和信息字符串),
    #  org.apache.log4j.TTCCLayout(包含日志产生的时间、线程、类别等等信息)
    
    #Log4J采用类似C语言中的printf函数的打印格式格式化日志信息,打印参数如下
    #    %m 输出代码中指定的消息
    #    %M 输出日志发生的方法名
    #  %p 输出优先级,即DEBUG,INFO,WARN,ERROR,FATAL
    #  %r 输出自应用启动到输出该log信息耗费的毫秒数
    #  %c 输出所属的类目,通常就是所在类的全名
    #  %t 输出产生该日志事件的线程名
    #  %n 输出一个回车换行符,Windows平台为“rn”,Unix平台为“n”
    #  %d 输出日志时间点的日期或时间,默认格式为ISO8601,也可以在其后指定格式,比如:%d{yyyy MMM dd HH:mm:ss,SSS},输出类似:2002年10月18日 22:10:28,921
    #  %l 输出日志事件的发生位置,包括类目名、发生的线程,以及在代码中的行数。举例:Testlog4.main(TestLog4.java:10)
    #    %L 输出日志发生的位置
    #     %F 输出类名
     可以在%与模式字符之间加上修饰符来控制其最小宽度、最大宽度、和文本的对齐方式。如:
     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字符,就从左边较远输出的字符截掉。
    ConversionPattern 日志信息,符号所代表的含义:
     -X号: X信息输出时左对齐;
    #####################################################################
    #设置级别和目的地 -- 把日志等级为debug的日志信息输出到stdout和SYS,QUERY这三个目的地
    log4j.rootLogger=debug,STDOUT
    # stdout:目的地 -- 打印到屏幕
    ## org.apache.log4j.ConsoleAppender:控制台
    log4j.appender.STDOUT=org.apache.log4j.ConsoleAppender
    ## org.apache.log4j.PatternLayout:灵活地指定布局模式
    log4j.appender.STDOUT.layout=org.apache.log4j.PatternLayout
    ## 上一句设置了PatternLayout灵活指定格式,则要指定打印参数 [%-5p][%d{HH:mm:ss}][%c-%M] %m%n   [%-5p][%d{HH:mm:ss}][%l] %m%n
    log4j.appender.STDOUT.layout.ConversionPattern=[%-5p][%d{yyyy-MM-dd HH:mm:ss sss}][%t][%c-%M][%L](%F:%L) - %m%n
    
    
    # QUERY:目的地 -- 输出到文件(限定每个文件大小)
    ## 凡是 info、warn、error、fatal 级别的数据都会在这里执行输出到 query.log 日志文件中
    ##log4j.logger.QUERY=INFO,QUERY
    log4j.logger.QUERY=INFO
    ##输出到文件(这里默认为追加方式),使用org.apache.log4j.FileAppender:日志会在一个文件中追加
    log4j.appender.QUERY=org.apache.log4j.RollingFileAppender
    ##设置文件输出路径;html:log/query.html
    log4j.appender.QUERY.File=log/query.log
    ##设置文件输出样式;html格式: org.apache.log4j.HTMLLayout
    log4j.appender.QUERY.layout=org.apache.log4j.PatternLayout
    ## 上一句设置了PatternLayout灵活指定格式,则要指定打印参数 [%-5p][%d{HH:mm:ss}][%l] %m%n
    log4j.appender.QUERY.layout.ConversionPattern=[%-5p][%d{yyyy-MM-dd HH:mm:ss}][%c-%M] %m%n
    ## 指定文件的最大 大小
    log4j.appender.QUERY.MaxFileSize=2048KB
    ## 可被备份的日志数
    log4j.appender.QUERY.MaxBackupIndex=100
    
    
    # SYS:目的地 -- 输出到文件(每天产生一个文件) 
    ## 凡是 error、fatal 级别的数据都会在这里执行输出到 sys.log 日志文件中
    #log4j.logger.SYS=error,SYS
    log4j.logger.SYS=error
    ## org.apache.log4j.RollingFileAppender:每天产生一个日志文件
    #使用org.apache.log4j.FileAppender:日志会在一个文件中追加
    log4j.appender.SYS=org.apache.log4j.DailyRollingFileAppender
    ##设置文件输出路径 ${user.home}/log/sys.log
    log4j.appender.SYS.File=log/sys.log
    ## org.apache.log4j.PatternLayout:灵活地指定布局模式
    log4j.appender.SYS.layout=org.apache.log4j.PatternLayout
    ## 上一句设置了PatternLayout灵活指定格式,则要指定打印参数 [%-5p][%d{HH:mm:ss}][%l] %m%n
    log4j.appender.SYS.layout.ConversionPattern=[%-5p][%d{HH:mm:ss}][%C-%M] %m%n
    
    #设置特定包的级别
    ##com.swh.weixin包下的日志内容显示级别为debug,和目的地
    ## 把com.swh.weixin.util包下日志等级为debug的信息输出到pack 目的地
    #log4j.logger.com.swh.weixin.util=debug,pack
    ##输出到文件(这里默认为追加方式),使用org.apache.log4j.FileAppender:日志会在一个文件中追加
    log4j.appender.pack=org.apache.log4j.RollingFileAppender
    ##设置文件输出路径  或者 ${user.home}/log/pack.log
    log4j.appender.pack.File=log/pack.log
    ##设置文件输出样式
    log4j.appender.pack.layout=org.apache.log4j.PatternLayout
    ## 上一句设置了PatternLayout灵活指定格式,则要指定打印参数 [%-5p][%d{HH:mm:ss}][%l] %m%n
    log4j.appender.pack.layout.ConversionPattern=[%-5p][%d{yyyy MM dd HH:mm:ss}][%c-%M] %m%n
    ## 指定文件的最大 大小
    log4j.appender.pack.MaxFileSize=1024KB
    #日志最大备份数目
    log4j.appender.pack.MaxBackupIndex=100
    
    ########################################################################
    ##设置级别和目的地  
    #log4j.rootLogger=debug,appender1,appender2  
    ##只设置特定包的级别和目的地
    #log4j.logger.com.coderdream=debug,appender1
    #log4j.logger.com.coderdream.Dao=info,appender1,appender2
    
    ##输出到控制台
    #log4j.appender.appender1=org.apache.log4j.ConsoleAppender
    ##设置输出样式
    #log4j.appender.appender1.layout=org.apache.log4j.PatternLayout
    ##自定义样式
    ## %r 时间 0
    ## %t 方法名 main
    ## %p 优先级 DEBUG/INFO/ERROR
    ## %c 所属类的全名(包括包名)
    ## %l 发生的位置,在某个类的某行
    ## %m 输出代码中指定的讯息,如log(message)中的message
    ## %n 输出一个换行符号
    #log4j.appender.appender1.layout.ConversionPattern=[%d{yy/MM/dd HH:mm:ss:SSS}][%C-%M] %m%n
    
    ##输出到文件(这里默认为追加方式)
    #log4j.appender.appender2=org.apache.log4j.FileAppender
    ##设置文件输出路径
    ##【1】文本文件
    #log4j.appender.appender2.File=c:/Log4JCRM_Dao.log
    ##设置文件输出样式
    #log4j.appender.appender2.layout=org.apache.log4j.PatternLayout
    #log4j.appender.appender2.layout.ConversionPattern=[%d{HH:mm:ss:SSS}][%C-%M] -%m%n
    
    
    ##把日志文件写入数据库
    ##########################日志输出到远程数据库########################################
    ##把日志文件写入数据库
    ##记录的日志级别
    log4j.logger.db=info
    ##日志输出到数据库
    log4j.appender.db = org.apache.log4j.jdbc.JDBCAppender
    ##缓存
    log4j.appender.db.BufferSize = 0
    ##数据库驱动
    log4j.appender.db.Driver = com.mysql.jdbc.Driver
    ##数据url地址 ,本地可简写:jdbc:mysql:///test
    log4j.appender.db.URL = jdbc:mysql://localhost:3306/swh_hibernate4?useUnicode=true&characterEncoding=utf8
    ##数据库用户名
    log4j.appender.db.User = root
    ##数据库密码
    log4j.appender.db.Password = root
    ##日志布局模式
    log4j.appender.db.layout = org.apache.log4j.PatternLayout
    ##日志插入数据库中,t_logs 表字段可自定义
    log4j.appender.db.layout.ConversionPattern = INSERT INTO t_logs(createDate, thread, priority, category,<br />
    methodName, message) values('%d', '%t', '%-5p', '%c','%M', '[%l]-%m')
    

    log4j.xml

    <?xml version="1.0" encoding="UTF-8"?>
    <!DOCTYPE log4j:configuration SYSTEM "log4j.dtd">
    
    <log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/">
    
      <appender name="default" class="org.apache.log4j.ConsoleAppender">
        <param name="target" value="System.out"/>
        <layout class="org.apache.log4j.PatternLayout">
          <param name="ConversionPattern" value="[%-5p] %d{yyyy-MM-dd hh:mm:ss.SSS aa} %t [%c]%n%m%n%n"/>
        </layout>
      </appender>
    
      <appender name="console" class="org.apache.log4j.ConsoleAppender">
        <param name="target" value="System.out"/>
        <!-- 设置日志文件输出样式 -->
        <layout class="org.apache.log4j.PatternLayout">
        <!-- 设置日志的输出格式 -->
          <param name="ConversionPattern" value="[%-5p] [%d{yyyy-MM-dd HH:mm:ss.SSS z}] [%t] [%c]%n%m%n%n"/>
        </layout>
      </appender>
    
      <!-- 查询级别,输出到文件(限定每个文件大小) -->
       <appender name="query" class="org.apache.log4j.RollingFileAppender">     
        <!-- 设置日志输出文件名 -->    
            <param name="File" value="E:/user-job-web.log" />    
            <!-- 设置是否在重新启动服务时,在原有日志的基础添加新日志 -->     
            <param name="Append" value="true" />
            <!-- 指定文件的最大 大小为1MB 单位是B(1024B=1KB) -->     
            <param name="MaxFileSize" value="1048576" />
            <!-- 备份日志文件的个数(默认是10个) -->
            <param name="MaxBackupIndex" value="10" />     
            <layout class="org.apache.log4j.PatternLayout">     
                <param name="ConversionPattern" value="[%-5p][%d{yyyy-MM-dd HH:mm:ss}][%c-%M] %m%n" />     
            </layout>     
        </appender>     
    
      <!-- 输出到文件(每天产生一个文件)  -->
      <appender name="sys" class="org.apache.log4j.DailyRollingFileAppender">
        <!-- 设置日志输出文件名 --> 
         <param name="File" value="E:\\user-job-web_warn.log" />       
         <param name="DatePattern" value="'.'yyyy-MM-dd'.log'" /> 
        <!-- 设置日志文件输出样式 -->
        <layout class="org.apache.log4j.PatternLayout">
        <!-- 设置日志的输出格式 -->
          <param name="ConversionPattern" value="[%-5p] [%d{yyyy-MM-dd HH:mm:ss.SSS}] [%t] [%c-%M]%n%m%n%n"/>
        </layout>
      </appender>
    
     <!-- 日志输出到数据中 -->
       <appender name="dblog" class="org.apache.log4j.jdbc.JDBCAppender">
          <!-- 设置数据库信息和连接 --> 
         <param name="Driver" value="com.mysql.jdbc.Driver" />       
         <param name="URL" value="jdbc:mysql://localhost:3306/swh_hibernate4?useUnicode=true&characterEncoding=utf8" /> 
         <param name="user" value="root" />
         <param name="password" value="root" />
         <!-- 设置日志文件输出样式 -->
        <layout class="org.apache.log4j.PatternLayout">
        <!-- 设置输出日志的sql-->
          <param name="ConversionPattern" value="INSERT INTO t_logs(createDate, thread, priority, category,methodName, message) values('%d', '%t', '%-5p', '%c','%M', '[%l]-%m')"/>
        </layout>
      </appender>
      <!-- 单独配置,效果和放到logger->root下一样 -->
      <category name="com.swh.crm.aop" additivity="false">
            <level value="INFO" />
            <appender-ref ref="dblog" />
            <appender-ref ref="console" />
        </category>
    
     <logger name="org.quartz">
       <level value="warn" />
     </logger>
    
     <!-- 设置com.swh.crm.service路径下的日志信息级别为info级别 -->
     <logger name="com.swh.oa.service" additivity="true">
       <level value="info" />
     </logger>
    
    <!-- 设置级别和目的地 -->
      <root>
        <!-- 设置根日志级别,指定路径中的日志优先级大于根日志优先级
        (com.swh.crm(只会输出info级别以上的日志)>root,
         org.quartz(只会输出warn级别以上的日志))
         没有指定日志级别的则以root指定的日志级别为准 -->
        <level value="debug" />
        <!-- 引入appender -->
       <!--  <appender-ref ref="sys" /> -->
        <appender-ref ref="query" />
        <appender-ref ref="console" />
      </root>
    
    </log4j:configuration>
    
    ### 配置根 ###
    log4j.rootLogger = debug,console ,fileAppender,dailyRollingFile,ROLLING_FILE,MAIL,DATABASE
    
    ### 设置输出sql的级别,其中logger后面的内容全部为jar包中所包含的包名 ###
    log4j.logger.org.apache=dubug
    log4j.logger.java.sql.Connection=dubug
    log4j.logger.java.sql.Statement=dubug
    log4j.logger.java.sql.PreparedStatement=dubug
    log4j.logger.java.sql.ResultSet=dubug
    
    ### 配置输出到控制台 ###
    log4j.appender.console = org.apache.log4j.ConsoleAppender
    log4j.appender.console.Target = System.out
    log4j.appender.console.layout = org.apache.log4j.PatternLayout
    log4j.appender.console.layout.ConversionPattern =  %d{ABSOLUTE} %5p %c{ 1 }:%L - %m%n
    
    ### 配置输出到文件 ###
    log4j.appender.fileAppender = org.apache.log4j.FileAppender
    log4j.appender.fileAppender.File = logs/log.log
    log4j.appender.fileAppender.Append = true
    log4j.appender.fileAppender.Threshold = DEBUG
    log4j.appender.fileAppender.layout = org.apache.log4j.PatternLayout
    log4j.appender.fileAppender.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss}  [ %t:%r ] - [ %p ]  %m%n
    
    ### 配置输出到文件,并且每天都创建一个文件 ###
    log4j.appender.dailyRollingFile = org.apache.log4j.DailyRollingFileAppender
    log4j.appender.dailyRollingFile.File = logs/log.log
    log4j.appender.dailyRollingFile.Append = true
    log4j.appender.dailyRollingFile.Threshold = DEBUG
    log4j.appender.dailyRollingFile.layout = org.apache.log4j.PatternLayout
    log4j.appender.dailyRollingFile.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss}  [ %t:%r ] - [ %p ]  %m%n
    
    ### 配置输出到文件,且大小到达指定尺寸的时候产生一个新的文件 ###
    log4j.appender.ROLLING_FILE=org.apache.log4j.RollingFileAppender 
    log4j.appender.ROLLING_FILE.Threshold=ERROR 
    log4j.appender.ROLLING_FILE.File=rolling.log 
    log4j.appender.ROLLING_FILE.Append=true 
    log4j.appender.ROLLING_FILE.MaxFileSize=10KB 
    log4j.appender.ROLLING_FILE.MaxBackupIndex=1 
    log4j.appender.ROLLING_FILE.layout=org.apache.log4j.PatternLayout 
    log4j.appender.ROLLING_FILE.layout.ConversionPattern=[framework] %d - %c -%-4r [%t] %-5p %c %x - %m%n
    
    ### 配置输出到邮件 ###
    log4j.appender.MAIL=org.apache.log4j.net.SMTPAppender
    log4j.appender.MAIL.Threshold=FATAL
    log4j.appender.MAIL.BufferSize=10
    log4j.appender.MAIL.From=chenyl@yeqiangwei.com
    log4j.appender.MAIL.SMTPHost=mail.hollycrm.com
    log4j.appender.MAIL.Subject=Log4J Message
    log4j.appender.MAIL.To=chenyl@yeqiangwei.com
    log4j.appender.MAIL.layout=org.apache.log4j.PatternLayout
    log4j.appender.MAIL.layout.ConversionPattern=[framework] %d - %c -%-4r [%t] %-5p %c %x - %m%n
    
    ### 配置输出到数据库 ###
    log4j.appender.DATABASE=org.apache.log4j.jdbc.JDBCAppender
    log4j.appender.DATABASE.URL=jdbc:mysql://localhost:3306/test
    log4j.appender.DATABASE.driver=com.mysql.jdbc.Driver
    log4j.appender.DATABASE.user=root
    log4j.appender.DATABASE.password=
    log4j.appender.DATABASE.sql=INSERT INTO LOG4J (Message) VALUES ('[framework] %d - %c -%-4r [%t] %-5p %c %x - %m%n')
    log4j.appender.DATABASE.layout=org.apache.log4j.PatternLayout
    log4j.appender.DATABASE.layout.ConversionPattern=[framework] %d - %c -%-4r [%t] %-5p %c %x - %m%n
    log4j.appender.A1=org.apache.log4j.DailyRollingFileAppender
    log4j.appender.A1.File=SampleMessages.log4j
    log4j.appender.A1.DatePattern=yyyyMMdd-HH'.log4j'
    log4j.appender.A1.layout=org.apache.log4j.xml.XMLLayout
    
    Log4J的配置文件(Configuration File)就是用来设置记录器的级别、存放器和布局的,它可接key=value格式的设置或xml格式的设置信息。通过配置,可以创建出Log4J的运行环境。
    
    1\. 配置文件
    Log4J配置文件的基本格式如下:
    
    #配置根Logger
    log4j.rootLogger  =   [ level ]   ,  appenderName ,  appenderName1 ,  …
    
    #配置日志信息输出目的地Appender及Appender选项
    
    log4j.appender.appenderName = fully.qualified.name.of.appender.class   
    
      log4j.appender.appenderName.option = value1
         …   
      log4j.appender.appenderName.optionN = valueN 
    #配置日志信息的格式(布局)及格式布局选项 
    
    appender.appenderName.layout = fully.log4j.qualified.name.of.layout.class
      log4j.appender.appenderName.layout.option1 = value1
         …   
      log4j.appender.appenderName.layout.optionN = valueN
    
    *   其中 [ level ] 是日志输出级别:ERROR、WARN、INFO、DEBUG
        ERROR 为严重错误 主要是程序的错误
        WARN 为一般警告,比如session丢失
        INFO 为一般要显示的信息,比如登录登出
        DEBUG 为程序的调试信息
    *   appenderName是日志输出位置的配置的命名
    *   log4j.appender.appenderName = fully.qualified.name.of.appender.class中fully.qualified.name.of.appender.class应换上以下信息输出的目的地:
    
    1.  org.apache.log4j.ConsoleAppender(控制台)
    2.  org.apache.log4j.FileAppender(文件)
    3.  org.apache.log4j.DailyRollingFileAppender(每天产生一个日志文件)
    4.  org.apache.log4j.RollingFileAppender(文件大小到达指定尺寸的时候产生一个新的文件)
    5.  org.apache.log4j.WriterAppender(将日志信息以流格式发送到任意指定的地方)
    
    *   appender.appenderName.layout = fully.log4j.qualified.name.of.layout.class中fully.qualified.name.of.layout.class格式布局应换上以下信息:
    
    1.  org.apache.log4j.HTMLLayout(以HTML表格形式布局)
    2.  org.apache.log4j.PatternLayout(可以灵活地指定布局模式)
    3.  org.apache.log4j.SimpleLayout(包含日志信息的级别和信息字符串)
    4.  org.apache.log4j.TTCCLayout(包含日志产生的时间、线程、类别等等信息)
    
    *   log4j.appender.appenderName.option中option应替换的属性/选项
    
      1.ConsoleAppender控制台选项
    
        Threshold=DEBUG:指定日志消息的输出最低层次。
        ImmediateFlush=true:默认值是true,意味着所有的消息都会被立即输出。
        Target=System.err:默认情况下是:System.out,指定输出控制台
    
      2.FileAppender 文件选项
    
        Threshold=DEBUF:指定日志消息的输出最低层次。
        ImmediateFlush=true:默认值是true,意谓着所有的消息都会被立即输出。
        File=mylog.txt:指定消息输出到mylog.txt文件。
        Append=false:默认值是true,即将消息增加到指定文件中,false指将消息覆盖指定的文件内容。
    
      3.RollingFileAppender 每天生成一个文件选项
    
        Threshold=DEBUG:指定日志消息的输出最低层次。
        ImmediateFlush=true:默认值是true,意谓着所有的消息都会被立即输出。
        File=mylog.txt:指定消息输出到mylog.txt文件。
        Append=false:默认值是true,即将消息增加到指定文件中,false指将消息覆盖指定的文件内容。
        MaxFileSize=100KB: 后缀可以是KB, MB 或者是 GB. 在日志文件到达该大小时,将会自动滚动,即将原来的内容移到mylog.log.1文件。
        MaxBackupIndex=2:指定可以产生的滚动文件的最大数。
    
    

    相关文章

      网友评论

          本文标题:log4j配置

          本文链接:https://www.haomeiwen.com/subject/yuhnrctx.html