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