zoukankan      html  css  js  c++  java
  • Log4j详细教程

    一、简单的使用Log4j日志

    1,新建一个Java工程,导入包log4j-1.2.17.jar,目录如下:

    2,src同级创建并设置log4j.properties

    ### 把指定级别的日志信息输出到指定的一个或者多个位置###

    ### 把DEBUG层级以及以上的信息输出到console,all,error,interface###

    log4j.rootLogger=DEBUG,console,all,interface,error

    ### 编码格式###

    log4j.appender.encoding="utf-8"

    ### 输出信息到控制抬 ###

    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{yy/MM/dd HH:mm:ss} [%p] %c{2}:%L - [%M]%m%n

    ### 输出所有级别的日志到logs/all.log ###

    log4j.appender.all=org.apache.log4j.DailyRollingFileAppender

    log4j.appender.all.file=logs/all.log

    log4j.appender.all.DatePattern='.'yyyy-MM-dd

    log4j.appender.all.layout=org.apache.log4j.PatternLayout

    log4j.appender.all.layout.ConversionPattern=%d{yy/MM/dd HH:mm:ss} [%p] %c{2}:%L - [%M]%m%n

    ### 输出INFO 级别以上的日志到logs/info.log ###

    log4j.appender.interface=org.apache.log4j.DailyRollingFileAppender

    log4j.appender.interface.file=logs/info.log

    log4j.appender.interface.Threshold=INFO

    log4j.appender.interface.DatePattern='.'yyyy-MM-dd

    log4j.appender.interface.layout=org.apache.log4j.PatternLayout

    log4j.appender.interface.layout.ConversionPattern=%d{yy/MM/dd HH:mm:ss} [%p] %c{2}:%L - [%M]%m%n

    ### 输出ERROR 级别以上的日志到logs/error.log ###

    log4j.appender.error=org.apache.log4j.DailyRollingFileAppender

    log4j.appender.error.file=logs/error.log

    log4j.appender.error.Threshold=ERROR

    log4j.appender.error.DatePattern='.'yyyy-MM-dd

    log4j.appender.error.layout=org.apache.log4j.PatternLayout

    log4j.appender.error.layout.ConversionPattern=%d{yy/MM/dd HH:mm:ss} [%p] %c{2}:%L - [%M]%m%n

    3、创建Test类,如下

    /**
     * 
     * @类名称:Test
     * @类描述:测试
     * @创建人:zender
     */
    public class Test {
        private static Logger log = Logger.getLogger(Test.class);
        public static void main(String[] args) {
            // 记录debug级别的信息  
            log.debug("这是 debug 信息.");  
            // 记录info级别的信息  
            log.info("这是 info 信息.");  
            // 记录error级别的信息  
            log.error("这是 error 信息.");  
        }
    }

    4,输出结果

    控制台:

    文件:

    All.log

    Error.log

    Info.log

    二、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)将不会被打印出来。

    三、Log4j配置文件

    Log4j由三个重要的组件构成:日志信息的优先级,日志信息的输出目的地,日志信息的输出格式。

    日志信息的优先级从高到低有ERROR、WARN、 INFO、DEBUG,分别用来指定这条日志信息的重要程度;日志信息的输出目的地指定了日志将打印到控制台还是文件中;而输出格式则控制了日志信息的显示内容。

    1,配置根Logger:log4j.rootLogger

    语法:

    log4j.rootLogger = [ level ] , appenderName, appenderName, …

    level 是日志记录的优先级,分为OFF、FATAL、ERROR、WARN、INFO、DEBUG、ALL或者您定义的级别。

    Log4j建议只使用四个级别,优 先级从高到低分别是ERROR、WARN、INFO、DEBUG。通过在这里定义的级别,您可以控制到应用程序中相应级别的日志信息的开关。

    比如:定义了INFO级别,则应用程序中所有DEBUG级别的日志信息将不被打印出来。 appenderName就是指日志信息输出到哪个地方。您可以同时指定多个输出目的地。第一个例子就自定义了console,all,interface,error4个输出目的地。

    2,配置日志信息输出目的地Appender,其语法为:

    log4j.appender.appenderName = fully.qualified.name.of.appender.class

    log4j.appender.appenderName.option1 = value1

    ……

    log4j.appender.appenderName.optionN = valueN

    其中,Log4j提供的appender有以下几种:

    org.apache.log4j.ConsoleAppender(控制台)

    org.apache.log4j.FileAppender(文件)

    org.apache.log4j.DailyRollingFileAppender(每天产生一个日志文件)

    org.apache.log4j.RollingFileAppender(文件大小到达指定尺寸的时候产生一个新的文件)

    org.apache.log4j.WriterAppender(将日志信息以流格式发送到任意指定的地方)

    3,配置日志信息的格式(布局),其语法为:

    log4j.appender.appenderName.layout = fully.qualified.name.of.layout.class

    log4j.appender.appenderName.layout.option1 = value1

    log4j.appender.appenderName.layout.optionN = valueN

    其中,Log4j提供的layout有以下几种个数:

    org.apache.log4j.HTMLLayout(以HTML表格形式布局),

    org.apache.log4j.PatternLayout(可以灵活地指定布局模式),

    org.apache.log4j.SimpleLayout(包含日志信息的级别和信息字符串),

    org.apache.log4j.TTCCLayout(包含日志产生的时间、线程、类别等等信息)

    Log4J采用类似C语言中的printf函数的打印格式格式化日志信息,常用打印参数如下:

    %m 输出代码中指定的消息

    %M 显示调用logger的方法名

    %p 输出优先级,即DEBUGINFOWARNERRORFATAL

    %r 输出自应用启动到输出该log信息耗费的毫秒数

    %c 输出所属的类目,通常就是所在类的全名

    %t 输出产生该日志事件的线程名

    %n 输出一个回车换行符,Windows平台为"rn"Unix平台为"n"

    %d 输出日志时间点的日期或时间,默认格式为ISO8601,也可以在其后指定格式,比如:%d{yyy MMM dd HH:mm:ss,SSS},输出类似:20021018 221028921

    %l 输出日志事件的发生位置,包括类目名、发生的线程,以及在代码中的行数。举例:Testlog4.main(TestLog4.java:10)

    4,读取配置文件:

    BasicConfigurator.configure (): 自动快速地使用缺省Log4j环境。

    PropertyConfigurator.configure ( String configFilename) :读取使用Java的特性文件编写的配置文件。

    DOMConfigurator.configure ( String filename ) :读取XML形式的配置文件。

    例如:

    ### 输出信息到控制抬 ###

    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{yy/MM/dd HH:mm:ss} [%p] %c{2}:%L - [%M]%m%n

       

    ### 每天产生一个日志文件 ###

    log4j.appender.all=org.apache.log4j.DailyRollingFileAppender

    ### 日志输出的到文件:logs/all.log ###

    log4j.appender.all.file=logs/all.log

    ###Log4j会先生成all.log这样一个文件,然后当这一天过去的时候,生成一个新的all.log,然后把原来的保存为加上日期格式后缀的文件###

    log4j.appender.all.DatePattern='.'yyyy-MM-dd

    ###可以灵活地指定布局模式###

    log4j.appender.all.layout=org.apache.log4j.PatternLayout

    ### 输出信息的格式 ###

    log4j.appender.all.layout.ConversionPattern=%d{yy/MM/dd HH:mm:ss} [%p] %c{2}:%L - [%M]%m%n

    四、Web环境中使用Log4j

    在WEB应用使用Log4j,必须先在启动服务时加载Log4j的配置文件进行初始化,可以在web.xml中进行。

    1,使用InitServlet ,设置令其自启动来初始化 Log4j 。

    (1)创建Web工程,整个工程最后目录如下

    (2)PathUtils类,用来获取WEB应用路径

    /**
     * 
     * @类名称:PathUtils
     * @类描述:获取web应用路径
     * @创建人:zender
     */
    public class PathUtils {
        private static String webroot = null;
        static {
            webroot = getWebrootPath();
        }
     
        private final static String getWebrootPath() {
            String root = PathUtils.class.getResource("/").getFile();
            try {
                root = new File(root).getParentFile().getParentFile().getCanonicalPath();
                root += File.separator;
            } catch (IOException e) {
                throw new RuntimeException(e);
            }
            return root;
        }
     
        /**
         * 返回Web应用的路径
         * @return
         */
        public static String webRoot() {
            return webroot;
        }
    }

    (3)InitServlet类,用来初始化Log4j

    /**
     * 
     * @类名称:InitServlet
     * @类描述:初始化Log4j
     * @创建人:zender
     */
    public class InitServlet extends HttpServlet {
        private static final long serialVersionUID = -9074849844731671080L;
        static {
            // 获取web应用路径
            String root = PathUtils.webRoot();
            String logFilesPath = root + "WEB-INF" + File.separator;
            System.setProperty("logFilesPath", logFilesPath);
        }
     
        @Override
        public void init() throws ServletException {
            System.out.println("InitServlet 正在初始化 log4j日志设置信息.");
            super.init();
            String prefix = getServletContext().getRealPath("/");
            String log4jFile = getServletConfig().getInitParameter("log4j");
            // 获取Log4j配置文件路径
            String log4jConfigPath = prefix + log4jFile;
            // 设置Log4j配置文件
            PropertyConfigurator.configure(log4jConfigPath);
        }
    }

    (4)配置文件log4j.properties

    ### 把指定级别的日志信息输出到指定的一个或者多个位置###

    ### 把DEBUG层级以及以上的信息输出到console,all,error###

    log4j.rootLogger=DEBUG,console,all,error

       

    ### 编码格式###

    log4j.appender.encoding="utf-8"

       

    ### 输出信息到控制抬 ###

    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{yy/MM/dd HH:mm:ss} [%p] %c{2}:%L - [%M]%m%n

       

    ### 输出所有级别的日志到logs/all.log ###

    log4j.appender.all=org.apache.log4j.DailyRollingFileAppender

    log4j.appender.all.file=${logFilesPath}/logs/all.log

    log4j.appender.all.DatePattern='.'yyyy-MM-dd

    log4j.appender.all.layout=org.apache.log4j.PatternLayout

    log4j.appender.all.layout.ConversionPattern=%d{yy/MM/dd HH:mm:ss} [%p] %c{2}:%L - [%M]%m%n

       

    ### 输出ERROR 级别以上的日志到logs/error.log ###

    log4j.appender.error=org.apache.log4j.DailyRollingFileAppender

    log4j.appender.error.file=${logFilesPath}/logs/error.log

    log4j.appender.error.Threshold=ERROR

    log4j.appender.error.DatePattern='.'yyyy-MM-dd

    log4j.appender.error.layout=org.apache.log4j.PatternLayout

    log4j.appender.error.layout.ConversionPattern=%d{yy/MM/dd HH:mm:ss} [%p] %c{2}:%L - [%M]%m%n

    (5)web.xml配置如下

    <?xml version="1.0" encoding="UTF-8"?>
    <web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
        xmlns="http://java.sun.com/xml/ns/javaee"
        xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"
        id="WebApp_ID" version="3.0">
        <display-name>Log4jWeb</display-name>
        <welcome-file-list>
            <welcome-file>index.html</welcome-file>
            <welcome-file>index.htm</welcome-file>
            <welcome-file>index.jsp</welcome-file>
            <welcome-file>default.html</welcome-file>
            <welcome-file>default.htm</welcome-file>
            <welcome-file>default.jsp</welcome-file>
        </welcome-file-list>
     
        <servlet>
            <servlet-name>initServlet</servlet-name>
            <servlet-class>com.zender.servlet.InitServlet</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>
     
        <servlet-mapping>
            <servlet-name>initServlet</servlet-name>
            <url-pattern>/initServlet.do</url-pattern>
        </servlet-mapping>
    </web-app>

    (5)调用日志Log4JTestServlet类

    /**
     * 
     * @类名称:Log4JTestServlet
     * @类描述:测试Log4j的Servlet
     * @创建人:zender
     */
    @WebServlet("/log4JTestServlet")
    public class Log4JTestServlet extends HttpServlet {
        private static final long serialVersionUID = 8827404827021162856L;
        private static Logger log = Logger.getLogger(Log4JTestServlet.class);
     
        @Override
        protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
            doPost(req, resp);
        }
     
        @Override
        protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
            // 记录debug级别的信息
            log.debug("这是 debug 信息.");
            // 记录info级别的信息
            log.info("这是 info 信息.");
            // 记录error级别的信息
            log.error("这是 error 信息.");
            resp.setCharacterEncoding("UTF-8");
            PrintWriter out = resp.getWriter();
            out.write("访问成功!");
        }
    }

    (6)启动WEB项目访问:http://localhost:8080/Log4jWeb/log4JTestServlet

    控制台打印:

    日志文件:

    All.log

    Error.log

    2,通过监听器 ServletContextListener 监听 ServletContext 的初始化事件来初始化 Log4j 

    (1)创建MyServletContextListener监听器

    /**
     * 
     * @类名称:MyServletContextListener
     * @类描述:用于初始化log4j监听器
     * @创建人:zender
     */
    public class MyServletContextListener implements ServletContextListener {
        static {
            // 获取web应用路径
            String root = PathUtils.webRoot();
            String logFilesPath = root + "WEB-INF" + File.separator;
            System.setProperty("logFilesPath", logFilesPath);
        }
        
        @Override
        public void contextDestroyed(ServletContextEvent arg0) {
        }
     
        @Override
        //初始化方法
        public void contextInitialized(ServletContextEvent arg0) {
            System.out.println("MyServletContextListener 正在初始化 log4j日志设置信息.");
            ServletContext ctx = arg0.getServletContext();
            String prefix = ctx.getRealPath("/");
            String log4jFile = ctx.getInitParameter("log4j");
            //// 获取Log4j配置文件路径
            String log4jConfigPath = prefix + log4jFile;
            //// 设置Log4j配置文件
            PropertyConfigurator.configure(log4jConfigPath);
        }
    }

    (2)修改WEB.xml文件

    <?xml version="1.0" encoding="UTF-8"?>
    <web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
        xmlns="http://java.sun.com/xml/ns/javaee"
        xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"
        id="WebApp_ID" version="3.0">
        <display-name>Log4jWeb</display-name>
        <welcome-file-list>
            <welcome-file>index.html</welcome-file>
            <welcome-file>index.htm</welcome-file>
            <welcome-file>index.jsp</welcome-file>
            <welcome-file>default.html</welcome-file>
            <welcome-file>default.htm</welcome-file>
            <welcome-file>default.jsp</welcome-file>
        </welcome-file-list>
        
        <context-param>
            <param-name>log4j</param-name>
            <param-value>/WEB-INF/classes/log4j.properties</param-value>
        </context-param>
        <!-- 用于初始化log4j的监听器 -->
        <listener>
            <listener-class>com.zender.listener.MyServletContextListener</listener-class>
        </listener>
    </web-app>

    (3)启动WEB项目访问:http://localhost:8080/Log4jWeb/log4JTestServlet

    控制台打印:

    日志文件:

    All.log

    Error.log

  • 相关阅读:
    (17)打鸡儿教你Vue.js
    (16)打鸡儿教你Vue.js
    (15)打鸡儿教你Vue.js
    (14)打鸡儿教你Vue.js
    (13)打鸡儿教你Vue.js
    Webpack 入门教程
    ios textfield如何设置,只能输入1.0-9.9内的数字,并实现时时监测效果
    安卓edittext实现输入数字限制条件的效果
    js动态设置根元素的rem方案
    Fresco使用之OOM问题记录
  • 原文地址:https://www.cnblogs.com/Zender/p/7463628.html
Copyright © 2011-2022 走看看