machinery
Machinery is an asynchronous task queue/job queue based on distributed message passing. (by RichardKnop)
NATS
Golang client for NATS, the cloud native messaging system. (by nats-io)
Our great sponsors
machinery | NATS | |
---|---|---|
14 | 11 | |
7,281 | 5,121 | |
- | 1.7% | |
5.3 | 9.1 | |
11 days ago | 1 day ago | |
Go | Go | |
Mozilla Public License 2.0 | Apache License 2.0 |
The number of mentions indicates the total number of mentions that we've tracked plus the number of user suggested alternatives.
Stars - the number of stars that a project has on GitHub. Growth - month over month growth in stars.
Activity is a relative number indicating how actively a project is being developed. Recent commits have higher weight than older ones.
For example, an activity of 9.0 indicates that a project is amongst the top 10% of the most actively developed projects that we are tracking.
Stars - the number of stars that a project has on GitHub. Growth - month over month growth in stars.
Activity is a relative number indicating how actively a project is being developed. Recent commits have higher weight than older ones.
For example, an activity of 9.0 indicates that a project is amongst the top 10% of the most actively developed projects that we are tracking.
machinery
Posts with mentions or reviews of machinery.
We have used some of these posts to build our list of alternatives
and similar projects. The last one was on 2023-02-24.
- Looking for library recommendations: Django -> Golang port
-
Are there any actively maintained or official Golang libraries for managing work queues?
I've had this project starred for a while but haven't used it: https://github.com/RichardKnop/machinery
- Looking for a mature distributed task queuer/scheduler in go
- What would be a good message broker internal to my program?
-
Golang task queue
I had a look at: 1. machinery - https://github.com/RichardKnop/machinery 2. go-celery - https://github.com/gocelery/gocelery 3. asynq - https://github.com/hibiken/asynq 3. taskq - https://github.com/vmihailenco/taskq
-
is there any go library that allows running background tasks after a specified period of time?
you mean a scheduler? try RichardKnop/machinery or hibiken/asynq
-
Using a High-Level RabbitMQ Client in Go
I use this one: https://github.com/RichardKnop/machinery
-
Do you know of a robust library that handles persistent job scheduling and queuing using PostgreSQL
I’ve also used https://github.com/RichardKnop/machinery for for a few projects and it’s solid.
- Distributed asynchronous tasks?
-
Any one knows a job worker project (like Celery) + distributed cron written in Go
Machinery is an asynchronous task queue/job queue based on distributed message passing.
NATS
Posts with mentions or reviews of NATS.
We have used some of these posts to build our list of alternatives
and similar projects. The last one was on 2023-07-21.
- High-Performance server for NATS.io, the cloud and edge native messaging system
- Asyncapi with Go
-
What is the coolest Go open source projects you have seen?
nats: Golang client for NATS, the cloud native messaging system
-
Distributed communication patterns with NATS
Install the nats.go package
- Redis vs. Kafka vs. RabbitMQ
-
Distributed messaging with NATS
Now that our NATS server is running, we'll be using Go and Node.js clients to connect to it for simple demonstration. Not familiar with Go or Node? Don't worry NATS has clients available in over 40 languages!
- How do I build a text editor like notepad using wails
-
Plugins vs Microservices
You can build monolith applications and if they need cross communication, rely on something like Nats: https://github.com/nats-io/nats.go
- Modern Communication: Sockets
-
Subscription management in pub/sub system
You could start by looking/reading how it is implemented in production ala https://github.com/nats-io/nats.go
What are some alternatives?
When comparing machinery and NATS you can also consider the following projects:
Asynq - Simple, reliable, and efficient distributed task queue in Go
nsq - A realtime distributed messaging platform
gocelery - Celery Distributed Task Queue in Go
Centrifugo - Scalable real-time messaging server in a language-agnostic way. Self-hosted alternative to Pubnub, Pusher, Ably. Set up once and forever.
celery - Distributed Task Queue (development branch)
EventBus - [Go] Lightweight eventbus with async compatibility for Go
go-nsq - The official Go package for NSQ
temporal - Temporal service
dbus - Native Go bindings for D-Bus
Confluent Kafka Golang Client - Confluent's Apache Kafka Golang client
emitter - Emits events in Go way, with wildcard, predicates, cancellation possibilities and many other good wins