ZenQ
ants
Our great sponsors
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.
ZenQ
-
HaxMap v0.2.0 released, huge performance improvements and added support for 32-bit systems
Use of golang runtime internals like itogami and ZenQ to squeeze out a little extra performance
- ZenQ vs Channels benchmarks for low-end raspberry pi
-
GoQueue, A Flexible Queue System for Go
regarding thread safety you can make the queue lock free, see this https://github.com/alphadose/ZenQ
- ZenQ version 2.6.1 released, with new features, performance improvements and added support for more CPU architectures
-
Itogami, the best golang thread-pool till date
I have also made a similar project https://github.com/alphadose/ZenQ
- ZenQ now has select{} capability
-
ZenQ now finally a better alternative to native channels with v1.2.0
Hello fellow gophers, A few days ago I published ZenQ, which is a fast thread-safe queue
- A thread-safe queue faster than native Golang channels
-
A thread-safe queue faster than native golang channels
Code for the above benchmark https://github.com/alphadose/ZenQ/blob/main/benchmarks/main_test.go
ants
-
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?
goqueue - Flexible Queue System for Go
tunny - A goroutine pool for Go
haxmap - Fastest and most memory efficient golang concurrent hashmap
goworker - goworker is a Go-based background worker that runs 10 to 100,000* times faster than Ruby-based workers.
parallel - xargs for concurrent, distributed execution of shell commands
workerpool - Go simple async worker pool
itogami - Fastest and most efficient goroutine pool (experimental)
pond - 🔘 Minimalistic and High-performance goroutine worker pool written in Go
Disruptor - High Performance Inter-Thread Messaging Library
threadpool - Golang simple thread pool implementation
workerpool - Concurrency limiting goroutine pool
go-waitgroup - A sync.WaitGroup with error handling and concurrency control