当一个接口响应时间非常长时,如何定位问题并解决?
1、先拿到curl。浏览器netWork --> copy as curl 如果是app则抓包下,copy出来.如下:
curl -H 'Host: ' -H 'Cookie: uid=CgoUFF/J3UVXIkMEB0//Ag==' -H 'apptype: 3' -H 'user-agent: ling zhi wen zhen ce shi/2.1.2 (iPhone; iOS 14.0; Scale/2.00)' -H 'storeid: ' -H 'deviceuuid: 6E47AC24-5477-4CB3-9E97-F0689776DFBA' -H 'accountid: 1293541453032587288' -H 'appversion: 2.1.2' -H 'client: ios' -H 'version: 2.1.2' -H 'usertype: GROUPUSER' -H 'sign: 89BEE7049DF61EFFFBA226AE076023F9' -H 'token: 9a2123abccbee8fcee1d0265a4bb3d44' -H 'timestamp: 1608776144395' -H 'accept-language: en;q=1' -H 'accept: */*' -H 'content-type: application/json;charset=utf-8' -H 'appver: 3' --data-binary '{"token":"9a2123abccbee8fcee1d0265a4bb3d44","organSign":"ZHL0009529","activityType":1}' --compressed '/patient/rights/verify'
2、curl 改造。在curl和-H前加入:
"\ntime_namelookup: "%{time_namelookup}"\ntime_connect: "%{time_connect}"\ntime_appconnect: "%{time_appconnect}"\ntime_pretransfer: "%{time_pretransfer}"\ntime_starttransfer: "%{time_starttransfer}"\ntime_redirect: "%{time_redirect}"\ntime_total: "%{time_total}"\n"
3、改造后的curl如下:
curl -w "\ntime_namelookup: "%{time_namelookup}"\ntime_connect: "%{time_connect}"\ntime_appconnect: "%{time_appconnect}"\ntime_pretransfer: "%{time_pretransfer}"\ntime_starttransfer: "%{time_starttransfer}"\ntime_redirect: "%{time_redirect}"\ntime_total: "%{time_total}"\n" -H 'Host: ' -H 'Cookie: uid=CgoUFF/J3UVXIkMEB0//Ag==' -H 'apptype: 3' -H 'user-agent: ling zhi wen zhen ce shi/2.1.2 (iPhone; iOS 14.0; Scale/2.00)' -H 'storeid: ' -H 'deviceuuid: 6E47AC24-5477-4CB3-9E97-F0689776DFBA' -H 'accountid: 1293541453032587288' -H 'appversion: 2.1.2' -H 'client: ios' -H 'version: 2.1.2' -H 'usertype: GROUPUSER' -H 'sign: 89BEE7049DF61EFFFBA226AE076023F9' -H 'token: 9a2123abccbee8fcee1d0265a4bb3d44' -H 'timestamp: 1608776144395' -H 'accept-language: en;q=1' -H 'accept: */*' -H 'content-type: application/json;charset=utf-8' -H 'appver: 3' --data-binary '{"token":"9a2123abccbee8fcee1d0265a4bb3d44","organSign":"ZHL0009529","activityType":1}' --compressed '/patient/rights/verify'
4、执行curl。结果如下:
time_namelookup: 0.253
time_connect: 0.257
time_appconnect: 0.361
time_pretransfer: 0.361
time_starttransfer: 5.618
time_redirect: 0.000
time_total: 5.618
5、相关含义如下:
6、如果时间大部分是time_starttransfer 减去time_pretransfer的值。则代表此请求慢的原因在服务器业务代码执行部分。
7、业务代码耗时代码快定位。使用arthas排查即可。
8、启动arthas.
java -jar arthas-boot.jar
9、选择Java进程。输入序号。
10、执行 类全名 + 方法名
trace com.xxxx.service.impl.xxxxServiceImpl xxxMethod
11、查看耗时调用。
如果觉得《接口响应时间长问题排查流程》对你有帮助,请点赞、收藏,并留下你的观点哦!