kafka--kafka的基本概念-topic和partition

一、kafka的基本概念-topic和partition

1、topic (主题 )

topic是逻辑概念

  • 以Topic机制来对消息进行分类的,同一类消息属于同一个Topic,你可以将每个topic看成是一个消息队列。

  • 生产者(producer)将消息发送到相应的Topic,而消费者(consumer)通过从Topic拉取消息来消费

  • kafka中是要求消费者主动拉取消息消费的,它并不会主动推送消息

2、partition(分区)

每个topic可以有多个分区,这是kafka为了提高并发量而设计的一种机制:

一个topic下的多个分区可以并发接收消息,同样的也能供消费者并发拉取消息,即分区之间互不干扰,这样的话,有多少个分区就可以有多大的并发量。

所以,如果要更准确的打比方,一个分区就是一个消息队列,只不过这些消息队列同属于一种消息分类

分区是有序,主题不是有序的

分区的目的 分散磁盘的IO

可以再增加分区

相关推荐
面向Google编程15 小时前
从零学习Kafka:生产者分区机制
大数据·kafka
Jackeyzhe15 小时前
从零学习Kafka:生产者分区机制
kafka
大G的笔记本17 小时前
分布式事务
分布式
weixin_4196583118 小时前
RabbitMQ 的高级特性
java·分布式·rabbitmq
_F_y19 小时前
仿RabbitMQ实现消息队列-服务端核心模块实现(1)
分布式·rabbitmq
.柒宇.20 小时前
RabbitMQ入门教程
分布式·rabbitmq
jiajia_lisa21 小时前
社区诊所便民行,就医通行不添堵
kafka
代码漫谈21 小时前
RabbitMQ 单节点部署指南
分布式·消息队列·rabbitmq
aLTttY1 天前
Spring Boot + Redis 实战分布式锁:从入门到精通
spring boot·redis·分布式
weixin_419658311 天前
RabbitMQ 应用问题
java·分布式·中间件·rabbitmq