(1)你是否有时发现线上的代码运行效率不高,但却无法定位到底具体是哪一段代码?
(2)你是否有时在测试环境中苦苦测试,最后却发现测试环境和生产环境差距太大而导致测试结果不可信?
恭喜你,本文恰好符合你的需求。
1什么是BTrace
BTrace是sun推出的一款java性能监控工具,利用java agent 和 jvm attach技术来实现运行时java程序的跟踪和替换,可以不停机的情况下监控线上情况,并且做到最少的侵入,占用最少的系统资源。BTrace的脚本是用纯java编写的,基于一套官方提供的annotation,使跟踪逻辑实现起来异常简单。详细信息可以参考:http://kenai.com/projects/btrace
2如何使用BTrace
(1)下载btrace包 http://kenai.com/projects/btrace/downloads/directory/releases。 目前最新的版本是1.2
(2).设置环境变量。
(3).定制自己需要的脚本,一般是自己写一个Java文件。
(4).jps命令查出需要监控的jvm pid。
(5).调用命令btrace <pid> <自己定制的脚本> <输出文件> eg:btrace 3045 PrintExecuteTime.java > time.log
3 使用示例
本次我们是因为morgan中DefaultMemberService的updateActivedBaseSite方法效率非常低,在测试环境下,发现各个机器上差距很大,不能完全定位性能。从测试机器上的测试结果来看,初步怀疑有两个点的性能可能存在问题:
(1)进行数据库的update的操作
(2)Napoli发送消息
按照如下示例代码(监控时间):
import static com.sun.btrace.BTraceUtils.name;
import static com.sun.btrace.BTraceUtils.print;
import static com.sun.btrace.BTraceUtils.println;
import static com.sun.btrace.BTraceUtils.probeClass;
import static com.sun.btrace.BTraceUtils.probeMethod;
import static com.sun.btrace.BTraceUtils.str;
import static com.sun.btrace.BTraceUtils.strcat;
import static com.sun.btrace.BTraceUtils.timeMillis;
import com.sun.btrace.annotations.BTrace;
import com.sun.btrace.annotations.Kind;
import com.sun.btrace.annotations.Location;
import com.sun.btrace.annotations.OnMethod;
import com.sun.btrace.annotations.TLS;
/**
* 监控方法耗时
*
* @author jerry
*/
@BTrace
public class PrintTimes {
/**
* 开始时间
*/
@TLS
private static long startTime = 0;
/**
* 方法开始时调用
*/
@OnMethod(clazz = "/com\\.jerry\\../", method = "/.+/")
public static void startMethod() {
startTime = timeMillis();
}
/**
* 方法结束时调用<br>
* Kind.RETURN这个注解很重要
*/
@SuppressWarnings("deprecation")
@OnMethod(clazz = "/com\\.jerry\\../", method = "/.+/", location = @Location(Kind.RETURN))
public static void endMethod() {
print(strcat(strcat(name(probeClass()), "."), probeMethod()));
print(" [");
print(strcat("Time taken : ", str(timeMillis() - startTime)));
println("]");
}
}
书写了附件中的测试代码MorganTraceTest.java,并在线上找了一台机器试验:btrace <pid> MorganTraceTest.java > time.log
截取其中一部分结果如附件中time.log,可以看到真正的数据库update方法占用时间相对是较少的,反而DefaultEventService.publishEvent(发napoli消息)占用时间较多,问题基本定位。
4使用时注意
(1)BTrace的功能远不止监控运行时间,还可以监控Annotation,内存等各种资源,大家可以更深入的研究。
(2)鉴于此监控对线上环境还是有些许影响的(虽然非常小),所以我们在监控时时分几次每次半小时,而没有长期一直开启。建议大家时候时还是小心比较好,并且把这作为排查的最后一个手段,而不是第一手段,毕竟线上环境直接影响到用户,进行保持线上环境问题,是每位工程师的责任。
以上信息,参考页面:http://www.iteye.com/topic/652653
其他详细参考资料请见:
BTrace 用户指南 http://kenai.com/projects/btrace/pages/UserGuide
BTrace 开发者指南 http://kenai.com/projects/btrace/pages/DeveloperGuide
分享到:
相关推荐
【标题】"jdk1.8-Btrace.rar"指的是一个针对Java开发的特殊工具包,它包含了一个名为Btrace的在线检测插件。这个插件专为Java开发者设计,旨在帮助他们在应用程序运行时进行问题的实时定位,而无需停止或重启服务。...
1. **动态性**:BTrace可以在运行时动态地插入代码到正在运行的Java应用中,无需停止或重新启动服务,极大地提高了调试效率。 2. **安全性**:BTrace遵循安全模型,只允许执行预定义的安全脚本,防止对系统造成破坏...
MQ-2气体传感器: 应用:适用于家庭或工厂的...3、代码使用KEIL 开发,当前在STM32F103C8T6运行,如果是STM32F103其他型号芯片,依然适用,请自行更改KEIL芯片型号以及FLASH容量即可。 4、技术服务:349014857@qq.com
信息系统应用安全代码检测标准
BTrace是一款强大的Java应用程序动态跟踪工具,它允许开发者在不修改源代码或重新启动应用的情况下,对正在运行的Java应用程序进行实时的性能分析和诊断。这款工具的核心在于其字节码注入技术,它能够动态地在类的...
在Java开发中,线上问题的排查往往是一项挑战,尤其是在生产环境中无法通过常规的日志分析来定位问题时。本文将介绍两款强大的Java...通过熟练掌握这类工具,可以极大地提高问题解决的效率,保障线上服务的稳定运行。
此资源为红外图像盲元检测与修复的示例python代码,或者说是红外图像坏点检测与修复,另外还有那一份灰度均衡的代码,方便可视化坏点修复前后的效果。本算法通过统计图像像素直方图的方法,按照某个设定的比例,把一...
本文将深入探讨如何在Source Insight这款流行的源代码编辑器中集成并使用PC-lint进行静态代码检测。 首先,我们要了解PC-lint的基本功能。PC-lint能够检查源代码中的语法错误、风格问题、潜在的运行时错误、未初始...
5. 保存和分享你的BTrace脚本,便于团队成员共同使用和改进。 总之,BTrace Workbench是Java开发者的一个强大助手,它使得复杂的应用性能问题变得更容易理解和解决。通过集成在jVisualVM中,它提供了直观的界面和...
C#内存检测工具是开发过程中不可或缺的辅助软件,主要用于诊断和优化C#应用程序的内存使用情况。在.NET框架下,C#程序的内存管理主要由垃圾收集器(Garbage Collector, GC)负责,但理解并控制内存使用仍然是开发者...
系统以FPGA为核心单元,通过硬件描述语言进行具体设计,随后进行模块仿真,再利用Quartus软件进行布局布线,最后将图像下载至DE1-SOC评估板上进行场景测试。 2. 摄像头传感器配置 系统首先通过I2C协议配置摄像头...
# 卷积神经网络CNN火焰识别...- 使用PyTorch的数据加载器和数据流水线来加载和预处理图像数据。 - 训练过程中使用了Adam优化器和BCEWithLogitsLoss损失函数。 - 在训练过程中,模型的权重会被保存,以便获取最佳模型。
330-用数码管显示动态检测结果(51单片机C语言实例Proteus仿真和代码)330-用数码管显示动态检测结果(51单片机C语言实例Proteus仿真和代码)330-用数码管显示动态检测结果(51单片机C语言实例Proteus仿真和代码)330-用...
2、代码特点:内含运行结果,不会运行可私信,参数化编程、参数可方便更改、代码编程思路清晰、注释明细,都经过测试运行成功,功能ok的情况下才上传的。 3、适用对象:计算机,电子信息工程、数学等专业的大学生...
"5目标检测模型测试.ipynb"则涉及模型的测试和验证,这一步会应用训练好的模型对新的图像进行预测,查看模型能否准确地定位和识别出铁路线上的异物。结果可能会以输出图像"output.jpg"的形式展示,其中包含有预测的...
61-8位端口检测8独立按键(51单片机C语言实例Proteus仿真和代码)61-8位端口检测8独立按键(51单片机C语言实例Proteus仿真和代码)61-8位端口检测8独立按键(51单片机C语言实例Proteus仿真和代码)61-8位端口检测8独立按键...
# Graduation毕业设计课题:基于异常检测技术的恶意代码对抗样本识别--------该资源内项目源码是个人的毕设,代码都测试ok,都是运行成功后才上传资源,答辩评审平均分达到96分,放心下载使用!<项目介绍>1、该资源...
matlab说话代码 SpeedBumps-Detection 数据集: YOLO v3:./images/dataset/xqqds-0620-train/和./images/dataset/xqqds-0620-val/ CNN Classifier:./classifier/bbox/ 模型文件和权重: 上传到 运行: 下载darknet...
运行安全--防火墙与入侵检测.pptx