(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
分享到:
相关推荐
这个压缩包文件“PaddleDetection-develop”包含了使用PaddleDetection实现rt-detr模型的相关代码和配置,rt-detr是一种实时的、轻量级的目标检测方法,特别适合于资源有限的设备。 PaddleDetection框架提供了多种...
【标题】"jdk1.8-Btrace.rar"指的是一个针对Java开发的特殊工具包,它包含了一个名为Btrace的在线检测插件。这个插件专为Java开发者设计,旨在帮助他们在应用程序运行时进行问题的实时定位,而无需停止或重启服务。...
基于tensorflow搭建Faster R-CNN实现目标检测任务 有代码 有数据 可直接运行。 Faster R-CNN 实现目标检测 tensorflow 基于tensorflow搭建Faster R-CNN实现目标检测任务 有代码 有数据 可直接运行。 Faster R-CNN ...
1. **动态性**:BTrace可以在运行时动态地插入代码到正在运行的Java应用中,无需停止或重新启动服务,极大地提高了调试效率。 2. **安全性**:BTrace遵循安全模型,只允许执行预定义的安全脚本,防止对系统造成破坏...
btrace-bin直接解压缩配置环境变量后即可运行使用。 java监控调试工具虚拟机监控程序,利用BTrace可以在线监控java程序状态。 BTrace是一种安全,动态的Java跟踪工具。BTrace通过动态(字节码)检测正在运行的Java...
缺陷检测-基于深度学习的道路裂缝缺陷检测代码和使用文档-优质项目实战算法选择 由于本项目是为了更加深入的熟悉语义分割,所以使用传统的unet网络进行训练,不做其他模型之间的对比。 推理加速方案 在推理方面,...
这个压缩包文件"VisualVM--BTrace"很可能包含了安装和使用BTrace插件所需的所有资源。 BTrace的工作原理是基于字节码注入,它可以让你编写简单的Java脚本,这些脚本会在运行时被插入到目标应用程序的类中。通过这种...
信息系统应用安全代码检测标准
BTrace利用了字节码注入的技术,能够在不修改原有代码的情况下,动态地向目标应用添加追踪代码,帮助开发者获取到运行时的详细信息,从而更好地理解和优化应用性能。 在描述中提到,BTrace与OpenSolaris上的DTrace...
MQ-2气体传感器: 应用:适用于家庭或工厂的...3、代码使用KEIL 开发,当前在STM32F103C8T6运行,如果是STM32F103其他型号芯片,依然适用,请自行更改KEIL芯片型号以及FLASH容量即可。 4、技术服务:349014857@qq.com
该代码实现rt-detr的部署,使用python,调用tensorRT转换后的模型,实现单张图片或者图片文件夹批量推理,代码输入图片/文件夹路径,模型路径,输出图片保存路径,运行命令python ./infer_tensorrt.py --infer_dir=....
5. **应用实例**:BTrace常用于诊断性能瓶颈、检测线程死锁、监控内存使用、分析SQL查询等。例如,可以创建一个脚本来记录所有数据库访问,以找出慢查询。 6. **与其他工具集成**:BTrace也可以与持续集成系统、...
毕业设计基于深度学习的舌苔检测系统源代码+毕业论文-基于神经网络模型efficient Net对舌象图片数据进行图像分类,个人经导师指导并认可通过的毕业设计项目,评审分98分,项目中的源码都是经过本地编译过可运行的,...
阿里巴巴的p3c-pmd-2.1.1.jar是一款专为Java开发者设计的代码质量检测工具,旨在提升代码质量并遵循阿里巴巴内部的编码规范。该插件是基于开源项目PMD进行定制和优化,旨在帮助开发团队在早期阶段发现并修复潜在的...
此资源为红外图像盲元检测与修复的示例python代码,或者说是红外图像坏点检测与修复,另外还有那一份灰度均衡的代码,方便可视化坏点修复前后的效果。本算法通过统计图像像素直方图的方法,按照某个设定的比例,把一...
2、代码特点:内含运行结果,不会运行可私信,参数化编程、参数可方便更改、代码编程思路清晰、注释明细,都经过测试运行成功,功能ok的情况下才上传的。 3、适用对象:计算机,电子信息工程、数学等专业的大学生...
这个压缩包文件“STM32使用MQ-2代码及资料.zip”包含了使用STM32微控制器配合MQ-2传感器进行气体检测的相关教程和代码资源。 首先,关于STM32的基础知识,它拥有强大的处理能力、丰富的外设接口和低功耗特性。在本...
基于机器学习的android恶意代码检测,n-gram opcode + RandomForest.zip本资源中的源码都是经过本地编译过可运行的,评审分达到95分以上。资源项目的难度比较适中,内容都是经过助教老师审定过的能够满足学习、使用...
系统以FPGA为核心单元,通过硬件描述语言进行具体设计,随后进行模块仿真,再利用Quartus软件进行布局布线,最后将图像下载至DE1-SOC评估板上进行场景测试。 2. 摄像头传感器配置 系统首先通过I2C协议配置摄像头...