worker_pool v2.0.3

a basic fiber pool implementation for crystal lang

worker_pool

Allocates a minimum number fibers for performing work

  • grows and shrinks the pool as required
  • reduces the overhead of allocating fibers for repetitive, bursty, work
  • handles long running tasks like websockets

Installation

  1. Add the dependency to your shard.yml:

    dependencies:
      worker_pool:
        github: spider-gazelle/worker_pool
    
  2. Run shards install

Usage

require "worker_pool"

pool = WorkerPool.new(100)

100.times do
  pool.perform { my_task }
end

Contributing

  1. Fork it (https://github.com/spider-gazelle/worker_pool/fork)
  2. Create your feature branch (git checkout -b my-new-feature)
  3. Commit your changes (git commit -am 'Add some feature')
  4. Push to the branch (git push origin my-new-feature)
  5. Create a new Pull Request

Contributors

Repository

worker_pool

Owner
Statistic
  • 5
  • 0
  • 0
  • 0
  • 0
  • over 1 year ago
  • May 4, 2023
License

MIT License

Links
Synced at

Tue, 21 Jan 2025 01:23:19 GMT

Languages