Amazon Kinesis vs. Apache Kafka

Overview
ProductRatingMost Used ByProduct SummaryStarting Price
Amazon Kinesis
Score 8.0 out of 10
N/A
Amazon Kinesis is a streaming analytics suite for data intake from video or other disparate sources and applying analytics for machine learning (ML) and business intelligence.
$0.01
per GB data ingested / consumed
Apache Kafka
Score 8.4 out of 10
N/A
Apache Kafka is an open-source stream processing platform developed by the Apache Software Foundation written in Scala and Java. The Kafka event streaming platform is used by thousands of companies for high-performance data pipelines, streaming analytics, data integration, and mission-critical applications.N/A
Pricing
Amazon KinesisApache Kafka
Editions & Modules
Amazon Kinesis Video Streams
$0.00850
per GB data ingested / consumed
Amazon Kinesis Data Streams
$0.04
per hour per stream
Amazon Kinesis Data Analytics
$0.11
per hour
Amazon Kinesis Data Firehose
tiered pricing starting at $0.029
per month first 500 TB ingested
No answers on this topic
Offerings
Pricing Offerings
Amazon KinesisApache Kafka
Free Trial
NoNo
Free/Freemium Version
NoNo
Premium Consulting/Integration Services
NoNo
Entry-level Setup FeeNo setup feeNo setup fee
Additional Details
More Pricing Information
Community Pulse
Amazon KinesisApache Kafka
Considered Both Products
Amazon Kinesis
Chose Amazon Kinesis
The main benefit was around set up - incredibly easy to just start using Kinesis. Kinesis is a real-time data processing platform, while Kafka is more of a message queue system. If you only need a message queue from a limited source, Kafka may do the job. More complex use …
Apache Kafka
Chose Apache Kafka
Confluent Cloud is still based on Apache Kafka but it has a subscription fee so, from a long term perspective, it is wiser to deploy your own Kafka instance that spans public and private cloud. Amazon Kinesis, Google Cloud Pub/Sub do not do well for a very number of messages …
Chose Apache Kafka
Apache Kafka is open-sourced, scales great has cloud agnostics and performs better than Amazon Kinesis [in my view]. Amazon Kinesis has some limitations and vendor lockin is not something I [like]. With Confluent operators you can easily install it on a kubernetes cluster.
Chose Apache Kafka
- The biggest advantage of using Apache Kafka is that it is cloud agnostic - It handles super high volume, is fault tolerance, high performance
Chose Apache Kafka
Kafka is simple and lower in price.
Top Pros
Top Cons
TrustRadius Insights
Amazon KinesisApache Kafka
Highlights

TrustRadius
Research Team Insight
Published

Apache Kafka and Amazon Kinesis are both streaming analytics software solutions that perform real-time reporting and create visualizations on streaming data collected from multiple sources. Businesses of all sizes use both software options, but larger organizations are more likely to use Apache Kafka, while Amazon Kinesis users are evenly spread across businesses of all sizes.

Features

Apache Kafka and Amazon Kinesis both offer essential streaming analytics features, including reporting and visualization creation, but they also have a few features that set them apart from each other.

Apache Kafka is an open-source technology. Being open-source means that Apache Kafka’s code is available for free, and an active community of developers is continuously contributing to it, resulting in quick bug fixes and feature updates. Apache Kafka can be deployed on-premises, on the cloud, or with a hybrid approach. In addition to flexible deployments, Apache Kafka is also very scalable and allows for the analysis of huge amounts of data.

Amazon Kinesis is built to run on AWS and integrate with other AWS technologies, making it a great choice for organizations that need to analyze data from AWS software. Additionally, Amazon Kinesis requires minimal configuration for features like data replication. The usability of Amazon Kinesis can make it more usable for an organization with few technical staff members. Amazon Kinesis also provides high performance and reporting speed.

Limitations

Apache Kafka and Amazon Kinesis both provide robust features, but they also have a few limitations.

Apache Kafka offers greater flexibility in deployment and scale, but it doesn’t integrate as well with AWS technologies compared to Amazon Kinesis. Additionally, Apache Kafka requires technical users or vendor support for configuration and implementation. Lastly, Apache Kafka performs slightly slower than Amazon Kinesis.

Amazon Kinesis offers usability and performance but lacks flexibility. Organizations must use a cloud deployment for Amazon Kinesis, as opposed to Apache Kafka’s multiple deployment options. Additionally, Amazon Kinesis isn’t open-source, which limits how low costs can be compared to DIY Apache Kafka implementations. Lastly, Amazon Kinesis is not as scalable as Apache Kafka due to a limited amount of shards, which hold data to be analyzed.

Pricing

Apache Kafka is an open-source technology, but if a company decides to go with a vendor, pricing can vary depending on the vendor chosen, level of support, and type of deployment. Though pricing can vary a lot, it can start as low as $40.00 per month.

Amazon Kinesis pricing depends on region, the number of shards, and optional features such as enhanced data retention. Though pricing can vary greatly, organizations can expect the essential features to start around $50.00 per month.

Features
Amazon KinesisApache Kafka
Streaming Analytics
Comparison of Streaming Analytics features of Product A and Product B
Amazon Kinesis
8.3
2 Ratings
3% above category average
Apache Kafka
-
Ratings
Real-Time Data Analysis10.01 Ratings00 Ratings
Data Ingestion from Multiple Data Sources9.02 Ratings00 Ratings
Low Latency9.02 Ratings00 Ratings
Integrated Development Tools9.02 Ratings00 Ratings
Data wrangling and preparation10.01 Ratings00 Ratings
Linear Scale-Out6.12 Ratings00 Ratings
Data Enrichment5.01 Ratings00 Ratings
Best Alternatives
Amazon KinesisApache Kafka
Small Businesses
IBM Streams
IBM Streams
Score 9.0 out of 10

No answers on this topic

Medium-sized Companies
Confluent
Confluent
Score 7.4 out of 10
IBM MQ
IBM MQ
Score 9.0 out of 10
Enterprises
Spotfire Streaming
Spotfire Streaming
Score 8.1 out of 10
IBM MQ
IBM MQ
Score 9.0 out of 10
All AlternativesView all alternativesView all alternatives
User Ratings
Amazon KinesisApache Kafka
Likelihood to Recommend
9.0
(3 ratings)
8.3
(18 ratings)
Likelihood to Renew
-
(0 ratings)
9.0
(2 ratings)
Usability
-
(0 ratings)
10.0
(1 ratings)
Support Rating
7.1
(2 ratings)
8.4
(4 ratings)
User Testimonials
Amazon KinesisApache Kafka
Likelihood to Recommend
Amazon AWS
Amazon Kinesis is a great replacement for Kafka and it works better whenever the components of the solution are AWS based. Best if extended fan-out is not required, but still price-performance ratio is very good for simplifying maintenance.
I would go with a different option if the systems to be connected are legacy, for instance in the case of traditional messaging clients.
Read full review
Apache
Apache Kafka is well-suited for most data-streaming use cases. Amazon Kinesis and Azure EventHubs, unless you have a specific use case where using those cloud PaAS for your data lakes, once set up well, Apache Kafka will take care of everything else in the background. Azure EventHubs, is good for cross-cloud use cases, and Amazon Kinesis - I have no real-world experience. But I believe it is the same.
Read full review
Pros
Amazon AWS
  • Processing huge loads of data
  • Integrating well with IoT Platform on Amazon
  • Integration with overall AWS Ecosystem
  • Scalability
Read full review
Apache
  • Really easy to configure. I've used other message brokers such as RabbitMQ and compared to them, Kafka's configurations are very easy to understand and tweak.
  • Very scalable: easily configured to run on multiple nodes allowing for ease of parallelism (assuming your queues/topics don't have to be consumed in the exact same order the messages were delivered)
  • Not exactly a feature, but I trust Kafka will be around for at least another decade because active development has continued to be strong and there's a lot of financial backing from Confluent and LinkedIn, and probably many other companies who are using it (which, anecdotally, is many).
Read full review
Cons
Amazon AWS
  • Not a queue system, so little visibility into "backlog" if there is any
  • Confusing terminology to make sure events aren't missed
  • Sometimes didn't seem to trigger Lambda functions, or dropped events when a lot came in
Read full review
Apache
  • Sometimes it becomes difficult to monitor our Kafka deployments. We've been able to overcome it largely using AWS MSK, a managed service for Apache Kafka, but a separate monitoring dashboard would have been great.
  • Simplify the process for local deployment of Kafka and provide a user interface to get visibility into the different topics and the messages being processed.
  • Learning curve around creation of broker and topics could be simplified
Read full review
Likelihood to Renew
Amazon AWS
No answers on this topic
Apache
Kafka is quickly becoming core product of the organization, indeed it is replacing older messaging systems. No better alternatives found yet
Read full review
Usability
Amazon AWS
No answers on this topic
Apache
Apache Kafka is highly recommended to develop loosely coupled, real-time processing applications. Also, Apache Kafka provides property based configuration. Producer, Consumer and broker contain their own separate property file
Read full review
Support Rating
Amazon AWS
The documentation was confusing and lacked examples. The streams suddenly stopped working with no explanation and there was no information in the logs. All these were more difficult when dealing with enhanced fan-out. In fact, we were about to abort the usage of Kinesis due to a misunderstanding with enhanced fan-out.
Read full review
Apache
Support for Apache Kafka (if willing to pay) is available from Confluent that includes the same time that created Kafka at Linkedin so they know this software in and out. Moreover, Apache Kafka is well known and best practices documents and deployment scenarios are easily available for download. For example, from eBay, Linkedin, Uber, and NYTimes.
Read full review
Alternatives Considered
Amazon AWS
The main benefit was around set up - incredibly easy to just start using Kinesis. Kinesis is a real-time data processing platform, while Kafka is more of a message queue system. If you only need a message queue from a limited source, Kafka may do the job. More complex use cases, with low latency, higher volume of data, real time decisions and integration with multiple sources and destination at a decent price, Kinesis is better.
Read full review
Apache
I used other messaging/queue solutions that are a lot more basic than Confluent Kafka, as well as another solution that is no longer in the market called Xively, which was bought and "buried" by Google. In comparison, these solutions offer way fewer functionalities and respond to other needs.
Read full review
Return on Investment
Amazon AWS
  • Caused us to need to re-engineer some basic re-try logic
  • Caused us to drop some content without knowing it
  • Made monitoring much more difficult
  • We eventually switched back to SQS because Kinesis is not the same as a Queue system
Read full review
Apache
  • Positive: Get a quick and reliable pub/sub model implemented - data across components flows easily.
  • Positive: it's scalable so we can develop small and scale for real-world scenarios
  • Negative: it's easy to get into a confusing situation if you are not experienced yet or something strange has happened (rare, but it does). Troubleshooting such situations can take time and effort.
Read full review
ScreenShots