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

日志打印高并发场景case记录,第1张

日志打印高并发场景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随d栈返回,导致构建的StringBuilder在此期间大量存在最终累积导致OOM

学到的东西

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

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/5563206.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-12-14
下一篇 2022-12-14

发表评论

登录后才能评论

评论列表(0条)

保存