Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/progrium/hostpool
A worker pool manager for DigitalOcean hosts.
https://github.com/progrium/hostpool
Last synced: 2 months ago
JSON representation
A worker pool manager for DigitalOcean hosts.
- Host: GitHub
- URL: https://github.com/progrium/hostpool
- Owner: progrium
- Created: 2013-11-08T03:44:34.000Z (about 11 years ago)
- Default Branch: master
- Last Pushed: 2013-11-08T09:03:42.000Z (about 11 years ago)
- Last Synced: 2024-11-10T00:33:12.632Z (2 months ago)
- Language: Go
- Homepage:
- Size: 74.2 KB
- Stars: 22
- Watchers: 3
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
- awesome-digitalocean - hostpool - Worker pool manager for DigitalOcean hosts. (Community OSS projects)
README
# hostpool
A "thread pool" manager of DigitalOcean hosts. It can be used for on-demand CI workers, and runs on Heroku.
There is an HTTP endpoint to GET a host, in which depending on pool size (concurrency) you may wait in line, but eventually wait while a host is provisioned. While you wait, the connection remains open. Once provisioned, the IP of the host is returned and the connection is closed. The provisioned host will automatically be destroyed after a timeout. Hostpool ensures only a certain number of hosts are active at any time.
Configuration is done via environment variables:
* `CLIENT_ID`: DigitalOcean client ID
* `API_KEY`: DigitalOcean API key
* `PORT`: Port to bind on
* `NAME`: Name used to prefix Droplets owned by hostpool
* `CONCURRENCY`: Number of concurrent active hosts allowed (pool size)
* `TIMEOUT`: Minutes before a host is automatically destroyed
* `IMAGE`: ID of your DigitalOcean image to use for the hosts
* `KEY`: ID of a DigitalOcean SSH key to use with the hostsAll configuration is required except for `KEY`.
## License
MIT