https://github.com/matyama/codecrafters-kafka-rust
Build your own Kafka Codecrafters challenge
https://github.com/matyama/codecrafters-kafka-rust
codecrafters kafka rust
Last synced: about 2 months ago
JSON representation
Build your own Kafka Codecrafters challenge
- Host: GitHub
- URL: https://github.com/matyama/codecrafters-kafka-rust
- Owner: matyama
- Created: 2024-09-19T19:01:23.000Z (almost 2 years ago)
- Default Branch: master
- Last Pushed: 2025-01-18T16:38:23.000Z (over 1 year ago)
- Last Synced: 2025-01-18T17:36:16.368Z (over 1 year ago)
- Topics: codecrafters, kafka, rust
- Language: Rust
- Homepage: https://app.codecrafters.io/courses/kafka/overview
- Size: 227 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
[](https://app.codecrafters.io/users/codecrafters-bot?r=2qF)
This is a starting point for Rust solutions to the
["Build Your Own Kafka" Challenge](https://codecrafters.io/challenges/kafka).
In this challenge, you'll build a toy Kafka clone that's capable of accepting
and responding to APIVersions & Fetch API requests. You'll also learn about
encoding and decoding messages using the Kafka wire protocol. You'll also learn
about handling the network protocol, event loops, TCP sockets and more.
**Note**: If you're viewing this repo on GitHub, head over to
[codecrafters.io](https://codecrafters.io) to try the challenge.
# Passing the first stage
The entry point for your Kafka implementation is in `src/main.rs`. Study and
uncomment the relevant code, and push your changes to pass the first stage:
```sh
git commit -am "pass 1st stage" # any msg
git push origin master
```
That's all!
# Stage 2 & beyond
Note: This section is for stages 2 and beyond.
1. Ensure you have `cargo (1.54)` installed locally
1. Run `./your_program.sh` to run your Kafka broker, which is implemented in
`src/main.rs`. This command compiles your Rust project, so it might be slow
the first time you run it. Subsequent runs will be fast.
1. Commit your changes and run `git push origin master` to submit your solution
to CodeCrafters. Test output will be streamed to your terminal.