javaagent的优势

随着微服务的普及,系统监控变得至关重要,用于快速定位故障和数据分析。本文介绍了如何通过硬编码、AOP和JavaAgent进行服务监控。JavaAgent在JVM层面实现字节码增强,对业务代码零侵入,特别适用于大型分布式系统。它允许在类加载前插入监听字节码,是大型互联网公司如淘宝、京东解决监控问题的有效手段。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

截选:https://blog.youkuaiyun.com/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以后提供)下面我们分别来举例说明。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值