Skip to content

jmptrader/go-cloud-stream

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

26 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

go-cloud-stream

Build Status Coverage Status

The idea behind this work is to provide a simple way to build highly scalable messaging microservices. These message microservices use different transports such as Kafka or Redis for communication. The ideas is to deploy those microservices on Docker, Kubernetes or any other container system.

This work was inspired by the awesome Spring Cloud Stream project. However, streaming modules written in Java are pretty heavyweight, therefore we chose to implement the base framework in Go because it is lightweight and blazingly fast.

Our key design goals are to be minimalist and lightweight but still compatible with the Spring Cloud Steam Modules in terms of the most important command line arguments so they can be used interchangeably. This does not mean that go-cloud-stream supports all the options that Spring Cloud Stream supports. However, the key aspects of a modules are supported (e.g., queue and topic bindings, Redis and Kafka as transports, ...)

Combined with Spring Cloud Dataflow or your own "composition" and deployment framework, this work can easily be used to build highly scalable messaging microservices.

Build

$ redis-server
$ go test *.go

Build a go-cloud-stream module

TBD

About

Messaging microservices in Go

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Go 100.0%