1、log4j简介

  1.如果程序中出现异常,我们怎么解决?

    01.使用异常处理机制===》异常    (但是使用原则是,能不用异常处理机制,最好不用,怎么办?)

    02.通过debug调试          (必须掌握)

    03.通过System.out.print();

      但是:001.控制台有行数限制

         002.影响我们的系统性能

         003.如果我们要对用户的行为习惯进行分析

  2.我们需要一个把记录用户行为和习惯的代码,记录在一个文件中!

    .log(日志文件)

  3.log4j:(log for Java)

    01.是用java语言编写的一个日志框架

    02.是Apache的一个开源项目

    03.记录我们程序中的日志信息

    04.可以将日志信息输出到我们指定的目的地

  4.log4j的作用

    01.记录代码中变量的变化,用于我们程序的调试和后期维护

    02.可以周期性的保存一些数据,用于后期对数据的分析

    03.通过设置日志信息的级别,来便于我们的管理

2、log4j的组成部分

  1.日志的记录器(logger)

    日志的输出级别

      OFF  级别最高,用于关闭所有的日志输出

      ALL  级别最低,用于开启所有的日志输出

      Fatel  严重的错误事件,将导致我们的程序终止

      Error  错误事件,不会影响我们的程序的继续执行

      Warn  可能存在潜在的错误场景

      Info  指的是粗粒度级别上的使用

      Debug  指的是细粒度级别上的使用

      Trace  比Debug还要细的

    开发环境(开发阶段):  使用日志级别比较低:Debug

    生产环境(项目上线):  建立把Debug细粒度的设置成Warn

  2.日志的输出格式(Layout)

    %p  日志信息的优先级

    %d  日志信息的输出时间  %d(yyyy-MM-dd hh:mm:ss)

    %C  日志信息输出的类

    %l  日志信息的输出位置:类+线程+行号

    %M  日志信息的输出所在方法

    %m  日志信息的输出内容

    %n  输出日志信息之后换行

    %t  日志信息的输出所在线程

    %r  从程序启动到输出日志信息所经历的时间(毫秒)

  3.日志的输出目的地(Appender)

    01.把我们的日志信息输出到某个地址

    02.可以同时指定多个输出地

    03.一个输出地对应一个Appender

    将日志输出到Console控制台中=====》ConsoleAppender

    将日志输出到文件中

      =====》01.RollingFileAppender    根据文件大小创建新的日志文件

      =====》02.DailyRollingFileAppender  根据时间创建新的日志文件

3、重点log4j的使用

  1.创建Java项目

  2.在项目中创建lib文件夹

  3.把我们事先下载好的jar包引到我们lib中

  4.右键点击  jar builder path  加入到我们项目中

  5.创建测试类 书写我们的测试代码(logger)

  6.创建source folder

  7.在resource文件夹中创建需要的log4j.properties      (log4j.properties名字固定,不能随便命名,因为底层默认找这个)

  8.书写配置

    01.输出到Console控制台

    02.输出到文件中,根据文件大小自动创建

    03.书写到文件中,根据文件时间自动创建

    DailyRollingFileAppender中的DatePattern共分为6种方式

      001.每月    yyyy-MM

      002.每周    yyyy-ww

      003.每天    yyyy-MM-dd

      003.每半天    yyyy-MM-dd-a

      004..每小时    yyyy-MM-dd-hh

      005.每分钟    yyyy-MM-dd-hh-mm

log4j log for java的更多相关文章

  1. Log4j log for java(java的日志) 的使用

    log4j的使用,Log4j log for java(java的日志) 是java主流的日志框架,提供各种类型,各种存储,各种格式,多样化的日志服务. 可以再Apache官网下载得到. 我们下载lo ...

  2. 为什么使用 SLF4J 而不是 Log4J 来做 Java 日志

    转自:为什么使用 SLF4J 而不是 Log4J 来做 Java 日志 英文原文:Why use SLF4J over Log4J for logging in Java 每个Java开发人员都知道日 ...

  3. log4j配置文件及java调用 每个级别输出到不同的文件

    #配置根Logger log4j.rootLogger = DEBUG , RollingFile,CONSOLE #文件大小达到一定尺寸的时候创建一个新的文件 log4j.appender.Roll ...

  4. 【解决】hbase regionserver意外关机启动失败 [main] mortbay.log: tmpdir java.io.IOException: Permission denied

    错误信息: 015-12-24 10:57:26,527 INFO  [main] mortbay.log: jetty-6.1.26.cloudera.4 2015-12-24 10:57:26,5 ...

  5. Log4j实现对Java日志的配置全攻略

    1. 配置文件 Log4J配置文件的基本格式如下: #配置根Logger log4j.rootLogger = [ level ] , appenderName1 , appenderName2 , ...

  6. 使用log4j使某些java类的日志信息输出到指定日志文件中

    Log4j 是 Apache 的一个开放源代码项目,通过使用 Log4j,我们可以控制日志信息输送的目的地是控制台.文件.GUI 组件.甚至是套接口服务器.NT 的事件记录器.UNIX Syslog ...

  7. log4j配置文件及java调用 每个级别输出到不同的文件2

    log4j.rootLogger=debug,stdout,info,debug,error log4j.appender.stdout=org.apache.log4j.ConsoleAppende ...

  8. JAVA中的Log4j

    Log4j的简介: 使用异常处理机制==>异常 使用debug调试(必须掌握)    System.out.Print(); 001.控制台行数有限制        002.影响性能      ...

  9. java基础之Flex弹性布局、JSP错误处理以及Log4J

    一.Flex弹性布局 1.产生的比较晚,目前在移动网页开发中可以使用,而且逐渐成为主流. 在桌面网页开发中使用的比较少(主要是桌面浏览器的兼容性问题更加严重) 2.开启方法: 在容器标签上加上 dis ...

随机推荐

  1. POJ3061 Subsequence 尺取or二分

    Description A sequence of N positive integers (10 < N < 100 000), each of them less than or eq ...

  2. 重构改善既有代码设计--重构手法14:Hide Delegate (隐藏委托关系)

    客户通过一个委托类来调用另一个对象.在服务类上建立客户所需的所有函数,用以隐藏委托关系. 动机:封装即使不是对象的最关机特性,也是最关机特性之一.“封装”意味着每个对象都应该少了解系统的其他部分.如此 ...

  3. angular package.json中start build

    "start": "ng serve --host 0.0.0.0 --port 4200 --proxy-config proxy.conf.json", & ...

  4. 【BZOJ】4873: [Shoi2017]寿司餐厅

    [题目]#2146. 「SHOI2017」寿司餐厅 [题意]给定n种寿司的代号,取区间[i,j]的寿司收益是d[i,j]和所有子区间的d,吃了c(c>0)种代号x的寿司的代价是mx^2+cx,给 ...

  5. 【BZOJ】3238: [Ahoi2013]差异

    [题意]给定长度为n的小写字母字符串,令Ti表示以i开头的后缀,求Σ[Ti+Tj-2*lcp(Ti,Tj)],1<=i<j<=n. [算法]后缀自动机 [题解]Σ(Ti+Tj)只与n ...

  6. 【Atcoder】AGC 020 D - Min Max Repetition 二分+构造

    [题意]定义f(A,B)为一个字符串,满足: 1.长度为A+B,含有A个‘A',B个'B'. 2.最长的相同字符子串最短. 3.在满足以上2条的情况下,字典序最小. 例如, f(2,3) = BABA ...

  7. 20155117王震宇 2006-2007-2 《Java程序设计》第一周学习总结

    20155117王震宇 2006-2007-2 <Java程序设计>第一周学习总结 教材学习内容总结 尽量简单的总结一下本周学习内容 尽量不要抄书,浪费时间 看懂就过,看不懂,学习有心得的 ...

  8. pycharm显示行号

    在PyCharm 里,显示行号有两种办法: 1,临时设置.右键单击行号处,选择 Show Line Numbers. 但是这种方法,只对一个文件有效,并且,重启PyCharm 后消失. 2,永久设置. ...

  9. 浅析busybox如何集成到openwrt

    背景 近日添加了一个包到openwrt中,在此过程中又对openwrt多了一些认识 这个包本身自带了kconfig,可直接在这个包里面执行make menuconfig进行配置,然后执行make 但要 ...

  10. C#:Excel上传服务器后导入数据库