探索Java的日志世界

本文的思维导图

一、主题

打开日志的大门,探索的Java日志世界

二、目标

  1. 了解常用的日志框架
  2. 掌握日志框架的选择和使用以及开发规范
  3. 了解日志框架中的一些设计思想

三、内容

1、日志及日志框架简介

1.1 、日志简介

1.1.1 、 什么是日志?

1)基本字义是指工作日志 ,详细介绍一个过程和经历的记录。 日志(汉语词汇)

2)网络设备、系统及服务程序等,在运作时都会产生一个叫log的事件记录;每一行日志都记载着日期、时间、使用者及动作等相关操作的描述。 日志(计算机术语)

: 日志可以是有价值的信息宝库,也可以是毫无价值的数据泥潭。

1.1.2. 、什么是Java日志?

Java日志:Java应用程序在运行过程中记录的一些数据信息

如访问的程序中某个接口的时间,请求参数、响应参数等等。

1.2、从System.out.println() 打开Java日志的大门

public static void main(String[] args) {
System.out.println("hello sitech");
}

优点

使用方便和简单!

缺点

  1. 只能输出到控制台,不能输出到文件!
  2. 不能自定义全局的输出格式!(日志级别、日志切割/自动归档、异步打印日志等)
  3. 性能较低,如 println了 synchronized!

1.3、日志框架的简介

Java常用的日志框架对比和深入分析

commons-logging和slf4j都只是一个日志标准,并不是日志系统的具体实现

log4j,logback等等才是日志的真正实现。

2、如何选择及使用日志框架

2.1、如何选择?

接口选一个 、实现选一个实现,组合!

日志门面/接口: SLF4J(即简单日志门面(Simple Logging Facade for Java) );

日志实现:Logbacklog4j

2.2、 如何使用?

2.2.1 、单一日志框架通过slf4J使用 SLF4J user manual(用户使用手册)

注: 每个日志框架的实现都有自己的配置文件。使用slf4j以后,配置文件还是框架自己本身的配置文件;

  1. 导入对应的jar

  2. 编写相应实现的配置文件

  3. 使用slf4j编写日志代码

2.2.2、 在复杂系统如何统一所有的日志都统一到slf4J;legacy APIs
  1. 将系统中其他日志框架先排除出去;
  2. 用中间包来替换原有的日志框架;
  3. 我们导入slf4j其他的实现

2.3、例子

  1. 简单实现slf4j + log4J
  2. 简单实现slf4j + logback
  3. log4j-over-slf4j与slf4j-log4j12共存stack overflow异常分析
  4. 解决办法

log4j-over-slf4j与slf4j-log4j12共存stack overflow异常分析

log4jDelegationLoop

3、 日志开发规范

参考 阿里巴巴Java开发手册(终极版).pdf - 日志规范

4、Slf4j使用到的设计模式

4.1 、设计模式

  1. 工厂模式
  2. 外观模式门面模式
  3. 桥接模式
  4. .....

4.2 、 源码解析

四、 总结和讨论

1、总结

本次分享是Java日志的整体的介绍,其实日志开发中还有很多的细节需要关注!

比如日志的详细使用:日志配置文件编写,日志输出的格式语法,日志输出的级别,日志滚动策略等等

比如日志的设计思想:设计模式、加载原理等等

本此分享只是一个抛砖引玉的过程,日志的相关知识还是特别的多,希望后面大家可以分享出更精彩更深入的日志知识和使用技巧。

2、讨论

1、什么情况下,哪些数据信息需要记录日志?

  • 请求参数
  • 返回参数
  • 时间
  • 服务器IP(分布式)

2、大家谈一下实际日志开发中一些经验技巧?

  • 分布日志排查不方便 --统一日志平台(集中日志收集)ELK
  • 统一日志平台:对日志格式有一定要求
  • 日志文件数据(服务调用日志)

附录

Asynchronous Loggers for Low-Latency Logging:性能对比

log4j2使用介绍

关于日志记录的一些感想

Java日志框架:slf4j作用及其实现原理


如果您觉得这篇博文对你有帮助,请点赞或者喜欢,让更多的人看到,谢谢!

如果帅气(美丽)、睿智(聪颖),和我一样简单善良的你看到本篇博文中存在问题,请指出,我虚心接受你让我成长的批评,谢谢阅读!
祝你今天开心愉快!


欢迎访问我的csdn博客,我们一同成长!

不管做什么,只要坚持下去就会看到不一样!在路上,不卑不亢!

博客首页 : http://blog.csdn.net/u010648555

© 每天都在变得更好的阿飞

探索Java的日志世界的更多相关文章

  1. 探索java世界中的日志奥秘

                    java日志简单介绍 对于一个应用程序来说日志记录是必不可少的一部分.线上问题追踪,基于日志的业务逻辑统计分析等都离不日志.JAVA领域存在多种日志框架,目前常用的日志 ...

  2. 细说Java主流日志工具库

    概述 在项目开发中,为了跟踪代码的运行情况,常常要使用日志来记录信息. 在Java世界,有很多的日志工具库来实现日志功能,避免了我们重复造轮子. 我们先来逐一了解一下主流日志工具. java.util ...

  3. Java主流日志工具库

    在项目开发中,为了跟踪代码的运行情况,常常要使用日志来记录信息.在Java世界,有很多的日志工具库来实现日志功能,避免了我们重复造轮子.我们先来逐一了解一下主流日志工具. 1.java.util.lo ...

  4. 深入探索Java设计模式之单例模式

    单例模式可确保在给定的时间实例中只能创建一个具有全局访问点的对象.这是面向对象编程中最常用的技术之一.尽管它很简单,但从类设计的角度来看可能是最简单的,但是在尝试实现它们之前,必须先解决一些细微的问题 ...

  5. Java 标准日志工具 Log4j 的使用(附源代码)

    源代码下载 Log4j 是事实上的 Java 标准日志工具.会不会用 Log4j 在一定程度上可以说是衡量一个开发人员是否是一位合格的 Java 程序员的标准.如果你是一名 Java 程序员,如果你还 ...

  6. 探索 Java 同步机制[Monitor Object 并发模式在 Java 同步机制中的实现]

    探索 Java 同步机制[Monitor Object 并发模式在 Java 同步机制中的实现] https://www.ibm.com/developerworks/cn/java/j-lo-syn ...

  7. Java自定义日志输出文件

    Java自定义日志输出文件 日志的打印,在程序中是必不可少的,如果需要将不同的日志打印到不同的地方,则需要定义不同的Appender,然后定义每一个Appender的日志级别.打印形式和日志的输出路径 ...

  8. Java GC 日志详解(转)

    Java GC日志可以通过 +PrintGCDetails开启 以ParallelGC为例 YoungGC日志解释如下(图片源地址:这里) : FullGC(图片源地址:这里): http://blo ...

  9. java Log日志规范

    Overview 一个在生产环境里运行的程序如果没有日志是很让维护者提心吊胆的,有太多杂乱又无意义的日志也是令人伤神.程序出现问题时候,从日志里如果发现不了问题可能的原因是很令人受挫的.本文想讨论的是 ...

随机推荐

  1. ASP.NET MVC验证框架中关于属性标记的通用扩展方法

    http://www.cnblogs.com/wlb/archive/2009/12/01/1614209.html 之前写过一篇文章<ASP.NET MVC中的验证>,唯一的遗憾就是在使 ...

  2. UDP ------ UDP Broadcast Address

    Related information link : 百度百科---->广播地址 Use restrictions: 1. You can only broadcast on the same ...

  3. JS中的继承链

    我们首先定义一个构造函数Person,然后定义一个对象p,JS代码如下: function Person(name) { this.name = name; } var p = new Person( ...

  4. Spark记录-Scala函数与闭包

    函数声明 Scala函数声明具有以下形式 - def functionName ([list of parameters]) : [return type] Scala 如果不使用等号和方法体,则隐式 ...

  5. JAVA记录-JSP指令

    JSP中有三种类型的指令标签 - 序号 指令 说明 1 <%@ page ... %> 定义页面相关属性,如脚本语言,错误页面和缓冲要求. 2 <%@ include ... %&g ...

  6. POJ - 2299 Ultra-QuickSort(归并排序)

    https://vjudge.net/problem/POJ-2299 题意 求对于给定的无序数组,求出经过最少多少次相邻元素的交换之后,可以使数组从小到大有序. 分析 很明显是求逆序对的数目,那就要 ...

  7. CF #442 div2

    A 判断下5个名字出现了几次.pre数据巨弱,就这么一水题在std测刷掉了非常多的人.. /** @Date : 2017-10-24 16:04:41 * @FileName: A.cpp * @P ...

  8. Android手机间无线互传功能探索及实现

    年前研究了一下Android如何实现无线互传的功能,写了个小demo,最近无事,遂整理一下,与各位共享.前期调研发现,Android想要实现无线互传有以下几种技术:1,Bluetooth通行已久,简单 ...

  9. 如何提升mysql replication的性能&amp;多线程传输二进制日志

    1,最好使用内网或者专线链路传输binlog数据 (千兆网卡.还不够的话,bounding 技术,扩展带宽) 在my.cnf中强制使用内网ip传输数据bind-address=ip2,将二进制保存在独 ...

  10. nagios报警延迟的解决--flapping state

    这个问题是在测试中发现的.因为要在服务器上布置nagios用来监控oracle,可是发现手动shutdown数据库后能够很快报警,但是再startup后就不是很及时,有时会延迟很久.经过研究发现了这个 ...