Skip to content

Difference with Apache Kafka

lyx edited this page Jan 17, 2025 · 1 revision

AutoMQ is a next-generation Apache Kafka® distribution redesigned with cloud-native principles. It offers up to 10 times the cost and elasticity advantages while maintaining 100% compatibility with the Apache Kafka® protocol. This article primarily introduces the main differences and connections between AutoMQ and Apache Kafka®.

Differences from Apache Kafka®

Architecture: Shared Nothing Vs Shared Storage

Apache Kafka® uses local disk storage and constructs a highly reliable storage system through software-level high availability replica replication logic (ISR mechanism). This provides a "limitless" stream storage abstraction to the business logic side. All Kafka® data is stored on local disk media according to specific logic, a method generally referred to as a Shared Nothing architecture.

AutoMQ differs from Apache Kafka® by adopting a compute-storage separation approach. Instead of using local disks, it uses shared object storage services to store data. AutoMQ abstracts an S3Stream storage repository (software library) to replace Apache Kafka®'s local log storage. This transparent use of object storage to store Kafka® data while ensuring the upper layer Apache Kafka® functionalities and semantics remain unchanged is known as a Shared Storage architecture.

A comparison of the two different architectures of Apache Kafka® and AutoMQ is as follows:

Apache Kafka
Utilizes Shared Nothing architecture
AutoMQ
Utilizes Shared Storage architecture
Data is stored on local disks, requiring cross-node multiple replica replication
Data is stored in S3 shared storage (high reliability with three replicas), eliminating the need for multiple replica replication
Data is isolated across nodes, and data access is bound to specific nodes.
Data is shared across nodes, allowing cross-node access.
When adding nodes for horizontal scaling or replacing faulty nodes, shard data must be reassigned.
When adding nodes or replacing faulty nodes, data reassignment is not needed for quick switching.

Note:

Apache Kafka has planned for tiered storage capabilities starting from version 3.6 (not yet production-ready), which supports offloading historical data to object storage services. This architecture has similarities and differences with AutoMQ's approach, which relies entirely on object storage for the storage layer. For a detailed comparison, refer to Difference with Tiered Storage▸.

Flexibility: Second-level Partition Reassignment vs. Hour-level Partition Reassignment

Partition reassignment is a frequent and unavoidable issue in Apache Kafka production environments, required in scenarios like partial node failures, cluster scaling, and partial hotspot handling.

Apache Kafka uses a Shared Nothing architecture, where each partition's data is stored entirely on specific storage nodes. When partition reassignment is involved, the full data of the partition must be transferred to the new target node before service can be provided. This process can be time-consuming and unpredictable.

Example:

For a Kafka partition with a write throughput of 100MiB/s, the data generated in one day is approximately 8.2TiB. If this partition needs to be reassigned, all the data must be moved to another node. Even with a network bandwidth of 1Gbps, it would take hours to complete the reassignment.

AutoMQ adopts a storage-compute separation architecture, where the entire data of each partition is stored in S3 object storage. During partition reassignment, only a small amount of metadata needs to be synchronized to complete the switch. AutoMQ can ensure the switch is completed in seconds for partitions with any write throughput scale.

AutoMQ supports second-level partition reassignment, providing AutoMQ with faster and more predictable flexibility advantages over Apache Kafka in scenarios such as cluster scaling and fault recovery.

Cost: 10x Cost Difference

Referencing the above architectural differences, AutoMQ and Apache Kafka also have significant cost structure differences in terms of computing and storage. AutoMQ does not require cross-node multiple replica replication when writing messages, saving most of the cross-node replication traffic and pressure. Additionally, AutoMQ uses S3 object storage as the storage medium, which is far less costly than mounting EBS block storage to each node in typical Public Cloud environments.

The specific comparison items are as follows:

Cost Comparison
Apache Kafka
AutoMQ
Storage Unit Price
  • Scenario: 1GB data requires 3GB EBS (three replicas)
  • Cost: 0.288 USD/month
  • Scenario: 1GB business data requires 1GB S3
  • Cost: 0.023 USD/month
Cross-Node Replication Traffic
  • Scenario: Writing 1GB of data requires cross-node replication of 2GB traffic (three replicas)
  • Cost: 0.04 USD
  • Scenario: Writing 1GB of data, directly uploading to S3, no cross-node traffic needed (three replicas)
  • Cost: 0 USD

Notes:

The storage unit prices above are based on a comparison between AWS S3 US East EBS GP3 instances and S3 Standard storage. For detailed information, refer to AWS S3 Pricing.

The cross-node replication traffic costs above are based on the cost of data transfer between AWS AZs.

For a detailed cost comparison between AutoMQ and Apache Kafka, refer to Cost-Effective: AutoMQ vs. Apache Kafka▸.

Capacity: Reserved Vs Pay-as-you-go

Capacity planning is another challenge when Kafka is applied on a large scale in production environments. Due to the architectural differences and storage media differences between AutoMQ and Apache Kafka, there are differences in capacity planning:

Apache Kafka
Uses local disks, integrated storage and compute
AutoMQ
Uses S3 object storage, separated storage and compute
Disk space must be reserved in advance
Storage space is on-demand, pay-as-you-go
Limited storage on a single node, poor storage scalability
S3 object storage space is nearly unlimited, with good storage scalability

100% Compatible with Apache Kafka®

As a redesigned, next-generation Kafka release, AutoMQ provides a cost-effective and elastic alternative while ensuring 100% compatibility with Apache Kafka®. Applications based on Apache Kafka can seamlessly migrate to AutoMQ without any modifications or adaptations.

Referencing the architectural comparison above, AutoMQ abstracts the S3Stream storage repository to replace Apache Kafka's local log storage at the storage layer. The storage layer exposes the same Partition abstraction to the upper layers, allowing modules such as KRaft metadata management, Coordinator, ReplicaManager, and KafkaApis to reuse the original code logic. The storage layer reuses Apache Kafka's logic. AutoMQ supports 100% compatibility with Apache Kafka protocols and semantics and can continuously follow the latest features and bug fixes of Apache Kafka.

For more details on the compatibility between AutoMQ and Apache Kafka, refer to Compatibility with Apache Kafka▸.

AutoMQ Wiki Key Pages

What is automq

Getting started

Architecture

Deployment

Migration

Observability

Integrations

Releases

Benchmarks

Reference

Articles

Clone this wiki locally