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进行准确定位和修复。
相关推荐
spencer_tseng1 小时前
Stream not available [SysDictDataMapper.xml]
xml·java
蒸蒸yyyyzwd5 小时前
cpp对象模型学习笔记1.1-2.8
java·笔记·学习
qq_297574676 小时前
【实战教程】SpringBoot 集成阿里云短信服务实现验证码发送
spring boot·后端·阿里云
程序员徐师兄6 小时前
Windows JDK11 下载安装教程,适合新手
java·windows·jdk11 下载安装·jdk11 下载教程
RANCE_atttackkk7 小时前
[Java]实现使用邮箱找回密码的功能
java·开发语言·前端·spring boot·intellij-idea·idea
五岳7 小时前
DTS按业务场景批量迁移阿里云MySQL表实战(下):迁移管理平台设计与实现
java·应用·dts
韩立学长8 小时前
【开题答辩实录分享】以《智能大学宿舍管理系统的设计与实现》为例进行选题答辩实录分享
数据库·spring boot·后端
zhougl9968 小时前
Java 所有关键字及规范分类
java·开发语言
Python 老手8 小时前
Python while 循环 极简核心讲解
java·python·算法
java1234_小锋8 小时前
Java高频面试题:MyISAM索引与InnoDB索引的区别?
java·开发语言