worker_pool

a basic fiber pool implementation for crystal lang
2.0.2 released

worker_pool

Allocates a minimum number fibers for performing work

  • grows and shrinks the pool as required
  • reduces the overhead of allocating stacks 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

worker_pool:
  github: spider-gazelle/worker_pool
  version: ~> 2.0.2
License MIT
Crystal none

Authors

Dependencies 0

Development Dependencies 1

  • ameba
    {'github' => 'veelenga/ameba'}

Dependents 0

Last synced .
search fire star recently