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进行准确定位和修复。
相关推荐
Nobody_Cares28 分钟前
JWT令牌
java
沐浴露z29 分钟前
Kafka入门:基础架构讲解,安装与使用
java·分布式·kafka
神秘的土鸡33 分钟前
从数据仓库到数据中台再到数据飞轮:我的数据技术成长之路
java·服务器·aigc·数据库架构·1024程序员节
vir021 小时前
P1928 外星密码(dfs)
java·数据结构·算法·深度优先·1024程序员节
摇滚侠1 小时前
全面掌握PostgreSQL关系型数据库,备份和恢复,笔记46和笔记47
java·数据库·笔记·postgresql·1024程序员节
掘金码甲哥1 小时前
两张大图一次性讲清楚k8s调度器工作原理
后端
间彧2 小时前
Stream flatMap详解与应用实战
后端
间彧2 小时前
Java Stream流两大实战陷阱:并行流Parallel误用、List转Map时重复键异常
后端
eguid_12 小时前
【开源项目分享】JNSM1.2.0,支持批量管理的jar包安装成Windows服务可视化工具,基于Java实现的支持批量管理已经安装服务的可视化工具
java·开源·jar·1024程序员节·windows服务·jar包安装成服务·exe安装成服务
杯莫停丶3 小时前
设计模式之:享元模式
java·设计模式·享元模式