Kafka源码依赖于Scala环境,首先需要安装scala,这块请自行百度进行安装。
当然,我们要分析源码,需要下载源码,请自行从github上面下载。
说明:本文使用的kafka版本为0.10.0.1,这是目前公司使用的版本。
下面说明下kafka源码的工程结构:
下面主要对core目录模块进行说明,这块是kafka的核心。
- admin:管理员模块,操作和管理topic,paritions相关,包含create,delete topic,扩展patitions
- api:这块主要负责数据的组装,客户端和服务端数据交互的组装
- client:这个模块比较简单,只有一个类,主要是获取一些元数据,包括topic、broker等
- cluster:该模块定义了几个在kafka中比较重要的类:Broker,BrokerEndPoint,Cluster,EndPoint,Partition,Replica等,后续我们会对他们之间的关系进行分析
- common:通用类,定义了一些异常类等等
- consumer:comsu