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进行准确定位和修复。
相关推荐
番茄去哪了4 分钟前
一篇文章讲懂SDN
java·spring
AC赳赳老秦9 分钟前
OpenClaw + 华为云自动化:批量管理云资源、生成月度云账单分析与成本优化报告
java·开发语言·javascript·人工智能·python·mysql·openclaw
我是一颗柠檬15 分钟前
【Java项目技术亮点】读写分离+主从延迟处理:MySQL高并发下的性能优化方案
java·分布式·mysql·性能优化
qq_25183645715 分钟前
基于java Web 哈尔滨文化活动网站毕业论文
java·开发语言·前端
Java知识技术分享17 分钟前
安装sourcetree
java·git·源代码管理
geovindu25 分钟前
go: Coroutines Pattern
开发语言·后端·设计模式·golang·协程模式
Stick_ZYZ26 分钟前
A2A:让 Agent 从单兵作战走向团队协作
java·开发语言·网络·人工智能·python·ai
天才少年曾牛27 分钟前
Android新增服务添加selinux权限
android·java·frameworks
knighthood200127 分钟前
ros2-quick-runner插件v0.0.4版本发布
android·java·开发语言
程序猿乐锅28 分钟前
【JAVASE | 第十八篇】Java 反射
java