javaagent的优势

截选:https://blog.csdn.net/u012410733/article/details/104878111
1、为什么系统需要监控
随着分布式服务框架的流行,特别是微服务等设计理念在系统中应用,业务的调用链越来越复杂。
在这里插入图片描述

可以看到,随着服务的拆分,系统的模块变得越来越多,不同的模块可能由不同的团队维护。

一个调用请求可能会涉及到几十个服务协同处理,牵扯到多个团队的业务系统,那么如何快速定位到线上故障?如何有效的进行相关的数据分析工作?

对于大型网站系统,如淘宝、京东等大型互联网公司,这些问题尤其突出。

2、如何对服务埋点
我们如何在代码中添加监控信息,一般有以下三种情况:

在系统中使用硬编码的形式来添加监控代码
使用 AOP 面向切面的形式来添加监控代码
使用 Java 高级特性 Java Agent 在 JVM 层面来 AOP 添加监控代码
在系统中使用硬编码的情况对于单体系统来说来可以用用,但是对于分布式系统,就不太适合了。同样的使用 AOP 编程对于每一个系统都必须引入切面以及相应的切面配置,对于小型分布式系统来说还勉强可以。对于成百上千个服务集群来说简直是一个噩梦。所以对于大型系统一般都是采用 Java Agent 这个 JVM 层面的 AOP 来添加监控逻辑。也就是字节码增强,这样对于业务代码可以零倾入。

xxx.java ==> xxx.class ==> jvm 指令码 ==> 汇编 ==> CPU

如上图所示, Java 程序需要运行时:首先 Java 源代码需要编译成 Class 文件,文件的内容就由若干条 JVM 指令组成的集合(即代码逻辑)。插桩的过程就是将这些指令,拆开来,然后再插入监控所需指令,最后进行重新组装生成新的 Class 字节。

3、Java Agent
javaagent 是 java 1.5 之后引进的特性,其主要作用是在 class 被加载之前对其拦截,已插入我们的监听字节码。Agent分为两种,一种是在 main 程序之前运行的 Agent,一种是在主程序之后运行的 Agent(前者的升级版,1.6以后提供)下面我们分别来举例说明。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java Agent是一种Java应用程序的扩展方式,通过在应用程序启动时加载Agent,可以在不修改原始代码的情况下实现对应用程序的监控和修改。Agent可以通过字节码注入的方式,在运行时动态修改应用程序的字节码,实现埋点操作。 埋点是指在应用程序中插入一些代码,用于记录关键的业务逻辑和性能指标。通过在Java Agent中实现埋点功能,可以方便地获取应用程序的执行过程和性能数据,以及关键业务逻辑的执行情况。 Java Agent埋点的实现方式通常涉及对类加载机制的hook和字节码编译技术。Agent可以通过在类加载之前修改字节码,将需要埋点的代码动态插入到应用程序中。埋点代码可以是用于记录日志、收集性能数据、统计方法执行时间等。 与传统的静态埋点相比,Java Agent埋点的优势在于不需要修改原始代码,且可以在运行时动态修改应用程序的行为。这种方式不会对原始代码产生任何影响,也不会增加部署的复杂性。同时,Java Agent还可以提供更加细粒度的监控和修改能力,可以对特定的方法、类和类加载器进行监控和修改。 总之,Java Agent埋点是一种非侵入式的监控和修改应用程序的方式。通过加载Agent并在运行时修改字节码,可以方便地实现埋点操作,用于记录关键的业务逻辑和性能指标,从而提供更好的应用程序监控和调优能力。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值