pond
🔘 Minimalistic and High-performance goroutine worker pool written in Go (by alitto)
ants
🐜🐜🐜 ants is the most powerful and reliable pooling solution for Go. (by panjf2000)
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.
pond
Posts with mentions or reviews of pond.
We have used some of these posts to build our list of alternatives
and similar projects. The last one was on 2023-02-24.
-
Help! channel vs workerpool
https://github.com/alitto/pond i use this one :3
-
tasq - my first published open-source Go module
(In this case, originally the example had a workerpool package alitto/pond imported until I removed in favor of something simpler, but if I left it and didn't use and underscore then the alitto/pond library would have been a dependency of tasq too)
ants
Posts with mentions or reviews of ants.
We have used some of these posts to build our list of alternatives
and similar projects. The last one was on 2023-04-04.
-
Rust vs Go Issue
I remember doing something similar to OP recently. Goroutines also incur a bit of overhead (have to be GC'd and so on), and the same worker pool technique can be applied to them in much the same way, as seen in popular libraries like https://github.com/panjf2000/ants
-
Beginner ~ Intermediate Go programmer, how can I get better in go and get out of the "beginner" phase?
The best example I can give you is https://github.com/nutsdb/nutsdb it’s great project that got me started, one thing one should know is Go is different “yep” so there’re some coding habits that may bite you in Go and the Go compiler won’t correct you, you wanna learn about optimizations, unsafe usage check out https://github.com/valyala/fasthttp (note this is deep the rabbit hole), wanna learn concurrency check out ants https://github.com/panjf2000/ants with a little aid from “Go by example” you’re good to go
-
Conc: Better Structured Concurrency for Go
conc seem similar to ant lib (https://github.com/panjf2000/ants). Is there any considerable difference between them?
-
[Side Project] Post automated Youtube videos from Reddit
But still, that looked hard to maintain, and I asked myself there has to be a better way to do this, just out of curiosity i googled and came across ants which seemed exactly right for this kind of functionality I wanted, so I converted the same function to use ants, and it became this:
-
Dynamic number of Goroutines based on load?
You can try use this one https://github.com/panjf2000/ants We are using that as well for that purpose
-
Itogami, the best golang thread-pool till date
Benchmarking was performed against existing golang threadpool implementations Ants and Gamma-Zero-Worker-Pool and unlimited goroutines
-
Hello! Please explain what a pool?
The readme of the project explains it very well: https://github.com/panjf2000/ants
-
Parapipe - FIFO paralleling pipeline with concurrent job processing
Looks interesting, but what new concepts/features does it bring to the table compared to the already battletested ants library? Link: https://github.com/panjf2000/ants
What are some alternatives?
When comparing pond and ants you can also consider the following projects:
workerpool - Go simple async worker pool
conc - Better structured concurrency for go
pool - :speedboat: a limited consumer goroutine or unlimited goroutine pool for easier goroutine handling and cancellation
tunny - A goroutine pool for Go
gollback - Go asynchronous simple function utilities, for managing execution of closures and callbacks
semaphore go - Fast resizable golang semaphore primitive
goworker - goworker is a Go-based background worker that runs 10 to 100,000* times faster than Ruby-based workers.
gohive - 🐝 A Highly Performant and easy to use goroutine pool for Go
threadpool - Golang simple thread pool implementation
nursery - Structured Concurrency in Go
neilotoole/errgroup - errgroup with goroutine worker limits