带着之前的疑问,我们先回顾一下日志相关的知识:

首先是SL4J,SL4J是个什么东西来着?官方解释为:“The Simple Logging Facade for Java (SLF4J) serves as a simple facade or abstraction for various logging frameworks (e.g. java.util.logging, logback, log4j) allowing the end user to plug in the desired logging framework at deployment time.” 这非常好理解,它说:“

SL4J是java的日志框架的一个接口规范,利用这个规范,它允许用户在合适的时间衔接他想要的日志框架。”可见,SL4J是一个规范性的接口,而java.util.logging,logback,log4j是SL4J的具体实现,我们在使用SL4J的时候,最好要用SL4J绑定具体框架(e.g. java.util.logging, logback, log4j)的方式,而不是直接用日志框架。

目前用的最最广泛的日志框架是log4j,而且是直接用;但是当前比较流行的用法是:SL4J+logback。

我们闲话少说,回顾一下之前的问题:play是如何实现,只定义一个Logger,就可以打印的呢?

每当遇到问题,最直接的解决方式我认为有两种:1、翻阅官方文档:https://www.playframework.com/documentation/2.3.x/SettingsLogger(这是我翻阅出来的详细地址) 2、程序调试(时间耗费或许会长一点,但是收获绝对多)。

经过一番折腾,我终于发现了端倪:

在play的源码中,出现了下图这两个似成相识的文件:

呵呵,为何它俩和logback的配置文件如此相似???我们打开看看:

这下醉了吧:这特么的就是logback的配置文件好吗?人家还明显说明了:“The default logback configuration that Play uses if no other configuration is provided”

再从代码角度看看,哪里用了这两个文件:

标红框的地方写的清楚吧:application-logger.xml and logger.xml are deprecated methods for supplying the configuration , logback.xml is the documented method, logback-play-default.xml is the fallback that Play uses if no other file is found

人家说:“用application-logger.xml和logger.xml定义成logback的配置文件时可以滴,但是不是很好,写成logback.xml 才是王道,如果没有配置文件,也不用担心,我们还有logback-play-default.xml 这个备胎呢”  我们不禁好奇:那logback-play-dev.xml是做什么的呢? 我们看一下这个文件和那个条件语句:

“env.mode == Mode.Dev”很明显,是在说“在某种模式下”,打开logback-play-dev.xml:

它说:“play在用dev的模式下”用这个。

继续追踪:

发现存在三种模式:Dev、Test和Prod,由之前的代码文档和play文档推断,正常情况下应该不是Dev 模式,显然也不是Test模式,应该是Prod模式。那如何切换到其他模式呢,在play 1.XX的版本中,直接可以在application.conf中设置,但是最新的2.3版本没有了此设置,到底为何,这是另一个问题了,以后探讨。

好了,现在我们知道了,为何play只需定义一个Logger就可以直接打印日志了吧:因为play默认加载了logback-play-default.xml这个文件,这个文件中定义了日志打印的一些配置:appender和pattern。那我们如何自定义一个logback的配置文件呢?

请听下回分解。

playframework 一步一步来 之 日志 (二)的更多相关文章

  1. 一步一步教你编写与搭建自动化测试框架——python篇

    [本文出自天外归云的博客园] 这两天用python写了一个自动化测试框架,取名为Auty.准备用来做Web方面的接口测试,以下为Auty框架一步一步的搭建过程——

  2. 一步一步搭建Jenkins环境

    Jenkins使用经验谈1(一步一步搭建Jenkins环境)在公司使用 Jenkins 软件已经有一段时间了,走了很多弯路,但也积累了一些经验,可以和大家分享一下.我们来一起搭建Jenkins环境.首 ...

  3. 一步一步实现iOS微信自动抢红包

    微信红包 前言:最近笔者在研究iOS逆向工程,顺便拿微信来练手,在非越狱手机上实现了微信自动抢红包的功能.   此教程所需要的工具/文件 yololib class-dump dumpdecrypte ...

  4. 跟我一步一步开发自己的Openfire插件

    http://www.blogjava.net/hoojo/archive/2013/03/07/396146.html 跟我一步一步开发自己的Openfire插件 这篇是简单插件开发,下篇聊天记录插 ...

  5. 一步一步在Windows中使用MyCat负载均衡 下篇

    之前在 一步一步在Windows中使用MyCat负载均衡 上篇 中已经讲了如何配置出MyCat.下面讲其相关的使用. 五.配置MyCat-eye 对于MyCat监控官网还提供一个MyCat-eye w ...

  6. 【DG】[三思笔记]一步一步学DataGuard

    [DG][三思笔记]一步一步学DataGuard 它有无数个名字,有人叫它dg,有人叫它数据卫士,有人叫它data guard,在oracle的各项特性中它有着举足轻理的地位,它就是(掌声)..... ...

  7. jumpservice一步一步安装

    一步一步安装 (CentOS) 本文档旨在帮助用户了解各组件之间的关系, 生产环境部署建议参考 进阶安装文档 云服务器快速部署参考 极速安装 安装过程中遇到问题可参考 安装过程中常见的问题 测试推荐环 ...

  8. 一步一步搭建 oracle 11gR2 rac+dg之grid安装(四)【转】

    一步一步在RHEL6.5+VMware Workstation 10上搭建 oracle 11gR2 rac + dg 之grid安装 (四) 转自 一步一步搭建 oracle 11gR2 rac+d ...

  9. 一步一步搭建oracle 11gR2 rac+dg之database安装(五)【转】

    一步一步在RHEL6.5+VMware Workstation 10上搭建 oracle 11gR2 rac + dg 之database安装 (五)   转自 一步一步搭建oracle 11gR2 ...

  10. 一步一步搭建11gR2 rac+dg之安装rac出现问题解决(六)【转】

    一步一步在RHEL6.5+VMware Workstation 10上搭建 oracle 11gR2 rac + dg 之安装rac出现的问题 (六) 本文转自 一步一步搭建11gR2 rac+dg之 ...

随机推荐

  1. 前端-JavaScript1-2——JavaScript建立认知

    关于首篇的“ Hello world ! ”这事儿吧,挺有意思,就是学习任何的语言,我们都喜欢在屏幕上直接输出一点什么,当做最简单.最基本的案例.输出什么大家随意,但是很多人都习惯输出“hello w ...

  2. Python Day5 模块 包

    一:区分Python文件的2种用途 1个Python文件的2种用途 1.1 当作脚本执行:        if __name__ == '__main__': 1.2 当作模块导入使用     if ...

  3. storj白皮书v3最全面解读,Docker创始人的加入能否扳倒AWS S3

    Storj新发了白皮书v3,地址是:https://storj.io/storjv3.pdf. 这次白皮书一共有90页,看完还真要费不少时间.如果你没有时间看,可以看一下我这篇快速技术解读. 上次St ...

  4. 转:细说ASP.NET Windows身份认证

    转自:https://www.cnblogs.com/fish-li/archive/2012/05/07/2486840.html 细说ASP.NET Windows身份认证 阅读目录 开始 认识A ...

  5. 红黑树Python实现

    # coding=utf-8 # 红黑树Python实现 # 颜色常量 RED = 0 BLACK = 1 def left_rotate(tree, node): if not node.right ...

  6. Openface 入门

    Openface 简单入门 背景 Openface是一个开源的人脸识别框架,同类软件产品还有 seetaface ,DeepID等,当然,如果算上商业的产品,那就更多了. Openface人脸比对结果 ...

  7. maven的单元测试中没有

    原因:BaseTest没有找到单元测试造成的 增加一个空的单元测试 @Testpublic void testNothing(){} 异常现象:在maven项目执行mvn install 或mvn t ...

  8. leetcode42

    class Solution: def calLeft(self,height,rightval,left,right): if left>=right: return 0 sums = 0 m ...

  9. 前端-toggleClass(效果切换,如果存在移除,如果不存在展示)

    <!DOCTYPE html> <html> <head> <meta charset="utf-8" /> <title&g ...

  10. Java中的包装数据类型

    基本类型 包装器类型 boolean Boolean char Character int Integer byte Byte short Short long Long float Float do ...