mirror of
https://github.com/woodpecker-ci/woodpecker.git
synced 2025-01-07 16:15:27 +00:00
e072e4cce7
* refactor: - rename IsAvivable -> IsAvailable - drop depricated Kill - make sure backends implement interface - rename backend struct for ide (better info) * docker backend fix autodetect
42 lines
921 B
Go
42 lines
921 B
Go
package docker
|
|
|
|
// import (
|
|
|
|
// )
|
|
//
|
|
// // Pool manages a pool of Docker clients.
|
|
// type Pool struct {
|
|
// queue chan (backend.Engine)
|
|
// }
|
|
//
|
|
// // NewPool returns a Pool.
|
|
// func NewPool(engines ...backend.Engine) *Pool {
|
|
// return &Pool{
|
|
// queue: make(chan backend.Engine, len(engines)),
|
|
// }
|
|
// }
|
|
//
|
|
// // Reserve requests the next available Docker client in the pool.
|
|
// func (p *Pool) Reserve(c context.Context) backend.Engine {
|
|
// select {
|
|
// case <-c.Done():
|
|
// case docker := <-p.queue:
|
|
// return docker
|
|
// }
|
|
// return nil
|
|
// }
|
|
//
|
|
// // Release releases the Docker client back to the pool.
|
|
// func (p *Pool) Release(docker backend.Engine) {
|
|
// p.queue <- docker
|
|
// }
|
|
|
|
// pool := docker.Pool(
|
|
// docker.FromEnvironmentMust(),
|
|
// docker.FromEnvironmentMust(),
|
|
// docker.FromEnvironmentMust(),
|
|
// docker.FromEnvironmentMust(),
|
|
// )
|
|
//
|
|
// client := pool.Reserve()
|
|
// defer pool.Release(client)
|