log4j日志收集

目录

    • 1. log4j 是什么
      • 1. 日志管理工具
      • 2. 有哪些组成部分?
      • 3. 日志级别
    • 2. 输出端与日志格式化器
      • Appender(输出端)
      • Layout(日志格式化器)
    • 3. log4j.properties
      • 占位符,格式化日志
    • 4. 使用

1. log4j 是什么

1. 日志管理工具

  • log4j 是 Apache 的一个开源项目
    (官网 http://jakarta.apache.org/log4j),
  • 通过在项目中使用 Log4J,我们可以控制日志信息输出到控制台、文件、GUI 组件、甚至是数据库中。
  • 我们可以控制每一条日志的输出格式,通过定义日志的输出级别, 可以更灵活的控制日志的输出过程。方便项目的调试。

对应的slf4j,也是日志管理工具

一般将日志输出到文件。或者将日志输出到数据库,做成对应的日志管理系统。
方便对程序分析,做出改正。

2. 有哪些组成部分?

log4j 主要由 Loggers (日志记录器)、Appenders(输出端)
和 Layout(日志格式化器)组成。
其中 Loggers 控制日志的输出级别与日志是否输出;
Appenders 指定日志的输出方式(输出到控制台、文件等);
Layout 控制日志信息的输出格式。

3. 日志级别

  • OFF 最高日志级别,关闭所有日志
  • FATAL 将会导致应用程序退出的错误
  • ERROR 发生错误事件,但仍不影响系统的继续运行
  • WARN 警告,即潜在的错误情形
  • INFO 一般和在粗粒度级别上,强调应用程序的运行全程
  • DEBUG 一般用于细粒度级别上,对调试应用程序非常有帮助
  • ALL 最低等级,打开所有日志记录
  • 一般只使用4个级别,优先级从高到低为 ERROR > WARN > INFO > DEBUG
  • 注意,是error,只会记录error级别及fatal, off的错误

2. 输出端与日志格式化器

Appender(输出端)

Appender 用来指定日志输出到哪个地方,可以同时指定日志的输出目的地。Log4j 常用的输出目的地有以下几种
ConsoleAppender 将日志输出到控制台
FileAppender 将日志输出到文件中
DailyRollingFileAppender 将日志输出到一个日志文件,并且每天输出到一个新的文件
RollingFileAppender 将日志信息输出到一个日志文件,并且指定文件的尺寸,当文件大 小达到指定尺寸时,会自动把文件改名,同时产生一个新的文件
JDBCAppender 把日志信息保存到数据库中

Layout(日志格式化器)

HTMLLayout 格式化日志输出为HTML表格形式
SimpleLayout 简单的日志输出格式化,打印的日志格式为(info - message)
PatternLayout 最强大的格式化期,可以根据自定义格式输出日志,如果没有指定转换格式,就是用默认的转换格式

3. log4j.properties

在d盘创建log文件夹,日志会自动输出到log下

#总控制 日志级别 使用哪些方式输出。 以error级别,只会logger.error(e)输出
log4j.rootLogger = error,stdout,D,E,F#将日志输出到控制台
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] %d{yyyy-MM-dd HH\:mm\:ss,SSS} method\:%l%n%m%n  #输出至文件 级别 DEBUG
log4j.appender.D = org.apache.log4j.DailyRollingFileAppender  
log4j.appender.D.File = D\://logs/log.log  
log4j.appender.D.Append = true  
log4j.appender.D.Threshold = DEBUG   
log4j.appender.D.layout = org.apache.log4j.PatternLayout  
log4j.appender.D.layout.ConversionPattern = %-d{yyyy-MM-dd HH\:mm\:ss}  [ %t\:%r ] - [ %p ] -[%l]  %m%n  #输出至文件 级别 ERROR
log4j.appender.E = org.apache.log4j.DailyRollingFileAppender  
log4j.appender.E.File =D\://logs/error.log
log4j.appender.E.Append = true  
log4j.appender.E.Threshold = ERROR   
log4j.appender.E.layout = org.apache.log4j.PatternLayout  
log4j.appender.E.layout.ConversionPattern =%-d{yyyy-MM-dd HH\:mm\:ss}  [ %t\:%r ] - [ %p ] -[%l]  %m%n#输出至html文件 
log4j.appender.F=org.apache.log4j.DailyRollingFileAppender
log4j.appender.F.layout=org.apache.log4j.HTMLLayout
log4j.appender.F.File=D\:\\logs\\index.html
log4j.appender.F.layout.ConversionPattern =%-d{yyyy-MM-dd HH\:mm\:ss}  [ %t\:%r ] - [ %p ] -[%l]  %m%n

占位符,格式化日志

%m   输出代码中指定的日志信息
%p    输出优先级,及 DEBUG、INFO 等
%n    换行符(Windows平台的换行符为 "\n",Unix 平台为 "\n")
%r     输出自应用启动到输出该 log 信息耗费的毫秒数
%c    输出打印语句所属的类的全名
%t     输出产生该日志的线程全名
%d    输出服务器当前时间,默认格式为 ISO8601,也可以在后面指定格式。如:%d{yyyy年MM月dd日 HH:mm:ss}
%l     输出日志时间发生的位置,包括类名、发生的线程,以及在代码中的行数,如:Test.main(Test.java:10)
%F    输出日志消息产生时所在的文件名称
%L    输出代码中的行号
%x    输出和当前线程相关的 NDC(嵌套诊断环境)

4. 使用

private static Logger logger = Logger.getLogger(StudentController.class);
@Controller
public class AuthorAction extends BaseAction{// 日志对象private static Logger logger = Logger.getLogger(AuthorAction.class);private AuthorService authorService;@Autowiredpublic void setAuthorService(AuthorService authorService) {this.authorService = authorService;}//查询所有书籍public String findAuthor(){logger.info("查询所有书籍 start");try{List<Author> authorList = authorService.findAuthor();this.getRequest().setAttribute("authorList", authorList);SimpleDateFormat ft = new SimpleDateFormat("yyyy-MM-dd");System.out.println("查询所有书籍");int count = 1/0;} catch (Exception e) {
//			logger.info(e.getMessage()); // 记录普通信息,程序运行过程
//			logger.debug(e.getMessage()); // debug模式
//			logger.warn(e.getMessage()); // 警告//logger.error(e.getStackTrace()); // 错误logger.error(e+"--"+e.getStackTrace()[0].getLineNumber()); // 错误类,对应的行号}logger.info("查询所有书籍 end"); return "authorList";}}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/420582.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【从零之三(更)】自定义类中调用讯飞语音包错误解决办法

原文&#xff1a;http://blog.csdn.net/monkeyduck/article/details/24302655 在科大讯飞语音包的Mscdemo中它的方法都是写在Activity中的&#xff0c;这样其实并不是很好&#xff0c;因为Activity只是负责UI交互的&#xff0c;如果项目很简单自然可以&#xff0c;但是一旦比较…

php常用代码(一)

一&#xff1a;获取上个小时 方法1&#xff1a;date("H",strtotime("-1 hours"); 方法2&#xff1a;date(H,time()-60*60); 方法3&#xff1a;echo substr(0.(--date(H) & 23),-2); 转载于:https://www.cnblogs.com/Alight/p/3998203.html

spring 整合quartz

定时框架quartz1. 使用场景2. corn表达式3. 简单使用4. 注意点1. 使用场景 定时任务 周期性执行 &#xff08;每隔多长时间&#xff09; 定时执行&#xff08;每天几点&#xff09; 系统之间的数据交换 两个系统之间的数据 数据整理 报表打印… 2. corn表达式 corn 表达式…

poi excel文档生成与读取

阿帕奇poi excel文档操作1. introduce2. 轮子3. demo 以九九乘法表为例3.1 xls的生成3.2 xlsx的生成3.3 读取xlsx1. introduce poi是什么 答&#xff1a;用于excel的操作的&#xff0c;可以对集合&#xff0c;map进行操作生成对应的excel文档。做报表。 对应的iText是pdf操作的…

hdu4405:概率dp

题意&#xff1a; 总共有n1个格子&#xff1a;0-n 初始情况下在 0号格子 每次通过掷骰子确定前进的格子数 此外 还有一些传送门可以瞬间从 u 点传送到 v 点&#xff08;必须被传送&#xff09; 求走到&#xff08;或超过&#xff09;n点总共需要掷多少次骰子 分析&#xff1a; …

echarts生成图表

目录1. echarts是一个优秀的js绘图框架2. 如何使用echats框架绘图&#xff1f;3. 更多彩蛋1. echarts是一个优秀的js绘图框架 ECharts&#xff0c;一个使用 JavaScript 实现的开源可视化库&#xff0c;可以流畅的运行在 PC 和移动设备上&#xff0c;兼容当前绝大部分浏览器&…

HDU 1394 线段树or 树状数组~

Minimum Inversion Number   Description The inversion number of a given number sequence a1, a2, ..., an is the number of pairs (ai, aj) that satisfy i < j and ai > aj. For a given sequence of numbers a1, a2, ..., an, if we move the first m > 0 nu…

servlet,springmvc,springboot转发时页面静态资源404问题

目录不讨论静态资源过滤的问题。。。这个问题重定向不会404&#xff0c;因为重定向是找到了对应的页面&#xff0c;是浏览器决定的。 而转发在相同目录下转发会找到资源。但是从controller&#xff08;根目录&#xff09;里面转发到根目录的下面的目录&#xff0c;转发能过去&…

消除过期的对象引用

http://www.oak.hk/blog/2014/09/28/eliminate-obsolete-object-refrences/ 转载于:https://www.cnblogs.com/reader2012/p/4006299.html

mysql数据库面试总结

mysql数据库相关1. 数据库事务的四个特性及含义2. 视图的作用&#xff0c;视图可以更改么2.1 什么是视图&#xff0c;作用3. drop,delete与truncate的区别4. 索引的工作原理及其种类5. 连接查询的种类6. 数据库范式7. 数据库优化的思路7.1 sql语句的优化7.2 数据库结构优化7.3 …

SQL Server 中索引的禁用与删除

主题 1、 禁用索引 alter index index_name on table_name disable; 主题 2、 删除索引 drop index table_name.index_name; 转载于:https://www.cnblogs.com/JiangLe/p/4007095.html

关于split与StringTokenizer的理解

关于split与StringTokenizer的理解 一.split 依据匹配给定的正則表達式来拆分此字符串。此方法返回的数组包括此字符串的子字符串&#xff0c;每一个子字符串都由还有一个匹配给定表达式的子字符串终止&#xff0c;或者由此字符串末尾终止。数组中的子字符串按它们在此字符串中…

springboot, thymeleaf 教你快速搭建网站

目录项目结构国际化curd操作404页面拦截器地址&#xff1a; https://github.com/sevenyoungairye/spring-boot-study员工管理员系统&#xff0c;页面用html thymeleaf模板数据库用的是map集合&#xff0c;没用真实的数据库项目结构 国际化 默认中文 中文&#xff0c;英文切换…

springboot 整合druid

目录1. maven依赖2. yml配置3. druid配置类编写4. 后台性能监控https://github.com/sevenyoungairye/spring-boot-studydruid优点&#xff1a;提供性能监控&#xff0c;配置灵活丰富 1. maven依赖 <!-- mysql驱动 springboot内置 --><dependency><groupId>…

Ubuntu 查看默认软件安装位置

tags: Linux 方法 1&#xff1a;在命令行输入&#xff1a;dpkg -L 软件包名&#xff1b;方法 2&#xff1a;在/var/cache/apt/archives找的你安装程序的包&#xff0c;然后用gdebi-gtk软件包名可以查看具体安装在什么位置。转载于:https://www.cnblogs.com/svitter/p/4011433.h…

maven 项目管理和构建工具

mvn1. maven 是什么2. maven能解决什么问题3. maven 需要配置和下载4. 使用eclipse创建maven项目5. xml依赖配置 作用范围6. maven的常用命令1. maven 是什么 Maven 在美国是一个口语化的词语&#xff0c;代表专家、内行的意思&#xff0c; Maven是一个项目管理工具&#xff0…

大数据----基于sogou.500w.utf8数据的MapReduce编程

目录 一、前言二、准备数据三、编程实现3.1、统计出搜索过包含有“仙剑奇侠传”内容的UID及搜索关键字记录3.2、统计rank<3并且order>2的所有UID及数量3.3、上午7-9点之间&#xff0c;搜索过“赶集网”的用户UID3.4、通过Rank&#xff1a;点击排名 对数据进行排序 四、参…

Java源代码分析与生成

源代码分析&#xff1a;可使用ANTLRANTLR是开源的语法分析器&#xff0c;可以用来构造自己的语言&#xff0c;或者对现有的语言进行语法分析。JavaParser 对Java代码进行分析CodeModel 用于生成Java代码(但对于已有代码的支持可能有问题) 转载于:https://www.cnblogs.com/laoni…