日志框架 - 基于SpringBoot 2.0 - 完整使用手册

相对于日志框架 - 基于spring-boot - 使用入门,这是本框架升级到SpringBoot 2.0版本的使用说明书

由于种种原因,本框架暂时未共享到开源社区,因此,代码不是对所有人开放的。

1. 基础使用说明

1.1 版本要求

本框架基于spring-boot-2.0.6.RELEASE与Java 8版本开发,应用必须兼容此版本,才能正常添使用本框架。

1.2 添加maven依赖

<dependency>
    <groupId>com.cmsz</groupId>
    <artifactId>xpay-framework</artifactId>
    <version>1.3.0-SNAPSHOT</version>
</dependency>

1.3 最小示例配置

以下配置放置于Spring-Boot的配置文件(properties或yaml)中。

#关键字定义,用逗号进行分隔
xpay.framework.logging.keywords=Order-No,Activity-Code,Req-Sys,Province
#定义系统日志的格式,使用logback的语法
xpay.framework.logging.logback.system.encoder.pattern=\
  %level#%date{yyyy-MM-dd HH:mm:ss.SSS}#\
  %mdc{APPLICATION_NAME}_%mdc{IP}_%mdc{PORT}#%mdc{Order-No}#\
  %mdc{Activity-Code}#%mdc{Req-Sys}#%mdc{Province}#%logger{5}:%msg%n%wEx

xpay.framework.logging.keywords 用于定义关键字, 系统会根据关键字自动搜索请求消息中的对应内容信息。

支持的消息格式包括XML、Json、Key-Value,同时还支持在Key-Value中嵌入的XML与Json。关键字可以是处于任意层级的元素。

xpay.framework.logging.logback.system.encoder.pattern 定义的是系统运行日志的格式,用的是logback的语法,但不支持${}, 因为与spring的转义符相冲突。

如logback一样,本框架也为用户提供了默认关键字供用户使用,包括

  1. APPLICATION_NAME(取spring.application.name配置的值)
  2. IP(本机网卡IP)
  3. PORT(取server.port配置的值)
  4. HOSTNAME(主机名)。

1.4 在代码中使用slf4j接口打印日志

private Logger logger = LoggerFactory.getLogger(getClass());

logger.info("some infomation")
logger.error("this is an error")

框架约定,info级别的日志只会被打印到系统日志文件(system-log)中,warn及error级别的日志除了在系统日志文件中打印,还会再被打印到告警日志文件(alarm-log)中。

2. 样例代码

如果你是我们内部成员,那么你可以在本框架的同个 GIT 库中找到日志框架使用的样例代码,这对使用这个框架有一定帮助。

3. 高级功能

3.1 消息关键字(自定义MessageKeyword类)

上文中xpay.framework.logging.keywords配置项定义了来自消息报文中的关键字,框架在收到消息时会自动从报文中提出对应的取值。但在实际应用中,情况其实更为复杂。

比如从消息报文中提出流水号,有些消息中关键字是ReqTransId,而有些消息却是SessionId;又比如有时取到的值是“REQ”,但却要在报中打印“发送请求”

因此,框架提供了MessageKeyword类供用户自定义。可如下定义。

    @Bean
    public MessageKeyword logIndicationKeyword() {
        return new MessageKeyword(
                "Indication",
                new String[]{"activityCode", "ActivityCode"},
                new ValueConverter() {
                    @Override
                    public String convert(String field, String realValue) {
                        if (realValue.contains("U101_001")) {
                            return "支付请求";
                        } else {
                            return "其它";
                        }
                    }
                }
        );
    }

构造MessageKeyword需要3个参数:

  1. 第一个是mdcKey:表示日志格式中的字段名称,如上面的代码,日志格式里关键字会被配置为%mdc{Indication}
  2. 第二个是fields:表示在消息报文中的名称,如上面的代码,在消息报文中的关键字可能是activityCodeActivityCode
  3. 第三个是一个接口:其作用允许用户自定义转换输出,比如上面的代码,当从消息报文中获取的值为 U101_001 时,打印日志时会在%mdc{Indication}位置输出"支付请求"

3.2 自定义消息报文打印(使用@MessageToLog注解)

在需要自定义打印报文的地方,可以使用 @MessageToLog 注解。

@RequestMapping(path = "/get", method = RequestMethod.GET)
@MessageToLog(addition = "返回消息")
public @ResponseBody OrderInfo orderGet(OrderInfo info) {
    service.doService(info);
    return info;
}

添加 @MessageToLog 注解表示此方法的返回值被视作消息打印到消息日志文件中,返回的对象可以不实现 toString() 方法,框架会自动转换为Json格式打印。

4. 附录:完整配置

日志完整配置项及默认配置如下:

#spring-boot自带配置,指定日志文件的所在目录。
logging.path=./log
#spring-boot自带配置,指定日志文件名,但此日志在
logging.file=spring.log

#是否使用此log框架,默认为true
xpay.framework.logging.enabled=true
#是否将打印到文件的日志在console输出,此配置项是为方便开发人员调试,设置为true时,打印到文件的日志会同时打印到控制台。
xpay.framework.logging.log-to-console=false

#由于logback日志名称是根据包名来命名,必须确定第一个非root logger的名称,以保证logger被正常管理。
#此配置项默认项目使用com作为包名的起始名称,可以相应的修改为org,cn等值
xpay.framework.logging.package.root=com

#此executor线程池用于保证上下文在父子线程间传递,应作为默认的TaskExecutor使用,此处配置其最大并发线程数
xpay.framework.executor.max-pool-size=16

#关键字配置,前文有说明。
xpay.framework.logging.keywords=

#自动打印消息日志开关,false表示不自动打印接收的消息日志
xpay.framework.logging.print-message=true
#消息日志的文件名配置,采用logback语法,会按文件大小滚动输出
xpay.framework.logging.logback.message.filename.pattern=%d{yyyy-MM-dd}/message.log.%d{yyyy-MM-dd}
#消息日志的内容格式,采用logback语法
xpay.framework.logging.logback.message.encoder.pattern=%d{yyyy-MM-dd HH:mm:ss.SSS} %msg%n
#消息日志会按文件名及大小滚动输出,每个文件大小等于此处配置时触发滚动
#xpay.framework.logging.logback.message.max-file-size=200MB

#系统日志的文件名配置,采用logback语法,会按文件大小滚动输出
xpay.framework.logging.logback.system.filename.pattern=\
        %d{yyyy-MM-dd}/info.log.%d{yyyy-MM-dd}
#系统息日志的内容格式,采用logback语法
xpay.framework.logging.logback.system.encoder.pattern=\
        %d{yyyy-MM-dd HH:mm:ss.SSS} -%5p %X{PID:- } --- [%t] %-40.40logger{39} : %m%n%wEx
#系统日志会按文件名及大小滚动输出,每个文件大小等于此处配置时触发滚动
xpay.framework.logging.logback.system.max-file-size=200MB

#告警日志的文件名配置,采用logback语法,告警日志每天只产生一个文件,只按时间滚动输出
xpay.framework.logging.logback.alarm.filename.pattern=alarm/alarm.log.%d{yyyy-MM-dd}
#告警息日志的内容格式,采用logback语法
xpay.framework.logging.logback.alarm.encoder.pattern=\
        %d{yyyy-MM-dd HH:mm:ss.SSS} -%5p %X{PID:- } --- [%t] %-40.40logger{39} : %m%n%wEx
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,711评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,079评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,194评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,089评论 1 286
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,197评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,306评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,338评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,119评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,541评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,846评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,014评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,694评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,322评论 3 318
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,026评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,257评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,863评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,895评论 2 351

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,644评论 18 139
  • Spring Boot 参考指南 介绍 转载自:https://www.gitbook.com/book/qbgb...
    毛宇鹏阅读 46,789评论 6 342
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,914评论 25 707
  • 1、通过CocoaPods安装项目名称项目信息 AFNetworking网络请求组件 FMDB本地数据库组件 SD...
    阳明先生_X自主阅读 15,975评论 3 119
  • 休息真好,吃好吃的,看好看的电影,满足
    FineYoga小如阅读 145评论 0 0