源文章:structlog4j介绍

结构化日志对于日志的收集的作用挺大的,根据自身的业务场景,基于SLF4J实现了structlog4j

相关引用

Gradle

  1. // 基础包
  2. compile 'tech.ibit:structlog4j-api:latest'
  3. // 支持json, yaml格式等扩展
  4. compile 'tech.ibit:structlog4j-extend:latest'

Maven

  1. <!--基础包-->
  2. <dependency>
  3. <groupId>tech.ibit</groupId>
  4. <artifactId>structlog4j-api</artifactId>
  5. <version>latest</version>
  6. </dependency>
  7. <!--扩展包-->
  8. <dependency>
  9. <groupId>tech.ibit</groupId>
  10. <artifactId>structlog4j-extend</artifactId>
  11. <version>latest</version>
  12. </dependency>

概述

structlog4j的核心思想就是将日志已key-value的方式呈现,方便日期切分。

日志保留字段

  1. _message: 消息内容
  2. _errorMessage: 异常信息
  3. _stackTrace: 异常stack trace信息

引入logger

  1. import tech.ibit.structlog4j.Logger;
  2. import tech.ibit.structlog4j.StructLoggerFactory;
  3. private static final Logger log = StructLoggerFactory.getLogger(Test.class);

字符串处理

业务需要,将日志单行输入,所以对以下字符进行了处理, ":"前原字符串,":" 后的是处理后的字符

  1. \t: \\t
  2. \r: \\r
  3. \n: \\n

默认日志格式(key-value)

  1. _message=Something error!&user=ibit-tech_errorMessage=Test Exception

说明

  • 默认方式引入structlog4j-api即可
  • key-value的方式通过&进行分割,将&转为'%26'

json日志格式

  1. {"_message":"Something error!","user":"ibit-tech","_errorMessage":"Test Exception"}

修改全局formatter方法

  1. 方法1java代码):
  2. StructLog4J.setFormatter(JsonFormatter.getInstance());
  3. 方法2classpath:/structlog4j.properties):
  4. formatter=tech.ibit.structlog4j.extend.JsonFormatter#getInstance

说明

  • 需要引入structlog4j-extend
  • "#"后面为获取实例方法

yaml日志格式

  1. hostname: localhost\nip: 127.0.0.1

修改全局formatter方法

  1. 方法1java代码):
  2. StructLog4J.setFormatter(YamlFormatter.getInstance());
  3. 方法2classpath:/structlog4j.properties):
  4. formatter=tech.ibit.structlog4j.extend.YamlFormatter#getInstance

说明

  • 需要引入structlog4j-extend
  • "\n":表示换行符号,读取到日志之后,需要将"\n"转为"\n"才能正确显示
  • "#"后面为获取实例方法

自定义日志格式

实现tech.ibit.structlog4j.Formatter#format方法即可

  1. tech.ibit.structlog4j.Formatter {
  2. /**
  3. * 格式化(待实现)
  4. *
  5. * @param kvMap 兼职map
  6. * @return 格式化后的文本
  7. */
  8. String format(Map<String, ?> kvMap);
  9. }

异常信息处理

  • 默认方式,StructLog4J.isTransStackTrace() == true, 日志中会出现_errorMessage_stackTrace字段,_stackTrace进行了转义,单行显示
  • StructLog4J.isTransStackTrace() == false, 日志中只出现_errorMessage,然后之后就将异常信息在接下来的日志打印出来(多行)

eg:

  1. # 单行打印stackTrace
  2. _message=Something error&user=ibit-tech&_errorMessage=Test Exception&_stackTrace=java.lang.RuntimeException: Test Exception\n\tat tech.ibit.demo.structlog4j.Demo.main(Demo.java:32)\n
  3. # 多行打印stackTrace
  4. _message=Something error&user=ibit-tech&_errorMessage=Test Exception
  5. java.lang.RuntimeException: Test Exception
  6. at tech.ibit.demo.structlog4j.Demo.main(Demo.java:33)

修改全局transStackTrace方法

  1. 方法1java代码):
  2. StructLog4J.setTransStackTrace(true|false);
  3. 方法2classpath:/structlog4j.properties):
  4. transStackTrace=true|false

structlog4j.properties说明:

  1. # 指定formatter 创建方式(工厂方法)
  2. formatter=tech.ibit.structlog4j.extend.JsonFormatter#getInstance
  3. # 指定异常的stackTrace日志是否需要转化
  4. transStackTrace=true

用法

_message说明(以error为例子)

Logger存在一下方法支持error级别日志

  1. /**
  2. * ERROR日志
  3. *
  4. * @param message 消息
  5. * @param params 参数
  6. */
  7. void error(String message, Object... params);
  8. /**
  9. * ERROR日志
  10. *
  11. * @param messages 消息片段
  12. * @param params 参数
  13. */
  14. void error(Object[] messages, Object... params);

其中message和messages的区别在于,messages支持传入占位符,eg:

  1. logger.error("Something error, id: 12, username: ibit-tech");
  2. 等价于:
  3. logger.error(new Object[] {"Something error, id: {}, username: {}", 12, "ibit-tech"});

使用key-value的方式

  1. log.error("Something error", "user", "ibit-tech", "age", 100);

实现ToLog对key-value进行包装

  1. log.error("Something error", (ToLog) () -> new Object[] {"user", "ibit-tech", "age", 101});

异常处理

  1. log.error("Something error", "user", "ibit-tech", "age", 100, new RuntimeException("Test Exception"));

混合使用

  1. log.error("Something error", (ToLog) () -> new Object[] {"user", "ibit-tech"}, "age", 101);
  2. log.error("Something error", (ToLog) () -> new Object[] {"user", "ibit-tech"}, "age", 101, (ToLog) () -> new Object[] {"city", "sz"}, new RuntimeException("Test Exception"));

POJO实现MapToLog,toLog()会返回POJO中所有字段

  1. @Test
  2. public void toLog() {
  3. User user = new User("ibit-tech", 21);
  4. Assert.assertEquals("[name, ibit-tech, age, 21]", Arrays.asList(user.toLog()).toString());
  5. }
  6. @Value
  7. public class User implements MapToLog {
  8. private String name;
  9. private int age;
  10. }

说明

  • 需要引入structlog4j-extend

License

Apache License 2.0

【转载】structlog4j介绍的更多相关文章

  1. 转载 VPN介绍

    转载原地址:  http://aajs800.blog.51cto.com/519255/239724  原作者 aajs800 原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 .作者 ...

  2. [转载]Scikit-learn介绍几种常用的特征选择方法

    #### [转载]原文地址:http://dataunion.org/14072.html 特征选择(排序)对于数据科学家.机器学习从业者来说非常重要.好的特征选择能够提升模型的性能,更能帮助我们理解 ...

  3. [转载]Masonry介绍与使用实践(快速上手Autolayout)

    原博地址 http://adad184.com/2014/09/28/use-masonry-to-quick-solve-autolayout/ 前言 1 MagicNumber -> aut ...

  4. 转载 WebBrowser介绍——Javascript与C++互操作

    注:本文来自于 http://www.cnblogs.com/lucc/archive/2010/11/24/1886087.html WebBrowser控件是Microsoft提供的一个用于网页浏 ...

  5. 转载:简单介绍Python中的try和finally和with方法

    用 Python 做一件很平常的事情: 打开文件, 逐行读入, 最后关掉文件; 进一步的需求是, 这也许是程序中一个可选的功能, 如果有任何问题, 比如文件无法打开, 或是读取出错, 那么在函数内需要 ...

  6. 转载 GUID介绍

    转载 http://www.cnblogs.com/illele/archive/2008/02/25/1080554.html GUID(Global unique identifier)全局唯一标 ...

  7. 【转载】介绍“Razor”— ASP.NET的一个新视图引擎

    最近在做一个项目,用的MVC razor 视图,因为之前没用这个视图做过,于是查阅文档资料,共享一下. https://msdn.microsoft.com/zh-cn/ff849693 内容主要是讲 ...

  8. 转载:介绍AD另外一种奇葩的多通道复用的方法

    原文链接:http://www.eda365.com/forum.php?_dsign=74fe4957&mod=viewthread&page=1&tid=110710 在设 ...

  9. 转载 1-EasyNetQ介绍(黄亮翻译) https://www.cnblogs.com/HuangLiang/p/7105659.html

    EasyNetQ 是一个容易使用,坚固的,针对RabbitMQ的 .NET API. 假如你尽可能快的想去安装和运行RabbitMQ,请去看入门指南.EasyNetQ是为了提供一个尽可能简洁的适用与R ...

随机推荐

  1. [校内训练19_09_03]c Huge Counting

    题意 有一个定义在 k 维非负整点上的函数:$f(x_1,x_2,...,x_k):N_{0}^{k}->\{0,1\}$ ,定义方法如下: 若存在$j∈[1,k],x_j=0$,则$f(x_1 ...

  2. 腾讯云ubuntu服务器无法以root身份ssh连接

    在腾讯云上拿到的Ubuntu主机分配给的用户是ubuntu用户,并不是root用户,而阿里云上拿到的Ubuntu主机分配给的用户就是root用户.如果没有root用户权限做事情会变得麻烦,每次做什么都 ...

  3. 报错requests.exceptions.InvalidSchema: No connection adapters were found for

    刚开始学习,使用requests时,敲了点demo import requests params = { "name": "name", "passw ...

  4. MGR监控报警

    一.报警思路 m.conf文件记录配置信息,只需要修改这个文件的内容即可(需要将mysql_stat.sh里面的信息写到这里,进行中) mysql_stat.sh文件作为MGR状态监测脚本,加入定时任 ...

  5. Docker深入浅出系列 | Image实战演练

    目录 课程目标 Container与Image核心知识回顾 制作Docker Image的两种方式 Dockerfile常用指令 Image实战篇 通过Dockerfile制作Image 通过Dock ...

  6. Django面试集锦(51-65)

    目录 51.Django中filter和exclude的区别? 52.Django中values和values_list的区别? 53.如何使用django orm批量创建数据? 54.Django的 ...

  7. DOCKER 学习笔记7 Docker Machine 建立虚拟机实战,以及错误总结

    前言 通过以上6小节的学习,已经可以使用DOCKER 熟练的部署应用程序了.大家都可以发现使用 DOCKER 带来的方便之处,因为现在的话,只是在一台服务器上部署,这样部署,我们只需要一条命令,需要的 ...

  8. 如何在国内下载Eclipse及其插件

    北京理工大学 http://mirror.bit.edu.cn/eclipse/ 中国科学技术大学 http://mirrors.ustc.edu.cn/eclipse/ 大连东软信息学院 http: ...

  9. 当你的程序在朋友的机器上显示丢失msvcr100d.dll的时候

    0. 给朋友发了个DEMO,收到提示:丢失 msvcr100d.dll 1. 一看是运行库文件,赶紧让朋友下载并安装vc++ 2010 redistribution,朋友反馈还是提示丢失这个dll文件 ...

  10. Codeforces_821

    A.直接判断每一个数. #include<bits/stdc++.h> using namespace std; ][]; int main() { ios::sync_with_stdi ...