log4j的配置文件备份.[成功测试]

1.在项目的config目录下,新建配置文件 log4j.xml,或者 log4j.properties

2.配置config到class目录

3.如果是默认的配置,则不需要额外的配置,log4j即可起作用;如果是非默认配置,则需要手动的加载配置文件,具体方式,网上已经很多介绍,一般遵循默认配置即可.

4.分别贴出两种配置文件内容

4.1. log4j.properties

log4j.rootLogger=INFO, stdout, fileout

log4j.logger.org=ERROR
log4j.logger.com.jimmy=info

log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss.SSS} %p %l[%t] %m%n


log4j.appender.fileout=org.apache.log4j.RollingFileAppender
log4j.appender.fileout.File=/home/zhangjun/soft/logTest/jimmy.log
log4j.appender.fileout.MaxFileSize=1kb
log4j.appender.fileout.MaxBackupIndex=2
log4j.appender.fileout.layout=org.apache.log4j.PatternLayout
log4j.appender.fileout.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss.SSS}[%p][%F:%L][%t]%x %m%n


log4j.xml:

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE log4j:configuration SYSTEM "log4j.dtd">

<log4j:configuration threshold="debug"
	xmlns:log4j='http://jakarta.apache.org/log4j/'>

	<appender name="console" class="org.apache.log4j.ConsoleAppender">
		<param name="Target" value="System.out" />
		<param name="threshold" value="info" />
		<layout class="org.apache.log4j.PatternLayout">
			<param name="ConversionPattern" value="%d{yyyy-MM-dd HH:mm:ss} %p %C.%M[%L][%t] %m%n" />
		</layout>
	</appender>

	<!-- 业务类日志  -->
	<appender name="business" class="org.apache.log4j.RollingFileAppender">
		<param name="File" value="/home/zhangjun/soft/logTest/jimmy.log" />
		<param name="Append" value="true" />
		<param name="threshold" value="info" />
		<param name="MaxFileSize" value="1kb" />
		<param name="MaxBackupIndex" value="5" />
		<layout class="org.apache.log4j.PatternLayout">
			<param name="ConversionPattern" value="%d{yyyy-MM-dd HH:mm:ss} %p %C.%M[%L][%t] %m%n" />
		</layout>
	</appender>

	<!-- 指定特定的包路径下的日志输出级别 -->
	<category name="com.jimmy.base" additivity="true">
		<priority value="WARN" />
		<appender-ref ref="console.CONSOLE" />
	</category>


	<root>
		<level value="info" />
		<appender-ref ref="console" />
		<appender-ref ref="business" />
	</root>

</log4j:configuration> 



5.关于各配置项,网上已很多说明,贴出一部分:
这是log4j默认的配置,我们先熟悉一下
  <!-- ============================== -->
  <!-- Append messages to the console -->
  <!-- ============================== -->
    <!--输出方式:输出到控制台-->
    <appender name="CONSOLE" class="org.apache.log4j.ConsoleAppender">
    <!-- 设置通道名称:console和输出方式:org.apache.log4j.RollingFileAppender
           其中输出方式appender有5种,分别为
           org.apache.log4j.ConsoleAppender (控制台) 
           org.apache.log4j.FileAppender (文件)
           org.apache.log4j.DailyRollingFileAppender (每天产生一个日志文件)
           org.apache.log4j.WriterAppender (将日志信息以流格式发送到任意指定的地方)-->
    <param name="Target" value="System.out"/>
    <param name="Threshold" value="INFO"/>
      <!--Threshold是个全局的过滤器,它将把低于所设置的level的信息过滤不显示出来-->
      <!--level:是日记记录的优先级,优先级由高到低分为
          OFF ,FATAL ,ERROR ,WARN ,INFO ,DEBUG ,ALL。
          Log4j建议只使用FATAL ,ERROR ,WARN ,INFO ,DEBUG这四个级别。-->

    <layout class="org.apache.log4j.PatternLayout">
       <!-- 配置日志输出的格式-->
              参数都以%开始后面不同的参数代表不同的格式化信息(参数按字母表顺序列出):
              %c     输出所属类的全名,可在修改为 %d{Num} ,Num类名输出的围  如:"org.apache.elathen.ClassName",
                                                                               %C{2}将输出elathen.ClassName
                                                                                           
              %d     输出日志时间其格式为 %d{yyyy-MM-dd HH:mm:ss,SSS},可指定格式 如 %d{HH:mm:ss}
              %l     输出日志事件发生位置,包括类目名、发生线程,在代码中的行数
              %n     换行符
              %m     输出代码指定信息,如info(“message”),输出message
              %p     输出优先级,即 FATAL ,ERROR 等
              %r     输出从启动到显示该log信息所耗费的毫秒数
              %t     输出产生该日志事件的线程名
      <!-- The default pattern: Date Priority [Category] Message/n -->
      <param name="ConversionPattern" value="%d{ABSOLUTE} %-5p [%c{1}] %m%n"/>
    </layout>
  </appender>

  <!输出方式是:每天一个日志文件>
  <!-- A time/date based rolling appender -->
  <appender name="FILE" class="org.jboss.logging.appender.DailyRollingFileAppender">
    <!--设置通道名称是:file,输出方式DailyRollingFileAppender-->
    <param name="File" value="${jboss.server.home.dir}/log/server.log"/>
    <!--日志文件路径和文件名称 -->
    <param name="Append" value="false"/>
    <!-- 设置是否在重新启动服务时,在原有日志的基础添加新日志 -->


    <!-- Rollover at midnight each day -->
    <param name="DatePattern" value="'.'yyyy-MM-dd"/>



    <!-- Rollover at the top of each hour
    <param name="DatePattern" value="'.'yyyy-MM-dd-HH"/>
    -->



    <layout class="org.apache.log4j.PatternLayout">
      <!-- The default pattern: Date Priority [Category] Message/n -->
      <param name="ConversionPattern" value="%d %-5p [%c] %m%n"/>

      <!-- The full pattern: Date MS Priority [Category] (Thread:NDC) Message/n
      <param name="ConversionPattern" value="%d %-5r %-5p [%c] (%t:%x) %m%n"/>
       -->
    </layout>    
  </appender>

<!-- A size based file rolling appender-->
  <appender name="com.szypt.all" class="org.jboss.logging.appender.RollingFileAppender">
    <param name="File" value="${jboss.server.home.dir}/log/elathen.log"/>
    <param name="Append" value="true"/>
    <param name="MaxFileSize" value="500KB"/>
    <param name="MaxBackupIndex" value="1"/>

    <layout class="org.apache.log4j.PatternLayout">
      <param name="ConversionPattern" value="%d %-5p [%c] %m%n"/>
    </layout>    
  </appender>

  <logger name="com.szypt">
    <level value="DEBUG" />
    <appender-ref ref="com.szypt.all"/>
  </logger> 

你可能感兴趣的:(log4j)