接口返回 2 万条数据,easy-trans导致多了20s耗时排查过程

内网访问排版核料详情功能,用户反馈要等十几秒

 

排查 sql:sql 比较简单

排查内存计算:arthus trace 类名 方法名  总耗时2s

排查页面渲染是否缓慢:F12 查看接口 等待服务器响应 20s 下载时间 30s, 故不考虑渲染问题

排查请求响应日志打印:关闭请求响应日志拦截器 问题依然存在

本地还原数据 idea postman单独调接口:返回 12M ,耗时依然存在啊,跟页面无关

排查序列化问题:接口方法返回值改成 String, 把响应结果使用 ObjectMapper序列化成 json字符串(获取容器的 objectMapper) 不存在耗时,跟序列化貌似无关

排查框架问题,把接口方法复制到新的 springboot项目中,不存在问题,断定框架存在问题

排查拦截器、或过滤器问题:从 controller 方法的 return开始 debug ,经过层层 debug, 在RequestResponseBodyAdviceChain..beforeBodyWrite 发现长时间停顿,再次 debug 发现easy-trans拦截器,项目中开启了全局扫描,关闭easy-trans全局扫描:

easy-trans: is-enable-global: false

中间猜测有什么特殊注解,没想到没有注解光trans扫描就很耗时(项目体量大了,注解都敢用:接口日志注解。spring创建的bean多了,启动慢,@Data编译也慢)数据量、体量一大,什么问题都放大

问题解决

收获:使用arthus查看各个业务方法的耗时,不需要添加日志来实现

解决问题思路:不懂原理,了解信息不够,通过猜想,拼接基础知识,不断各种试验(歇一歇停一停就会有新思路),找到一个线索后,逐渐挖掘,一步步接近,拼接运气:easy-tran拦截器正好在controller方法结束时就调用,如果埋藏在各个拦截器中,通过debug很难找出来,springmvc源码不好debug。

 

新收获:RestController可直接返回string(手动序列化再返回),前端依然可以兼容

如果是string,springmvc 的converter发现string直接发送,不再json序列化

 

 

 

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

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

相关文章

AIGC入门,手搓大模型客户端与MCP交互

概述 在现代应用开发中,将大语言模型(LLM)与专用工具服务相结合,可以构建出既能理解自然语言,又能准确执行专业任务的智能代理。本文介绍一个基于 MCP(Model Context Protocol)协议和 Ollama 本…

深度学习:从预备知识到未来展望

在当今数字化时代,深度学习正以前所未有的速度改变着我们的生活和工作方式。从智能语音助手到自动驾驶汽车,从精准医疗到个性化推荐系统,深度学习的应用无处不在。本文将从深度学习的预备知识入手,探讨其发展历程、关键技术和未来…

软考高级系统架构设计师之构件与中间件技术篇

一、构件的定义 定义1:软件构件是一种组装单元,它具有规范的接口规约和显式的语境依赖。软件构件可以被独立地部署并由第三方任意地组装。 定义2:构件是某系统中有价值的、几乎独立的并可替换的一个部分,它在良好定义的体系结构语境内满足某清晰的功能。…

Node.js 文件上传中文文件名乱码问题,为什么只有Node会有乱码问题,其他后端框架少见?

问题现象当用户上传包含中文字符的文件时,在服务器端获取到的文件名可能变成类似 ‹•–‡.txt 这样的乱码,而不是预期的中文文件名。为什么只有Node会乱码?很多后端框架(如 Java Spring Boot、Python Django、PHP Laravel&#x…

学习英语音标 (从汉语角度看英语音标发音差异)

仅供参考, 跟着教学视频看不懂时再来看以下引导 以下只写容易出错的音标 发音视频: https://www.jiwake.com/yinbiaofayin/ 音标规则单词ɜː类似汉语e, 饿~urgeə类似汉语e, 饿goɔː类似汉语o, 哦~walkɒ类似汉语o, 哦washɪ/iː/的短语, 不止发声短,舌头不用隆起itʃ类似汉…

论文笔记(九十一)GWM: Towards Scalable Gaussian World Models for Robotic Manipulation

GWM: Towards Scalable Gaussian World Models for Robotic Manipulation文章概括摘要1. 引言2. 相关工作3. 高斯世界模型(Gaussian World Model)3.1. 世界状态编码(World State Encoding)3.2. 基于扩散的动态建模(Dif…

apache phoenix sql 命令大全详解

这是一份非常详细的 Apache Phoenix SQL 命令大全和详解。Phoenix 作为 HBase 上的 SQL 层,其语法大部分与标准 SQL 兼容,但也有许多针对 HBase 的特性扩展。核心概念 在开始之前,请记住 Phoenix 的两个核心概念: 主键&#xff08…

【代码讲解】SO-ARM100 双场景演示:手柄驱动 Mujoco 仿真 + 实机控制

视频讲解: 【代码讲解】SO-ARM100 双场景演示:手柄驱动 Mujoco 仿真 实机控制今天介绍下使用使用北通手柄通过控制 Mujoco 中的 SO-ARM100 机械臂,然后将关节数据通过 zmq 通信转发控制实际机械臂。 本期中会涉及如下点,需要注意…

「数据获取」《中国教育经费统计年鉴》(1997-2024)

01、数据简介《中国教育经费统计年鉴》作为我国教育经费领域的核心统计典籍,全面系统地呈现了全国各级各类教育经费的来源构成、分配流向与使用成效。其统计范围覆盖学前教育、基础教育、中等职业教育、高等教育及特殊教育等全学段,数据维度涵盖财政性教…

使用 Logspout 收集所有容器的

1.将所有容器的输出路由到远程 rsyslog 服务器1.修改 rsyslog 配置文件/etc/rsyslog.conf, 从中找到 “# Provides UDP sysilog recepion"语句。并将该处的以下两行配置代码行首的“#”字符删除(取消注释)[roothost1 ~]# vi /etc/rsyslog.conf [roo…

【智能化解决方案】基于多目标优化检索增强生成的智能行程规划方案

📝 基于多目标优化的智能行程规划方案 1 用户需求分析与矩阵构建 1.1 核心用户信息提取 根据用户提供的年龄、出发地、目的地、出行时间等基本信息,我们首先构建一个用户特征向量: U {Age, Origin, Destination, TravelDate, Duration, Budg…

软件研发的演变

软件研发从一门手工作坊式的艺术,逐步演进为一门系统化、工程化、智能化的现代学科。其发展历程不仅体现了技术的飞跃,更反映了方法论、协作模式和思维方式的深刻变革。一、发展演变历程软件研发的演变可以大致划分为以下几个阶段:1. 软件作坊…

「日拱一码」091 机器学习——集成学习

目录 集成学习介绍 1. 核心思想 2. 为什么有效? 3. 主要流派与方法 A. 并行方法:Bagging (Bootstrap Aggregating) B. 串行方法:Boosting C. 堆叠法:Stacking 代码示例 Bagging 的代表 —— 随机森林 (Random Forest) 集成…

vscode实现第三方包的使用,cmake结合vcpkg(跨平台)

要使用cmake和vcpkg组织一个完整的现代cpp项目,一般来说需要三个文件vcpkg.json描述第三方依赖项//vcpkg.json {"dependencies": ["fmt"] }//安装,在vcpkg.json目录执行 vcpkg installCMakePresets.json定义项目的本质属性(What&…

DevExpress中Word Processing Document API学习记录

文章目录1 文档结构划分2 文档操作基础2.1 Positions and Ranges2.2 Secitions2.3 Paragraphs2.4 Tables2.5 Lists2.6 Hyperlinks and Bookmarks2.7 Comments2.8 Headers and Footers2.9 Shapes and Pictures2.10 Watermarks2.11 Charts2.12 OLE Objects2.13 ActiveX Controls2…

Roo Code 的差异_快速编辑功能

什么是差异编辑? 简单来说,差异编辑就像是一位细心的装修师傅:他不会把整个房子拆掉重盖,而是精准地只修补需要改动的部分。Roo Code 的这项功能默认开启,它通过比对代码差异(diff)来实施修改&a…

【Axure高保真原型】标签树分类查询案例

今天和大家分享标签树分类查询案例的原型模版,效果包括: 树形分类——点击左侧树形里的箭头,可以展开或收起子级选项; 查询表格——点击标签树里的选项,如果是末级选项,可以筛选右侧表格用户标签&#xf…

容器化部署项目05

一、工作原理 镜像:容器的模板,包括容器运行时所需的数据 容器:运行中的进程,依赖镜像运行,镜像的具现化 镜像你可以把它看成Python中的类,而容器可以看做是类的实例化对象。 一个类可以有多个对象&#xf…

微信小程序 工作日历 周计划日报 修改等提报和状态展示功能,支持h5,Android ,ios,基于uniapp,适配vue2和vue3

Work-calendar 介绍 (底部附链接) 基于uni-calendar做的定制化开发,主要功能为工作日历展示和提报组件 ​ 1.支持周计划日报状态展示且可配置 ​ 2.支持农历展示配置,回到当日,月份切换 ​ 3.日历,周报…

openharmony 鸿蒙 下 利用蓝牙API(a2dp模块-高级音频,ble模块-低功耗蓝牙等)完成对蓝牙音响的控制(蓝牙广播)

1.首先是登录页面(利用webapi 和本地数据存储完成登陆操作) 2.添加设备(利用ble.startBLEScan 和 ble.on("BLEDeviceFind", onReceiveEvent);完成蓝牙扫描与显示) 3.蓝牙ble连接(利用ble.createGattClientDe…