JAVA-WEB系统问题排查闲扯

排查一些模糊的东西

  • 1.客户反馈系统慢
  • 2.系统假死了
  • 3.前面两点的排查后最终还是要落到某个点的优化(但是如何找到这个点?

遇到这类问题要做的事

  • 1.出问题首先把系统dump文件导出来(切记重启不是第一位)
perl 复制代码
1234 pid
jmap -dump:format=b,file=/var/logs/heap.hprof 1234
  • 2.有一点要注意导dump也不是万能的,也可能是别的系统影响了公用的第三方组件(例如跑不掉的数据库)
  • 3.像系统因为内存不够挂掉的提前做配置项(内存溢出的时候自动导出dump
  • 4.有了有问题的dump我们可以结合代码针对运行的线程,并再测试环境复现或者定位一些问题了。
  • 5.慢的问题需要一个一个去看了比较哪个影响的比较大;
  • 6.假死如何看系统,系统处理不过来了,为什么处理不过来了?单个系统支持的请求就那么多(线程池内能用的线程都被占用了排队等待的又不断涌入你说能不挂吗,重点关注下共性的卡顿点了)
  • 7.通过这个图我们就可以理解限流防挂的意义了吧。

问题如何发现

  • 1.提前防范只能监控告警(一般的监控系统)。
  • 2.一切都是线程池,dynamictp提供线程池级别的监控。
  • 3.因为我没做过互联网项目不知道是否每天有复盘排查慢的地方进行针对优化的
  • 4.一般情况下库的问题比较直接些。数据库和、数据库中间件都有慢sql记录的隔一段时间优化下就可以了。
  • 7.提前防范问题我们可以通过accesslog进行了,通过一定时间的访问记录我们可以知道哪些具体的业务是慢的,针对这个业务我们可以再通过arthas进行准确定位和修复。
相关推荐
普通网友3 分钟前
深入探讨Linux驱动开发:字符设备驱动开发与测试_linux 驱动开发设备号(2)
java·linux·驱动开发
4Forsee5 分钟前
【Android】动态操作 Window 的背后机制
android·java·前端
小二李14 分钟前
第12章 koa框架重构篇 - Koa框架项目重构
java·前端·重构
cike_y17 分钟前
JavaBean&MVC三层架构
java·架构·mvc·javaweb·java开发
漂亮的小碎步丶22 分钟前
【启】Java中高级开发51天闭关冲刺计划(聚焦运营商/ToB领域)
java·开发语言
哈哈老师啊33 分钟前
Springboot简单二手车网站qs5ed(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·spring boot·后端
SadSunset35 分钟前
(19)Bean的循环依赖问题
java·开发语言·前端
⑩-36 分钟前
Java自定义业务异常类
java
Adellle36 分钟前
Java爬虫入门(2/5)
java·爬虫
JIngJaneIL37 分钟前
基于Java+ vue图书管理系统(源码+数据库+文档)
java·开发语言·前端·数据库·vue.js·spring boot·后端