Watermill by ThreeDotsLabs

Building event-driven applications the easy way in Go.

watermillevent-drivenevent-sourcingsagaseventsstream-processingreactivegogolangrabbitmqkafkacqrs
Verdict 65/100 health $4.13/mo cheapest, hetzner 2/5 setup difficulty Last release 8 months ago

Self-host Watermill on hetzner CAX11 for $4.13/mo.

Health score
65 /100
6-dim composite
Self-hosts from
$4.13 /mo
hetzner · CAX11
Difficulty
2 /5
Docker + read README
GitHub stars
9.7k
496 forks

About Watermill

From the project's README at github.com/ThreeDotsLabs/watermill. Lightly cleaned for readability; for the full source see the upstream repo.

[](https://github.com/ThreeDotsLabs/watermill/actions/workflows/master.yml) [](https://pkg.go.dev/github.com/ThreeDotsLabs/watermill) [](https://goreportcard.com/report/github.com/ThreeDotsLabs/watermill) [](https://codecov.io/gh/ThreeDotsLabs/watermill)

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 PostgreSQL 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

Health score breakdown

6-dimension composite. See methodology for formula and weights.

activity
55
maturity
100
community
81
security
70
sustainability
53
adoption
35

Adoption signals

Real-world usage data, pulled from each registry. The bigger the numbers, the more battle-tested the project.

SignalValueSource
GitHub stars 9.7k github.com/ThreeDotsLabs/watermill
GitHub forks 496 github.com/ThreeDotsLabs/watermill

Release & maintenance

Is this project actively maintained, or about to die? Check the recency of last commit and last release.

Project age7.5 yearssince Nov 2018
Last commit17 days agoApr 20, 2026
Releases shipped53last: 8 months ago

Self-hosting cost across providers

Detected requirements: 4GB RAM, 40GB disk minimum. Cheapest plan per provider that meets the requirement.

ProviderPlanSpecsMonthly
hetzner CAX11 2c · 4GB · 40GB $4.13 USD Deploy →
vultr VC2 1c · 1GB · 25GB $5 USD Deploy →
linode Nanode 1GB 1c · 1GB · 25GB $5.12 USD Deploy →
digitalocean Basic Regular 1GB 1c · 1GB · 25GB $6 USD Deploy →

What people say on Hacker News

Ready to self-host Watermill?

Spin up a hetzner CAX11 (4GB RAM, 40GB disk) for $4.13/mo and follow the project's official install docs.

Data last refreshed May 7, 2026.

Similar open-source projects

Projects in our directory that replace the same SaaS or share topics with Watermill.

Frequently asked questions

Last verified . Data refreshes every 30 minutes.