记一次接口执行时间和响应时间相差大的排查过程
qiyuwang 2024-11-26 08:03 7 浏览 0 评论
一、背景
因为项目需要进行私有化部署,对系统关键业务的接口tps、qps都有要求,目标值为单台4C*8G机器qps需要达到250、tps达到200,且响应时间tp99低于300ms。因此利用jmeter对关键接口进行性能测试。
二、测试过程
机器配置:4C*8G(阿里云sae通用型6)
jvm参数配置为
ruby复制代码-Xms5734M -Xmx5734M -Xmn4300M -Xss512k -XX:MetaspaceSize=200M -XX:+UseParNewGC -XX:+UseConcMarkSweepGC -XX:CMSInitiatingOccupancyFraction=85 -XX:+UseCMSInitiatingOccupancyOnly -XX:+PrintReferenceGC -XX:+ParallelRefProcEnabled -XX:+HeapDumpOnOutOfMemoryError
jmeter参数配置:
yaml复制代码thread: 200
Ram-up period: 1
Loop count: 30
三、测试结果
通过配置的监控可看到实际qps为15,接口平均响应时间为1.8s,这跟目标要求相差甚远,且与我的估算值也相差很大,因为这个接口我们做了大量的优化,基本不存在直接查询数据库的情况,对数据做了二级缓存(本地缓存+分布式缓存),并且浏览器接口单次请求响应基本在30ms上下,这30ms包含了从接口返回到页面接收到数据的时间,也就是说服务器接口时间还会比30ms小的多。而实际情况压测情况来看比理论值相差了50倍
四、排查过程
1.查看jvm监控,判断是否jvm参数配置不合理,导致大量的时间在gc。通过监控发现整个过程只有14次youngGC,且没有一次full gc。平均每次youngGC耗时400ms(由于年轻代配置的堆内存较大,也没有细致的对jvm参数调优,这个时间还算正常)。所以基本排除了gc导致接口响应时间长的问题
2.查看cpu监控情况,发现cpu平均使用率为50%左右,最大值为71%,且系统负载也较低,因此也排除cpu的情况
3.根据日志链路追踪查看方法栈调用情况,发现整个接口耗时3s,实际接口处理逻辑只有2ms,并且通过接口日志打印的时间发现也是2ms。
通过调用栈看到整个耗时是在FrameworkServlet.doPost方法上,因此点开源码进行分析,doPost实际执行processRequest方法,通过分析猜测可能finally执行的代码块存在耗时操作(日志打印,日志文件写入等操作?),而且finally里面最后发布一个RequestHandleEvent事件,表示着这个接口处理完成。所以我订阅了一下这个事件,并event.getProcessingTimeMillis()输出耗时时间,结果发现耗时也是毫秒级,说明finally代码块并不存在耗时逻辑。并且还排除自定义filter的拦截器耗时操作的可能性。
4.怀疑是否是带宽限制导致接口处理慢,由于网络问题无法及时返回,但是通过对此排查,发现网络带宽已经调整到最大,且带宽并未打满,因此不可能是网络的问题,同时通过监控也排除了磁盘io问题
5.到此初步能想到的问题都排查了一遍,于是按照生产jvm的配置在本地启动项目进行压测,发现整个qps要比线上高很多,同时通过任务管理器发现此时电脑cpu已经达到100%
这不禁让我感到疑惑,因为在第二步的时候我就通过阿里云监控排查了机器cpu负载发现并不高,难道是监控的值不准确吗?于是我直接进入线上容器同时进行压测,通过命令查看机器cpu负载情况,结果果真如猜想一样,此时cpu负载持续超过200%,而监控上的负载却只有46%。
到这基本上就已经确认是因为cpu负载高导致的接口响应时间慢,前面说过,压测的这几个接口都属于cpu密集型,而且接口耗时也比较短,所以推断是因为tomcat线程数大(springboot默认线程数为200),线程之间频繁切换导致的。调整tomcat配置调整为如下,再重启服务进行压测。
yaml复制代码server:
tomcat:
max-threads: 8
accept-count: 1000
max-connections: 10000
min-spare-threads: 8
测试结果为qps正常达到200,平均响应时间为72ms,最大响应时间为151ms;且通过后续压测,qps能够在1000控制平均响应时间为85ms左右
四、复盘
其实问题原因并不复杂,也还是常见的那些情况之一,在排查的第二步就已经接近真相,只是被阿里云sae监控误导了。
相关推荐
- 微软宣布将于10月份关闭OneDrive组功能
-
【巴士数码】微软已经宣布将在今年10月关闭OneDrive的组功能。一年多之前,微软已经关闭了用户在OneDrive当中创建组的功能。大大多数用户会发现共享文件夹是一种合适的替代品,而且由于这一点,O...
- 玩转Win10任务栏:从基础设置到效率神器的全攻略
-
一、基础操作:解锁任务栏的「隐藏布局」...
- 文档以只读模式打开的原因及解决方法
-
当文档以只读模式打开时,可能由多种原因导致。以下是详细的原因分析与对应解决方法,您可根据实际情况灵活选择操作。一、文件属性设置问题(一)Windows系统在Windows系统中,若文件属性被标记...
- Windows系统的优化(windows优化设置)
-
今天给大家讲一讲系统的图标和一些基本的优化。安装了原版系统之后有很多地方需要优化比如桌面图标小箭头,盾牌,休眠占用内存,关闭通知栏。首先我们打开软件这款软件以前就讲到过就是dism++软件,他可以清理...
- Win 10偷偷传送用户隐私至微软(win10设备隐私)
-
自推出以来Win10不断被揭发盗取用户带宽、泄漏WiFi密码等各式各样的私隐问题,令不少网络专家开始留意Win10还隐藏了多少类似的私隐漏洞。最近再有人发现Win10部分功能静静...
- OneDrive逆势下调存储空间,不限量存储被取消
-
日前,微软在周一晚发布的博客文章中表示,由于部分用户存滥用储存功能,所以该公司将取消不限量OneDrive存储服务。不限量用户的最大存储空间将被下调至1TB,定价为6.99美元,对于已存储较多文件和内...
- Win10中那些被微软取消的功能(微软公司从9日起停止对windows8的主流服务支持)
-
很多用户在使用Win10的时候,都会发现一些在Win7系统中的功能被取消了,有的时候想找也找不到。那么到底是那些过去的功能在Win10中被取消了呢?下面我们就简单梳理一下,并且告诉大家解决的办法。Wi...
- 微软推Win11 Dev 26200.5570预览版:语音打字上线脏话过滤选项
-
IT之家4月26日消息,微软公司昨日(4月25日)发布博文,邀请Dev频道的WindowsInsider项目成员,测试适用于Windows1124H2的KB50556...
- 微软VSCode商店发现9款挖矿恶意插件,已安装超30万次
-
IT之家4月8日消息,科技媒体bleepingcomputer昨日(4月7日)发布博文,报道称安全专家在微软VSCode扩展商店中,发现了9款伪装成开发工具的恶意插件。这些插...
- 微软Windows 11开始菜单大改版!(windows 11 开始菜单)
-
根据最新消息,微软正在对Windows11的开始菜单进行重大改版,这一更新将彻底改变其布局和功能。Windows11的开始菜单将从现有的多栏布局改为单栏可滚动视图,所有固定图标和已安装应用都将集中...
- OneDrive无限存储空间取消 免费降至5GB
-
2015-11-0313:35:06作者:徐鹏北京时间11月3日消息,微软在一篇博客文章中称,将取消OneDrive存储服务的不限量空间,原因是部分用户有滥用问题。OneDrive无限存储空间取消...
- 省出电脑C盘空间!微软悄悄更新:OneDrive终于能卸载了
-
快科技3月12日消息,近日,微软悄悄地在官方更新了关闭、禁用、卸载Windows自带软件OneDrive的方法。微软Windows系统自带了很多软件和功能,其中有很多我们可能永远都用不上。但这些软件还...
- 微软关闭OneDrive新建组群功能(windows关闭onedrive)
-
微软的OneDrive云端储存服务能够让你创建组群(Group),这样当你和团队成员共同从事一个项目的时候能够通过云端协作提升效率,并且组群的文档储存空间还将同你标准的OneDrive分割独立开来。不...
- 微软为何取消OneDrive无限制容量存储?被75TB占用吓坏
-
那么为什么微软会取消Office365的无限OneDrive存储呢?“自推出Office365订阅无限制存储服务以来,一小部分用户开始备份多台PC设备,存储众多电影收藏合集和DVR录像。在某些情况下...
- Win11必关的5个设置!关闭后电脑流畅到起飞,操作简单不藏私!
-
Windows11虽然界面炫酷,但默认设置中隐藏了不少“拖慢电脑”的坑!尤其是老电脑用户,用久了卡顿、开机慢、反应迟钝……其实只需关闭几个鸡肋功能,就能让电脑提速50%以上!...
你 发表评论:
欢迎- 一周热门
- 最近发表
-
- 微软宣布将于10月份关闭OneDrive组功能
- 玩转Win10任务栏:从基础设置到效率神器的全攻略
- 文档以只读模式打开的原因及解决方法
- Windows系统的优化(windows优化设置)
- Win 10偷偷传送用户隐私至微软(win10设备隐私)
- OneDrive逆势下调存储空间,不限量存储被取消
- Win10中那些被微软取消的功能(微软公司从9日起停止对windows8的主流服务支持)
- 微软推Win11 Dev 26200.5570预览版:语音打字上线脏话过滤选项
- 微软VSCode商店发现9款挖矿恶意插件,已安装超30万次
- 微软Windows 11开始菜单大改版!(windows 11 开始菜单)
- 标签列表
-
- navicat无法连接mysql服务器 (65)
- 下横线怎么打 (71)
- flash插件怎么安装 (60)
- lol体验服怎么进 (66)
- ae插件怎么安装 (62)
- yum卸载 (75)
- .key文件 (63)
- cad一打开就致命错误是怎么回事 (61)
- rpm文件怎么安装 (66)
- linux取消挂载 (81)
- ie代理配置错误 (61)
- ajax error (67)
- centos7 重启网络 (67)
- centos6下载 (58)
- mysql 外网访问权限 (69)
- centos查看内核版本 (61)
- ps错误16 (66)
- nodejs读取json文件 (64)
- centos7 1810 (59)
- 加载com加载项时运行错误 (67)
- php打乱数组顺序 (68)
- cad安装失败怎么解决 (58)
- 因文件头错误而不能打开怎么解决 (68)
- js判断字符串为空 (62)
- centos查看端口 (64)