栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

日志打印高并发场景case记录

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

日志打印高并发场景case记录

case介绍

线上服务OOM,通过Java自带的jvisualvm打开dump文件查看内存对象分析,500个一组,发现前面几组的栈信息全部指向代码中的同一行

LOGGER.info("业务xxxx, xName: {}, xText: {}", xName, xText);

jvisualvm截图如下

case分析(直接扒源码)



跳过N步后

结论归纳

可以看到上图最终是通过构造event参数体填充传入的StringBuffer,对比上面jvisualvm截图可以理解原因如下:

StringBuilder内部通过final修饰的char数组来存储数据,高并发情况短期大量线程构造StringBuilder对象,同时由于方法内部处理逻辑时间可能较长或者StringBuilder随弹栈返回,导致构建的StringBuilder在此期间大量存在最终累积导致OOM

学到的东西

作为技术人,用技术更要懂技术 。对于使用的技术工具最好能深入了解整个流程,一方面做技术规划时有更充分的理由支持技术栈的选择,另一方面也是避免踩坑。
其次,技术栈规划最好是使用社区活跃,适用人群较多的工具、语言,遇到问题排查成本会更小

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/571963.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号