Kakfa 依赖文件系统来存储和缓存消息。对于硬盘的传统观念是硬盘老是很慢,基于文件系统的架构可否提供优异的性能?实际上硬盘的快慢彻底取决于使用方式。同时 Kafka 基于 JVM 内存有如下缺点:缓存
实际上磁盘线性写入的性能远远大于任意位置写的性能,线性读写由操做系统进行了大量优化(read-ahead、write-behind 等技术),甚至比随机的内存读写更快。因此与常见的数据缓存在内存中而后刷到硬盘的设计不一样,Kafka 直接将数据写到了文件系统的日志中:架构
这样实现的好处:app
一个 Topic 被分红多 Partition,每一个 Partition 在存储层面是一个 append-only 日志文件,属于一个 Partition 的消息都会被直接追加到日志文件的尾部,每条消息在文件中的位置称为 offset(偏移量)。ide
以下图所示,咱们以前建立了mytopic1,具备三个分区。咱们能够到对应的日志目录下进行查看。工具
Kafka日志分为index与log(如上图所示),两个成对出现:index文件存储元数据,log存储消息。索引文件元数据指向对应log文件中message的迁移地址;例如2,128指log文件的第2条数据,偏移地址为128;而物理地址(在index文件中指定)+ 偏移地址能够定位到消息。
咱们可使用Kafka自带的工具来查看log日志文件中的数据信息:性能