zoukankan      html  css  js  c++  java
  • log4j配置打印实例

    1.转自:http://chenhaoming-mz.blog.163.com/blog/static/4950762820102131158141/

       a. 项目的文件结构
     
       
     (log4j-1.2.11.jar包下载地址http://www.jar114.com/,鄙视csdn那些牛人这些东西还要分,这个地址可以搜到大量的包
     b. 步骤:
      eclipse中新建一个java project命名为TestLog;
      新建一个com.hotel.log的package包;
      导入log4j的jar包;
      在com.hotel.log包里新建一个Log.java。
     c. 代码:

    Log.java

    package com.hotel.log;
    
    import org.apache.log4j.Logger;
    import org.apache.log4j.PropertyConfigurator;
    
    public class Log {
        // Logger实例
        public Logger loger;
        // 将Log类封装成单实例的模式,独立于其他类。以后要用到日志的地方只要获得Log的实例就可以方便使用
        private static Log log;
    
        // 构造函数,用于初始化Logger配置需要的属性
        private Log() {
            // 获得当前目录路径
            String filePath = this.getClass().getResource("/").getPath();
            // 找到log4j.properties配置文件所在的目录(已经创建好)
            filePath = filePath.substring(1).replace("bin", "src");
            // 获得日志类loger的实例
            loger = Logger.getLogger(this.getClass());
            // loger所需的配置文件路径
            PropertyConfigurator.configure(filePath + "log4j.properties");
        }
    
        public static Log getLoger() {
            if (log != null)
                return log;
            else
                return new Log();
        }
    }

    测试

    package com.hotel.testlog;
    
    import com.hotel.log.Log;
    
    public class T2 {
        public static void main(String args[]) {
            Log log = Log.getLoger();
            try {
                int a = 2 / 0;
            } catch (Exception e) {
                e.printStackTrace();
                log.loger.error("error", e);
            }
        }
    }

    log4j.properties:

    
    #定义DEBUG优先级,R为日志输出目的的 
    log4j.rootLogger=DEBUG, R 
    #设置日志输出类型,为文件类型 
    log4j.appender.R=org.apache.log4j.FileAppender 
    #设置日志文件名my.log (生成的文件到项目的workspace目录下找)
    log4j.appender.R.file=my.log
    #每次在文件尾写入新的日志信息 
    log4j.appender.R.Append=true 
    #日志输出信息格式类型 
    log4j.appender.R.layout=org.apache.log4j.PatternLayout 
    #日志输出信息格式为 换行、换行、日期、优先级、[类名]、日志信息、换行 
    log4j.appender.R.layout.ConversionPattern=%n%n%d %p [%c]-%m%n

    Result:运行吧,出错了,恭喜你成功了,去TestLog目录下寻找my.log日志信息吧
    以后在任何需要记录日志的地方只要使用下面语句就行了

      Log log= Log.getLogger();
      log.logger.error("something u like to record");

    总结:
      需求:记录日志就是这么简单,不过你可以有其他的需要:

      我要将日志发到邮箱
      我要将日志写到数据库
      我要每天的日志自动归档
      ……
      
      方案:这些都可以通过修改配置log4j.properties配置文件来实现
    以下是配置文件的语法

      1. log4j.rootLogger = [level],appenderName,appenderName...
      其中,level是日志记录的优先级,从高到低分别为FATAL ERROR WARN INFO DEBUG 。当
      你定义一个级别,只有等于或者高于这个基本的才进行处理。 可选的All打印所有日志,OFF
      关闭所有日志输出。
      appenderName用于指定日志信息输出目的地,可以指定多个
    2.配置appender
      
      类型有以下几种
      org.apache.log4j.jdbc.JDBCAppender 存入数据库
      org.apache.log4j.net.SMTPAppender 发送到指定邮箱
      net.cybercorlin.util.logger.appender.IMAppender 自定义类型
      org.apache.log4j.ConsoleAppender 控制台
      org.apache.log4j.FileAppender 文件
      org.apache.log4j.DailyRollingFileAppender 每天产生一个日志文件
      org.apache.log4j.RollingFileAppender 文件达到指定大小的时候产生一个新的文件
      org.apache.log4j.WriterAppender 将日志信息以流格式发送到任意指定的地方
      *************可以从网上摘抄的例子************
      3.配置日志信息格式Layout
      有以下几种
      org.apache.log4j.HTMLLayout HTML表格形式
      org.apache.log4j.PatternLayout 自定义的布局(下面将见到这么自定义配置)
      org.apache.log4j.SimpleLayout 只包含日志信息基本和信息的字符信息
      org.apache.log4j.TTCCLayout 包括日志产生时间、线程、类别等信息
      4.自定义的布局中用到的格式化日志信息
      采用跟C语言中printf的方式,参数有
      %m 输出代码中指定的信息 如 log.error("error")
      %p 输出优先级 就是上面提到的DEBUG,INFO等
      %c 输出所在类的全名
      %r 输出自应用启用到输出该log信息耗费的时间(毫秒)
      %t 输出产生该日子事件的线程名
      %n 输出换行符号 Windows平台为 "rn",unix平台“n"
      %d 输出日志时间点 默认格式是ISO8601 可以自定义格式,比如%d{yyy MM dd hh:mm:ss,sss}

    2.转自:http://sharep.blog.51cto.com/539048/143734/

    这篇文章写得比较全面,转过来,算是共享吧,同时感谢javaeye上的zengjinliang,呵呵

     
    方法一、 解决的办法自然是用相对路径代替绝对路径,其实log4j的FileAppender本身就有这样的机制,如:log4j.appender.logfile.File=${WORKDIR}/logs/app.log 
    其中“${WORKDIR}/”是个变量,会被System Property中的“WORKDIR”的值代替。这样,我们就可以在log4j加载配置文件之前,先用System.setProperty ("WORKDIR", WORKDIR);设置好根路径,此操作可通过一初始的servlet进行。 

    方法二、可以使用服务器环境变量 
    log4j的配置文件支持服务器的vm的环境变量,格式类似${catalina.home} 
    log4j.appender.R=org.apache.log4j.RollingFileAppender 
    log4j.appender.R.File=${catalina.home}/logs/logs_tomcat.log 
    log4j.appender.R.MaxFileSize=10KB 
    其中的${catalina.home}并非windows系统的环境变量,这个环境变量就不需要在Windows系统的环境变量中设置。之所以这样,你可以看看tomcat\bin\catalina.bat(startup,shutdown都是调用这个)里面自带有-Dcatalina.home= "%CATALINA_HOME%" 。继承这个思想,所以你也可以自己设定一个参数-Dmylog.home="D:/abc/log"到对应的服务器java启动的vm参数中 

    方法三、通过servlet初始化init()方法中加载file属性实现相对路径 
    具体实现:做一个servlet,在系统加载的时候,就把properties的文件读到一个properties文件中.那个file的属性值(我使用的是相对目录)改掉(前面加上系统的根目录),让后把这个properties对象设置到propertyConfig中去,这样就初始化了log的设置.在后面的使用中就用不着再配置了 
    一般在我们开发项目过程中,log4j日志输出路径固定到某个文件夹,这样如果我换一个环境,日志路径又需要重新修改,比较不方便,目前我采用了动态改变日志路径方法来实现相对路径保存日志文件 
    (1).在项目启动时,装入初始化类: 
    public class Log4jInit extends HttpServlet { 
             static Logger logger = Logger.getLogger(Log4jInit.class); 
             public Log4jInit() { 
             } 

             public void init(ServletConfig config) throws ServletException { 
                 String prefix = config.getServletContext().getRealPath("/"); 
                 String file = config.getInitParameter("log4j"); 
                 String filePath = prefix + file; 
                 Properties props = new Properties(); 
                 try { 
                     FileInputStream istream = new FileInputStream(filePath); 
                     props.load(istream); 
                     istream.close(); 
                     //toPrint(props.getProperty("log4j.appender.file.File")); 
                     String logFile = prefix + props.getProperty("log4j.appender.file.File");//设置路径 
                     props.setProperty("log4j.appender.file.File",logFile); 
                     PropertyConfigurator.configure(props);//装入log4j配置信息 
                 } catch (IOException e) { 
                     toPrint("Could not read configuration file [" + filePath + "]."); 
                     toPrint("Ignoring configuration file [" + filePath + "]."); 
                     return; 
                 } 
             } 

             public static void toPrint(String content) { 
                 System.out.println(content); 
             } 
    } 
    实际上log4j的配置文件log4j.properties如为默认名,可放置在JVM能读到的classpath里的任意地方,一般是放在WEB- INF/classes目录下。当log4j的配置文件不再是默认名,则需要另外加载并给出参数,如上 “ropertyConfigurator.configure(props);//装入log4j配置信息” 

    (2).Web.xml中的配置 
    <servlet> 
             <servlet-name>log4j-init</servlet-name> 
             <servlet-class>Log4jInit</servlet-class> 
             <init-param> 
               <param-name>log4j</param-name> 
               <param-value>WEB-INF/classes/log4j.properties</param-value> 
             </init-param> 
             <load-on-startup>1</load-on-startup> 
           </servlet> 

    注意:上面的load-on-startup设为0,以便在Web容器启动时即装入该Servlet。log4j.properties文件放在根的properties子目录中,也可以把它放在其它目录中。应该把.properties文件集中存放,这样方便管理。 
    (3).log4j.properties中即可配置log4j.appender.file.File为当前应用的相对路径. 


    以上是网上log4j日志文件的相对路径配置的三种方法(我能找到的就三种),分析: 

    方法一主要是扩展了log4j的RollingFileAppender类,其他的FileAppender同样道理。扩展的方法,就是用一个子类去覆盖setFile方法,这个方法在log4j读取配置文件生成appender的时候调用,传入的就是配 
    置文件中的路径,这样我就可以按照自己的想法在路径前面加上根路径了。这种方法可以在log4j.properties中用相对路径自由配置log4j.appender.A1.File属性来决定生成的日志相对web应用根 
    目录的位置。 

    方法二是利用服务器vm中已经存在的环境变量如${catalina.home}来设置相对于${catalina.home}的日志路径,日志只能放到服务器子目录里,而且如果是用的其它服务器,则要改对应的环境变量。此方法平台移植不方便。 

    方法三是扩展ActionServlet类,覆盖其init()方法,新方法中载入log4j.properties位置的参数,可以自由配置log4j的配置文件的名字和存放位置。也可自由配置log4j日志文件的相对于当前应用的路径。详 
    细代码如下: 

    程序代码 
    package wbb.bysxxglxt.util; 

    import org.apache.struts.action.*; 
    import org.apache.commons.logging.LogFactory; 
    import org.apache.commons.logging.Log; 
    import javax.servlet.ServletException; 
    import java.util.Properties; 
    import java.io.InputStream; 
    import org.apache.log4j.PropertyConfigurator; 
    import java.io.FileInputStream; 
    import java.io.IOException; 

    public class ExtendedActionServlet extends ActionServlet { 
            private Log log = LogFactory.getLog(this.getClass().getName()); 

            public ExtendedActionServlet() {} 

            public void init() throws ServletException { 
                log.info( 
                        "Initializing, My MyActionServlet init this System's Const Variable");
                String prefix = this.getServletConfig().getServletContext().getRealPath( 
                        "/"); 
                String file = this.getServletConfig().getInitParameter("log4j"); 
                String filePath = prefix + file; 
                Properties props = new Properties(); 
                System.out.println(prefix); 
                System.out.println(file); 
                System.out.println(filePath); 

                try { 
                    FileInputStream log4jStream = new FileInputStream(filePath); 
                    props.load(log4jStream); 
                    log4jStream.close(); 
                    String logFile = prefix + 
                                     props.getProperty("log4j.appender.A1.File"); //设置路径 

                    System.out.println(logFile); 
                    props.setProperty("log4j.appender.A1.File", logFile); 
                    PropertyConfigurator.configure(props); //装入log4j配置信息 
                } catch (IOException e) { 
                    e.printStackTrace(); 
                } 
                log.info("Initializing, end My Init"); 
                super.init();//应用了struts,此方法不能省,ActionServlet覆盖了的此方法中有很多重要操作 
            } 
    } 


    **********************应用web.xml 关键部分*************************** 

          
    程序代码 
    <servlet> 
            <servlet-name>action</servlet-name> 
            <servlet-class>wbb.bysxxglxt.util.ExtendedActionServlet</servlet-class> 
            <init-param> 
              <param-name>config</param-name> 
              <param-value>/WEB-INF/struts-config.xml</param-value> 
            </init-param> 
            <init-param> 
                <param-name>log4j</param-name> 
                <param-value>properties\log4j.properties</param-value>                    
              </init-param> 
            <init-param> 
              <param-name>debug</param-name> 
              <param-value>0</param-value> 
            </init-param> 
            <init-param> 
              <param-name>application</param-name> 
              <param-value>ApplicationResources</param-value> 
            </init-param> 
            <load-on-startup>0</load-on-startup> 
          </servlet> 
          <servlet-mapping> 
            <servlet-name>action</servlet-name> 
            <url-pattern>*.do</url-pattern> 
          </servlet-mapping> 


    注意log4j参数中相对路径的斜杠线的写法,而且log4j属性文件如放置在web-inf/classes目录或web-inf等目录中最好改名,因为在加载此Servlet之前,服务器如tomcat启动时会自动搜索web-inf目录和web-inf/classes目录中log4j.properties文件,如有则自动加载。log4j属性文件加载后,由于该属性文件中log4j.appender.A1.File的值用的是相对路径,自动加载配置便会出错: 
    log4j:ERROR setFile(null,true) call failed. 
    java.io.FileNotFoundException: WEB-INF\logs\bysxxglxt.log (系统找不到指定的路径。) 
    不知道log4j为什么会这么早自动启动。尽管后面加载扩展的ActionServlet中正确设置了log4j属性文件并正常加载了,但报的这个错还是怪不爽的,于是只有更改log4j属性文件名字或者更改其存放位置,让其不能自动加载了,不过还是有两个警告: 
    log4j:WARN No appenders could be found for logger (org.apache.commons.digester.Digester.sax). 
    log4j:WARN Please initialize the log4j system properly. 
    这样做就算是掩耳盗铃了,如果你有更好的解决办法,希望能在此贴出来,大家一起研究。 

    ********************log4j.properties***************************** 
    ### 设置logger级别 ### 

    程序代码 
    log4j.rootLogger=DEBUG,stdout,A1 

    ### appender.stdout输出到控制台 ### 
    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 

    ### appender.A1输出到日志文件 ### 
    log4j.appender.A1=org.apache.log4j.DailyRollingFileAppender 
    log4j.appender.A1.File=WEB-INF\\logs\\bysxxglxt.log 
    ##注意上面日志文件相对应用根目录路径的写法 
    log4j.appender.A1.DatePattern='.'yyyy-MM-dd'.log' 
    log4j.appender.A1.Append=true 
    ## 输出DEBUG级别以上的日志 
    log4j.appender.A1.Threshold=DEBUG 
    log4j.appender.A1.layout=org.apache.log4j.PatternLayout 
    log4j.appender.A1.layout.ConversionPattern= [%5p] [BYSXXGLXT] %d{yyyy-MM-dd HH:mm:ss}: %-4r     [%t] ( %F,%L ) - %m%n

     

  • 相关阅读:
    -bash: fork: Cannot allocate memory 问题的处理
    Docker top 命令
    docker常见问题修复方法
    The Absolute Minimum Every Software Developer Absolutely, Positively Must Know About Unicode and Character Sets (No Excuses!)
    What's the difference between encoding and charset?
    hexcode of é î Latin-1 Supplement
    炉石Advanced rulebook
    炉石bug反馈
    Sidecar pattern
    SQL JOIN
  • 原文地址:https://www.cnblogs.com/tv151579/p/2738056.html
Copyright © 2011-2022 走看看