Skip to content

A toy distributed pubsub written with Go and gRPC. Inspired by Kafka.

License

Notifications You must be signed in to change notification settings

danhhz/gopubsub

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

6 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

gopubsub

A toy distributed pubsub written with Go and gRPC. Inspired by Kafka.

Future Work

  • Tons of cleanup
  • Error checking
  • Close yo files/graceful exits and disconnects
  • Docs
  • Tests
  • Metrics
  • Distributed brokers
  • Partitions
  • Replication
  • Synchronous producers
  • Consumer API
  • Multiple segment files
  • Timeouts
  • Message delivery semantics
  • Availability and durability guarentees
  • Data retention
  • Mmap in the consumer implementation
  • Latency auditing

v0.2

  • Offsets
  • Load previously written data instead of destroying it on startup

v0.1

  • Placeholder binary format
  • Placeholder rpc interface
  • Server binary
  • Publisher test binary
  • Subscriber test "tail -f " binary
  • Works end-to-end (for some definition of works)

About

A toy distributed pubsub written with Go and gRPC. Inspired by Kafka.

Resources

License

Stars

Watchers

Forks

Packages

No packages published