log4j-简易log4j

1.导入log4j的jar包:log4j-1.2.17.jar。

2.配置log4j.properties或log4j.xml文件到WEB-INF/classes下,二者同时存在时先找的是log4j.xml。

3.在java中使用:生成log对象Logger log = Logger.getLogger(this.getClass());

   使用:log.debug("This is a debug msg.");
             log.info("This is a info msg.");
             log.warn("This is a warn msg.");
             log.error("This is a error msg.");


----------------------------------------log4j.properties--------------------------------------------------------

log4j.rootLogger=INFO, A1

log4j.appender.A1=org.apache.log4j.ConsoleAppender

# log4j.appender.A1=org.apache.log4j.RollingFileAppender
# log4j.appender.A1.File=fcxtest.log
# log4j.appender.A1.MaxFileSize=1000KB

log4j.appender.A1.layout=org.apache.log4j.PatternLayout
log4j.appender.A1.layout.ConversionPattern=%d %-5p [%t] %C{2} (%F:%L) - %m%n


--------------------------------------------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="stdout" class="org.apache.log4j.ConsoleAppender">
        <param name="Encoding" value="UTF-8" />
        <layout class="org.apache.log4j.PatternLayout">
            <param name="ConversionPattern" value="%5p %d{HH:mm:ss:SSS} %c (%L) %m%n"/>
        </layout>
    </appender>
    
    <appender name="sysfile" class="org.apache.log4j.FileAppender">
        <param name="File" value="D:\\sutudy\\webservices\\workspace\\.metadata\\.plugins\\org.eclipse.wst.server.core\\tmp0\\logs\\system.log" />
        <param name="Encoding" value="UTF-8" />
        <layout class="org.apache.log4j.PatternLayout">
            <param name="ConversionPattern" value="%d %5p [%c] - %m%n"/>
        </layout>
    </appender>
    
    <appender name="appfile" class="org.apache.log4j.FileAppender">
        <param name="File" value="D:\\sutudy\\webservices\\workspace\\.metadata\\.plugins\\org.eclipse.wst.server.core\\tmp0\\logs\\app.log" />
        <param name="Encoding" value="UTF-8" />
        <layout class="org.apache.log4j.PatternLayout">
            <param name="ConversionPattern" value="%d %5p [%c] - %m%n"/>
        </layout>
    </appender>
    
    <logger name="indieinside">
        <level value="INFO"/>
        <appender-ref ref="stdout"/>
        <appender-ref ref="appfile"/>
    </logger>
   
    <logger name="java.sql">
        <level value="DEBUG"/>
        <appender-ref ref="stdout"/>
        <appender-ref ref="sysfile"/>
    </logger>


    <category name="com.ibatis" additivity="false">
        <level value="DEBUG"/>
        <appender-ref ref="stdout"/>
        <appender-ref ref="appfile"/>
    </category>

    <root>
      <priority value ="debug"/>
      <appender-ref ref="stdout" />
    </root>
</log4j:configuration>  


---------------------------------------说明-----------------------------------------------------

1.关于log4j.xml中log的名字,logger标签中的name属性通常采用包名,在java中实例化log时通常也是用包名,并且与log4j中的名字采用前部匹配的方式。

例:log4j中 logger的名字是indieinside

类indieinside.action包中,LoginAction类 中获得logger是:Logger log = Logger.getLogger(this.getClass());

this.getClass()的值为:indieinside.action.LoginAction,与名为indieinside的logger匹配相同。


2.root标签为: 设置接收所有输出的通道,假如没有logger标签,则默认找root标签来输出。

--------------------------------------附(转)---------------------------------------------------

(1). 输出方式appender一般有5种:
             org.apache.log4j.RollingFileAppender(滚动文件,自动记录最新日志) 
             org.apache.log4j.ConsoleAppender (控制台) 
             org.apache.log4j.FileAppender (文件) 
             org.apache.log4j.DailyRollingFileAppender (每天产生一个日志文件) 
             org.apache.log4j.WriterAppender (将日志信息以流格式发送到任意指定的地方) 

(2). 日记记录的优先级priority,优先级由高到低分为 
            OFF ,FATAL ,ERROR ,WARN ,INFO ,DEBUG ,ALL。 
            Log4j建议只使用FATAL ,ERROR ,WARN ,INFO ,DEBUG这五个级别。 

(3). 格式说明layout中的参数都以%开始,后面不同的参数代表不同的格式化信息(参数按字母表顺序列出): 
                %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        输出产生该日志事件的线程名

你可能感兴趣的:(log4j-简易log4j)