当前位置: 首页 > news >正文

【Java】Logbook优化接口调用日志输出,优雅!

logbook 简介

很多人可能没有接触过 logbook,但它的确是一个很好用的日志框架。引用官网的介绍

Logbook 是一个可扩展的 Java 库,可以为不同的客户端和服务器端技术启用完整的请求和响应日志记录。它通过以下方式满足了特殊需求:

  • 允许 Web 应用程序开发人员记录应用程序接收或发送的任何 HTTP 流量 ,这意味着只要是 HTTP 请求它都可以选择记录日志
  • 以一种易于持久化和分析的方式。这对于传统的日志分析、满足审计要求或调查个别历史流量问题非常有用。

具体介绍可以参考 链接: logbook 官网

使用logbook

这边主要讲解logbookspringBoot2的整合
logbook 官方提供了 logbook-spring-boot-starter

简单使用

引入依赖

<!--按照官方要求 为了 Spring 5 / Spring Boot 2 向后兼容,需要导入如下依赖-->
<dependency><groupId>org.zalando</groupId><artifactId>logbook-servlet</artifactId><version>3.9.0</version><classifier>javax</classifier>
</dependency>
<dependency><groupId>org.zalando</groupId><artifactId>logbook-spring-boot-starter</artifactId><version>3.9.0</version>
</dependency>

添加配置

logging:level:org.zalando.logbook: TRACE

写个测试接口就可以看到日志了

{"origin": "remote", //remote 代表远程请求,local 代表本地发出的请求 例如 Feign"type": "request","correlation": "b2b2b8e449d7b650", //请求唯一id"protocol": "HTTP/1.1","remote": "0:0:0:0:0:0:0:1","method": "GET","uri": "http://localhost:8080/consumer","headers": {"accept": ["text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.9"],"accept-encoding": ["gzip, deflate, br"],"accept-language": ["zh-CN,zh;q=0.9"],"cache-control": ["max-age=0"],"connection": ["keep-alive"],"host": ["localhost:8080"],//...省略}
}

选择日志风格

logbook 提供了多种日志风格,默认是 JSON ,在 application.yml 中通过以下配置选择

logbook:format:style: json #默认值,可选值还有 curl、http、splunk

转载: 原文

http://www.lryc.cn/news/388021.html

相关文章:

  • LabVIEW电压电流实时监测系统
  • 骁龙相机拍照流程分析
  • sql-语句
  • 解决Vue3项目中跨域问题的步骤
  • macos scroll direction
  • Websocket实现方式二——注解方式
  • 零基础开始学习鸿蒙开发-页面导航栏布局设计
  • 【Hive中常见的优化手段----数据采集!Join 优化!Hive索引!数据倾斜!mapreduce本地模式!map和reduce数量调整!】
  • 【面试系列】软件工程师高频面试题及详细解答
  • Qt开发 | Qt界面布局 | 水平布局 | 竖直布局 | 栅格布局 | 分裂器布局 | setLayout使用 | 添加右键菜单 | 布局切换与布局删除重构
  • LW-DETR: A Transformer Replacement to YOLO for Real-Time Detection
  • 前端技术(二)——javasctipt 介绍
  • FireFox 编译指南2024 Windows10篇-环境准备(一)
  • Spring Boot中的热部署配置
  • 用ChatGPT快速打造一个专业WordPress网站
  • dsp入门
  • Java并发编程-Atomiclnteger、LongAdder等原子类的使用及案例实战
  • 九浅一深Jemalloc5.3.0 -- ②浅*size class
  • JavaScript——属性的增删改查
  • 51单片机第15步_串口多机通讯使用CRC8校验
  • WPF----进度条ProgressBar(渐变色)
  • Apipost接口测试工具的原理及应用详解(四)
  • 【图论】200. 岛屿问题
  • AI学习指南机器学习篇-随机森林的优缺点
  • 基于boost::beast的http服务器(上)
  • 深度学习之近端策略优化(Proximal Policy Optimization,PPO)
  • 用pycharm进行python爬虫的步骤
  • 重写功能 rewrite
  • ISO19110操作要求类中/req/operation/operation-attributes的详细解释
  • 访客(UV)、点击量(PV)、IP、访问量(VV)概念