• Stars
    star
    7,251
  • Rank 5,342 (Top 0.2 %)
  • Language
    Go
  • License
    MIT License
  • Created about 6 years ago
  • Updated 3 months ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

Building event-driven applications the easy way in Go.

Watermill

CI Status Go Reference Go Report Card codecov

Watermill is a Go library for working efficiently with message streams. It is intended for building event driven applications, enabling event sourcing, RPC over messages, sagas and basically whatever else comes to your mind. You can use conventional pub/sub implementations like Kafka or RabbitMQ, but also HTTP or MySQL binlog if that fits your use case.

Goals

  • Easy to understand.
  • Universal - event-driven architecture, messaging, stream processing, CQRS - use it for whatever you need.
  • Fast (see Benchmarks).
  • Flexible with middlewares, plugins and Pub/Sub configurations.
  • Resilient - using proven technologies and passing stress tests (see Stability).

Getting Started

Pick what you like the best or see in order:

  1. Follow the Getting Started guide.
  2. See examples below.
  3. Read the full documentation: https://watermill.io/

Our online hands-on training

Examples

Background

Building distributed and scalable services is rarely as easy as some may suggest. There is a lot of hidden knowledge that comes with writing such systems. Just like you don't need to know the whole TCP stack to create a HTTP REST server, you shouldn't need to study all of this knowledge to start with building message-driven applications.

Watermill's goal is to make communication with messages as easy to use as HTTP routers. It provides the tools needed to begin working with event-driven architecture and allows you to learn the details on the go.

At the heart of Watermill there is one simple interface:

func(*Message) ([]*Message, error)

Your handler receives a message and decides whether to publish new message(s) or return an error. What happens next is up to the middlewares you've chosen.

You can find more about our motivations in our Introducing Watermill blog post.

Pub/Subs

All publishers and subscribers have to implement an interface:

type Publisher interface {
	Publish(topic string, messages ...*Message) error
	Close() error
}

type Subscriber interface {
	Subscribe(ctx context.Context, topic string) (<-chan *Message, error)
	Close() error
}

Supported Pub/Subs:

All Pub/Subs implementation documentation can be found in the documentation.

Unofficial libraries

Can't find your favorite Pub/Sub or library integration? Check Awesome Watermill.

If you know another library or are an author of one, please add it to the list.

Contributing

Please check our contributing guide.

Stability

Watermill v1.0.0 has been released and is production-ready. The public API is stable and will not change without changing the major version.

To ensure that all Pub/Subs are stable and safe to use in production, we created a set of tests that need to pass for each of the implementations before merging to master. All tests are also executed in stress mode - that means that we are running all the tests 20x in parallel.

All tests are run with the race condition detector enabled (-race flag in tests).

For more information about debugging tests, you should check tests troubleshooting guide.

Benchmarks

Initial tools for benchmarking Pub/Subs can be found in watermill-benchmark.

All benchmarks are being done on a single 16 CPU VM instance, running one binary and dependencies in Docker Compose.

These numbers are meant to serve as a rough estimate of how fast messages can be processed by different Pub/Subs. Keep in mind that the results can be vastly different, depending on the setup and configuration (both much lower and higher).

Here's the short version for message size of 16 bytes.

Pub/Sub Publish (messages / s) Subscribe (messages / s)
GoChannel 331,882 118,943
Redis Streams 61,642 11,213
NATS Jetstream (16 Subscribers) 49,255 33,009
Kafka (one node) 44,090 108,285
SQL (MySQL) 5,599 167
SQL (PostgreSQL, batch size=1) 3,834 455
Google Cloud Pub/Sub 3,689 30,229
AMQP 2,702 13,192

Support

If you didn't find the answer to your question in the documentation, feel free to ask us directly!

Please join us on the #watermill channel on the Three Dots Labs Discord.

Every bit of feedback is very welcome and appreciated. Please submit it using the survey.

Why the name?

It processes streams!

License

MIT License

More Repositories

1

wild-workouts-go-ddd-example

Go DDD example application. Complete project to show how to apply DDD, Clean Architecture, and CQRS by practical refactoring.
Go
5,176
star
2

go-web-app-antipatterns

Short examples of common anti-patterns in Go Web Applications.
Go
338
star
3

monolith-microservice-shop

Source code for https://threedots.tech/post/microservices-or-monolith-its-detail/ article.
Go
247
star
4

event-driven-example

An example Event-Driven application in Go built with Watermill library.
Go
131
star
5

nats-example

An example Go project for running local development environment, with hot code reloading.
Go
100
star
6

watermill-sql

SQL (Postgres/MySQL) Pub/Sub for the Watermill project.
Go
61
star
7

watermill-kafka

Kafka Pub/Sub for the Watermill project.
Go
57
star
8

watermill-amqp

AMQP Pub/Sub for the Watermill project.
Go
54
star
9

watermill-nats

NATS Pub/Sub for the Watermill project.
Go
50
star
10

meteors

An example 2D game made with Go and Ebitengine.
Go
43
star
11

watermill-redisstream

Redis Pub/Sub for the Watermill project.
Go
30
star
12

watermill-http

HTTP Pub/Sub for the Watermill project.
Go
27
star
13

go-event-driven

Materials for https://threedots.tech/event-driven/
Go
26
star
14

esja

Event Sourcing library in Go.
Go
19
star
15

watermill-benchmark

Benchmarking tools for Watermill.
Go
18
star
16

watermill-googlecloud

Google Cloud Pub/Sub Pub/Sub for the Watermill project.
Go
17
star
17

watermill-aws

Amazon SQS/SNS Pub/Sub for the Watermill project.
Go
16
star
18

cli

Go
10
star
19

watermill-jetstream

Go
9
star
20

watermill-io

IO Pub/Sub for the Watermill project.
Go
8
star
21

watermill-bolt

Bolt Pub/Sub for the Watermill project.
Go
6
star
22

pii

Go
5
star
23

github-releases-dashboard

A simple dashboard to keep track of GitHub releases.
Go
1
star
24

wait-for

A simple "wait for port" utility.
Go
1
star
25

watermill-terraform

Terraform definitions for Watermill-related repositories and infrastructure.
HCL
1
star