黑马程序员技术交流社区

标题: 【上海校区】分布式追踪 & APM 系统 SkyWalking 源码分析 ——... [打印本页]

作者: 不二晨    时间: 2018-7-23 09:54
标题: 【上海校区】分布式追踪 & APM 系统 SkyWalking 源码分析 ——...
1. 概述
本文主要分享 SkyWalking Collector Client Component 客户端组件。Collector 通过客户端,和其他服务进行通信,例如 Elastic Search 、Zookeeper 、H2 等等。
Client Component 在 SkyWalking 架构图处于如下位置( 红框 ) :
FROM https://github.com/apache/incubating-skywalking
下面我们来看看整体的项目结构,如下图所示 :
OK,我们从接口到实现的顺序进行分享。
2. Client
org.skywalking.apm.collector.client.Client ,客户端接口。其定义接口方法如下:
Client 的实现类,如下类图:
3. ElasticSearchClient
org.skywalking.apm.collector.client.elasticsearch.ElasticSearchClient ,Elastic Search 客户端。
基于 org.elasticsearch.client.transport 的 5.5.0 版本,封装 SkyWalking 需要的 Elastic Search 操作。目前用于collector-storage-es-provider 模块。
4. GRPCClient
org.skywalking.apm.collector.client.grpc.GRPCClient ,gRPC 客户端。
基于 io.grpc.grpc-core 的 1.8.0 版本,封装 SkyWalking 需要的 gRPC 操作。目前用于 collector-remote-grpc-provider 模块。
5. H2Client
org.skywalking.apm.collector.client.h2.H2Client ,H2 数据库客户端。
基于 com.h2database.h2 的 1.4.196 版本,封装 SkyWalking 需要的 H2 数据库操作。目前用于 collector-storage-h2-provider /collector-cluster-standalone-provider 模块。
6. RedisClient
org.skywalking.apm.collector.client.redis.RedisClient ,Redis 客户端。
基于 redis.clients.jedis 的 2.9.0 版本,封装 SkyWalking 需要的 Reids 操作。预计未来用于 collector-cluster-redis-provider 模块。
7. ZookeeperClient
org.skywalking.apm.collector.client.zookeeper.ZookeeperClient ,Zookeeper 客户端。
基于 org.apache.zookeeper.zookeeper 的 3.4.10 版本,封装 SkyWalking 需要的 Zookeeper 操作。预计未来用于collector-cluster-zookeeper-provider 模块。


作者: 摩西摩西OvO    时间: 2018-7-23 13:30

作者: 不二晨    时间: 2018-7-23 13:48
奈斯,优秀
作者: 摩西摩西OvO    时间: 2018-7-26 09:11

作者: 吴琼老师    时间: 2018-7-26 15:33





欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) 黑马程序员IT技术论坛 X3.2