tail将输出的日志放到文件中_如何将Spring Boot应用中日志输出格式改为JSON?

2cc12b6a13e5e9ffd42a4ce1b99bec87.png

作者:DEV

出自:解道JDON

原文:jdon.com/55006


今天,我们有了一类称为日志聚合系统的应用程序。当我们拥有大量微服务并且我们希望跨微服务跟踪日志时,日志聚合很有用。

传统的Java应用程序日志如下所示:

2020-09-17 21:56:10.740  INFO [Orders:restartedMain::] o.s.b.w.embedded.tomcat.TomcatWebServer - Tomcat started on port(s): 8080 (http) with context path ''

使用下面方法对日志进行搜索:

cat application.log | grep <your-search>

有人想出了这种不同的方法,为什么在主要用于搜索时为什么不以更可搜索的格式存储日志。JSON碰巧很容易被搜索到,从而进行JSON日志记录。另一种引用方式是结构化日志,因为日志具有定义明确的结构,以后可以用来搜索。

以JSON格式显示的相同应用程序日志如下所示:

{"@timestamp": "2020-06-17T14:41:11.174-04:00","@version": "1","message": "Tomcat initialized with port(s): 8080 (http)","logger_name": "org.springframework.boot.web.embedded.tomcat.TomcatWebServer","thread_name": "restartedMain","level": "INFO","level_value": 20000
}

要以JSON格式记录日志,需要包含2个依赖项。如果您使用maven进行依赖性管理,则将包括以下依赖性

<dependency><groupId>net.logstash.logback</groupId><artifactId>logstash-logback-encoder</artifactId><version>6.4</version>
</dependency>
<dependency><groupId>ch.qos.logback</groupId><artifactId>logback-classic</artifactId><version>1.2.3</version>
</dependency>

在这里,我们使用的是logstash-logback-encoder库

然后,我们可以使用以下代码段将json编码器配置为logback

<encoder class="net.logstash.logback.encoder.LogstashEncoder"><providers><timestamp><timeZone>EST</timeZone></timestamp><pattern><pattern>{"level": "%level","service": "orders","traceId": "%X{X-B3-TraceId:-}","spanId": "%X{X-B3-SpanId:-}","thread": "%thread","class": "%logger{40}","message": "%message"}</pattern></pattern><stackTrace><throwableConverter class="net.logstash.logback.stacktrace.ShortenedThrowableConverter"><maxDepthPerThrowable>30</maxDepthPerThrowable><maxLength>2048</maxLength><shortenedClassNameLength>20</shortenedClassNameLength><rootCauseFirst>true</rootCauseFirst></throwableConverter></stackTrace></providers>
</encoder>

因此,让我们假设您想将数据作为传统日志记录到控制台,并将它们作为json记录到文件,我们可以如下配置logback xml:

<?xml version="1.0" encoding="UTF-8"?>
<configuration><include resource="org/springframework/boot/logging/logback/console.xml"/><appender name="stdout" class="ch.qos.logback.core.ConsoleAppender"><encoder><pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} %5p [Orders:%thread:%X{X-B3-TraceId}:%X{X-B3-SpanId}] %logger{40} - %msg%n</pattern></encoder></appender><appender name="fileout"class="ch.qos.logback.core.rolling.RollingFileAppender"><File>./logs/orders.log</File><rollingPolicy class="ch.qos.logback.core.rolling.FixedWindowRollingPolicy"><maxIndex>8</maxIndex><FileNamePattern>./logs/orders.log.%i</FileNamePattern></rollingPolicy><triggeringPolicyclass="ch.qos.logback.core.rolling.SizeBasedTriggeringPolicy"><MaxFileSize>128MB</MaxFileSize></triggeringPolicy><encoder class="net.logstash.logback.encoder.LogstashEncoder"><providers><timestamp><timeZone>EST</timeZone></timestamp><pattern><pattern>{"level": "%level","service": "orders","traceId": "%X{X-B3-TraceId:-}","spanId": "%X{X-B3-SpanId:-}","thread": "%thread","class": "%logger{40}","message": "%message"}</pattern></pattern><stackTrace><throwableConverter class="net.logstash.logback.stacktrace.ShortenedThrowableConverter"><maxDepthPerThrowable>30</maxDepthPerThrowable><maxLength>2048</maxLength><shortenedClassNameLength>20</shortenedClassNameLength><rootCauseFirst>true</rootCauseFirst></throwableConverter></stackTrace></providers></encoder></appender><root level="info"><appender-ref ref="fileout" /><appender-ref ref="stdout" /></root>
</configuration>

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

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

相关文章

造轮子是什么意思_程序员为什么热衷于造轮子,升职加薪吗?

作者&#xff1a;小傅哥博客&#xff1a; https://bugstack.cn-沉淀、分享、成长&#xff0c;让自己和他人都能有所收获&#xff01;一、前言哪个架构师没造过轮子&#xff1f;你想过这样一件事吗&#xff1f; 是先具备能力在安排职位&#xff0c;还是先安排职位在学习&#xf…

mysql 查看当前数据库编码方式_MySQL查看与修改当前数据库编码的方法

MySQL中&#xff0c;数据库的编码是一个相当重要的问题&#xff0c;有时候我们需要查看一下当前数据库的编码&#xff0c;甚至需要修改一下数据库编码。查看当前数据库编码的SQL语句为&#xff1a;mysql> use xxxDatabase changedmysql> show variables like character_s…

阿里云 服务器 系统 php mysql_阿里云服务器配环境(Ubuntu 16.04+Nginx+MySQL+PHP)并部署hexo博客...

购买服务器阿里云向学生出售优惠价格的服务器&#xff0c;一个月只需9.5块&#xff0c;具体配置看图吧更新Ubuntu源&#xff0c;安装Git123sudo apt updatesudo apt upgradesudo apt-get install git配置Nginx安装Nginxsudo apt install nginx开启Nginx服务sudo service nginx …

python web开发项目 源码_Python + Flask 项目开发实践系列七

对于 Python Flask 这种灵活的web开发框架&#xff0c;在前面的六个系列文章中详细的进行了说明&#xff0c;主要讲到了页面的首页加载时的页面渲染&#xff0c;增加功能&#xff0c;删除功能&#xff0c;修改功能&#xff0c;查询功能&#xff0c;查询详情功能等一些页面常见…

python垃圾回收 采用方式_python-面向对象-10-__del__析构方法/垃圾回收机制

Python语言自带垃圾回收机制&#xff0c;为了能够比较清楚说明白Python的垃圾回收机制的原理&#xff0c;我们今天就从最底层的解释器开始&#xff0c;采用由内到外的方式来说明。1.Python默认解释器CPythonPython语言拥有多种解释器&#xff0c;但是默认采用CPython实现。CPyt…

回调函数 相当于线程_阿里面试题:请简述下 Node 的线程模型

前言如果你有一定的前端基础&#xff0c;比如 HTML、CSS、JavaScript、jQuery&#xff1b;那么&#xff0c;Node.js 能让你以最低的成本快速过渡成为一个全栈工程师(我称这个全栈为伪全栈&#xff0c;我认为的全栈也要精通数据库&#xff0c;不喜勿喷)&#xff0c;从而触及后端…

微信小程序 本地mysql_微信小程序系列之使用缓存在本地模拟服务器数据库

微信小程序系列之使用缓存在本地模拟服务器数据库现在将data.js这个文件视作是本地数据库的初始化数据&#xff0c;要做的第一件事就是讲这些初始化数据装进缓存中&#xff0c;以形成数据库的初始化数据整个应用程序的生命周期&#xff0c;类比一下页面的生命周期&#xff0c;在…

jvm垃圾回收机制_JVM 垃圾回收机制之堆的分代回收

JVM垃圾回收机制之堆的分代回收前言前文我们了解了Java的GC机制&#xff0c;对于堆中的对象&#xff0c;JVM采用引用计数和可达性分析两种算法来标记对象是否可以清除&#xff0c;本文中我们还会了解到JVM将对分成了不同的区域&#xff0c;以便于更好的回收对象。堆的分代Java的…

roadhog不是内部或外部命令_git:git 不是内部或外部命令,也不是可运行的程序

出现git 不是内部或外部命令&#xff0c;也不是可运行的程序解决方案&#xff1a;Windows下配置Git1、从git官网下载windows版本的git&#xff1a;http://git-scm.com/downloads或是从该链接下载对应版本&#xff1a;https://github.com/git-for-windows/git/releases/tag/v2.1…

前端设定项目奖金有多少_【系列二】建筑工程项目激励模式探讨

​​建筑工程一般以项目制的形式运作&#xff0c;如何在这种“一次性”的组织形式下&#xff0c;确保项目符合质量、安全、进度等方面的要求&#xff0c;并确保项目的经济效益&#xff0c;对项目人员实施恰当的项目激励是关键。我们认为&#xff0c;建筑工程项目的激励主要包括…

mysql的分页怎么不对_jsp+mysql分页显示我的怎么不对啊?显示始终不对!

String path request.getContextPath();String basePath request.getScheme()"://"request.getServerName()":"request.getServerPort()path"/";%>My JSP wel.jsp starting page登陆成功&#xff01;恭喜恭喜&#xff01; 返回重新登录用户…

python没有这个xlwt模块_python xlwt模块简介

importxlwtclassWorkbook(object0):工作簿类&#xff0c;使用xlwt创建excel文件时&#xff0c;首先要实例化此类的对象def __init__(self, encodingascii, style_compression0):passdef add_sheet(self,sheetname, cell_overwrite_okFalse):在工作簿中创建工作表:param sheetna…

presto联合查询mysql和ES_presto-mysql/elasticsearch6.0.0安装部署测试,异种数据源关联查询入门实践...

本文简单记录一次实践使用过程&#xff0c;涉及presto-mysql,presto-elasticsearch&#xff0c;文中参数未做注释&#xff0c;请参考官方文档&#xff0c;希望能帮到大家1 下载安装 presto-0.228<1>下载服务端客户端相关jar<2>安装&#xff1a;1> 解压tar -zxvf…

xss过滤器无法处理ajax请求_thunkPHP 预防XSS攻击

比如在有人恶意在你的输入框中或文本域中输入<script>标签&#xff0c;如果不做处理的话&#xff0c;输入框中的<script>会保存到我们数据库中&#xff0c;等到将这个数据拿出来展示的时候&#xff0c;就等于将这个内容放入到了html代码中&#xff0c;那么这个<…

mysql bcmod_nextcloud网盘搭建:Ubuntu18.04+Nginx+Mysql

背景前几天在windows系统上搭建了一个seafile网盘服务器&#xff0c;在试用时对它的功能还是比较满意的&#xff0c;有保存文件&#xff0c;共享文件&#xff0c;小组讨论和小组文件共享等功能&#xff0c;基本上可以满足项目式学习的需求。不过在第一节课上课试用时(一个班大概…

mysql mode_MYSQL中的sql_mode模式

mysql数据库的中有一个环境变量sql_mode,定义了mysql应该支持的sql语法&#xff0c;数据校验等&#xff01;我们可以通过以下方式查看当前数据库使用的sql_mode&#xff1a;mysql>select sql_mode一&#xff0c;sql_mode值的含义ONLY_FULL_GROUP_BY对于GROUP BY聚合操作&…

汇编为什么分段执行总是执行不了_为什么我的计划总是执行不了?这里有你要的答案...

公众号配文&#xff1a;有些计划如泰山一样纹丝不动。说它难吧&#xff0c;又不是很难&#xff0c;奈何动不起来&#xff1f;——————————说起每日计划&#xff0c;很多人觉得&#xff0c;不就是写写行动清单&#xff0c;然后赶紧去做呗。不过&#xff0c;是不是有些计…

mysql unhex乱码_理解和解决MySQL乱码问题

本文将详细介绍MySQL乱码的成因和具体的解决方案在阅读本文之前&#xff0c;强烈建议对字符集编码概念还比较模糊的同学 阅读下博主之前对相关概念的一篇科普&#xff1a;十分钟搞清字符集和字符编码MySQL出现乱码的原因要了解为什么会出现乱码&#xff0c;我们就先要理解&…

单目相机 svd 从图像恢复3维位置_论文学习——VINSMono:一种鲁棒且通用的单目视觉惯性系统...

点击上方“视觉部落”&#xff0c;选择“星标”公众号精选作品&#xff0c;第一时间送达文章同步首发于知乎用户yikang专栏Part 1. 基本信息本文提出了一种基于紧耦合滑动窗口非线性优化方法的单目视觉-惯性系统&#xff0c;来自港科大沈老师实验室。这篇论文的亮点包括提出了效…

识别波峰波谷算法_马丁普林格:波峰-波谷演进法

我们有很多方法来识别趋势&#xff0c;计算机可以轻易地帮助我们实现各种复杂的想法。而在技术允许的条件下&#xff0c;我们还总是有把事物复杂化的倾向。事实也的确如此&#xff0c;目前市面上有无数复杂的方法、指标和程式化黑箱。但很显然&#xff0c;这些复杂的东西除了把…