分布式追踪 & APM 系统 SkyWalking 源码分析 —— Collector Client Component 客户端组件

1,750 阅读2分钟
原文链接: www.iocoder.cn
《Dubbo 实现原理与源码解析 —— 精品合集》 《Netty 实现原理与源码解析 —— 精品合集》
《Spring 实现原理与源码解析 —— 精品合集》 《MyBatis 实现原理与源码解析 —— 精品合集》
《Spring MVC 实现原理与源码解析 —— 精品合集》 《数据库实体设计合集》
《Spring Boot 实现原理与源码解析 —— 精品合集》 《Java 面试题 + Java 学习指南》

摘要: 原创出处 www.iocoder.cn/SkyWalking/… 「芋道源码」欢迎转载,保留摘要,谢谢!

本文主要基于 SkyWalking 3.2.6 正式版



1. 概述

本文主要分享 SkyWalking Collector Client Component 客户端组件。Collector 通过客户端,和其他服务进行通信,例如 Elastic Search 、Zookeeper 、H2 等等。

FROM github.com/apache/incu…

下面我们来看看整体的项目结构,如下图所示 :

OK,我们从接口到实现的顺序进行分享。

2. Client

org.skywalking.apm.collector.client.Client ,客户端接口。其定义接口方法如下:

  • #initialize() 方法,初始化客户端。
  • #shutdown() 方法,关闭客户端。

Client 的实现类,如下类图:

3. ElasticSearchClient

org.skywalking.apm.collector.client.elasticsearch.ElasticSearchClient ,Elastic Search 客户端。

基于 org.elasticsearch.client.transport5.5.0 版本,封装 SkyWalking 需要的 Elastic Search 操作。目前用于 collector-storage-es-provider 模块。

4. GRPCClient

org.skywalking.apm.collector.client.grpc.GRPCClient ,gRPC 客户端。

基于 io.grpc.grpc-core1.8.0 版本,封装 SkyWalking 需要的 gRPC 操作。目前用于 collector-remote-grpc-provider 模块。

5. H2Client

org.skywalking.apm.collector.client.h2.H2Client ,H2 数据库客户端。

基于 com.h2database.h21.4.196 版本,封装 SkyWalking 需要的 H2 数据库操作。目前用于 collector-storage-h2-provider / collector-cluster-standalone-provider 模块。

6. RedisClient

org.skywalking.apm.collector.client.redis.RedisClient ,Redis 客户端。

基于 redis.clients.jedis2.9.0 版本,封装 SkyWalking 需要的 Reids 操作。预计未来用于 collector-cluster-redis-provider 模块。

7. ZookeeperClient

org.skywalking.apm.collector.client.zookeeper.ZookeeperClient ,Zookeeper 客户端。

基于 org.apache.zookeeper.zookeeper3.4.10 版本,封装 SkyWalking 需要的 Zookeeper 操作。预计未来用于 collector-cluster-zookeeper-provider 模块。

666. 彩蛋

知识星球

哈哈哈,是不是看的很有成就感( 笔者又在水更了 )。

不要方,下面还有一篇水更。

胖友,分享个朋友圈可好?