agent_pool

Crystal Agent Pool

agent_pool

A shard to handle agent pooling with reusable connections and connection timeouts.

The AgentPool is based on the pool in use by crystal-db.

Installation

  1. Add the dependency to your shard.yml:

    dependencies:
      agent_pool:
        github: aluminumio/agent_pool
    
  2. Run shards install

Usage

require "agent_pool"

pool = AgentPool::AgentPool(Agent).new {|destination| Agent.new(destination) }
agent = pool.checkout("destination")
spawn do
  agent.do_work("abcd")
  pool.release(agent, "destination")
end

TODO: Write usage instructions here

Development

TODO: Handle timeouts raised by agents.

Contributing

  1. Fork it (https://github.com/aluminumio/agent_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

agent_pool

Owner
Statistic
  • 0
  • 1
  • 0
  • 0
  • 1
  • over 2 years ago
  • June 8, 2022
License

MIT License

Links
Synced at

Tue, 21 Jan 2025 08:46:30 GMT

Languages