diff options
-rw-r--r-- | README.md | 2 | ||||
-rw-r--r-- | pool.go | 4 |
2 files changed, 3 insertions, 3 deletions
@@ -17,8 +17,8 @@ Features: - automatic worker replacement and safe destruction - worker lifecycle management (create/allocate/destroy timeouts) - payload context +- control over max jobs per worker - protocol, worker and job level error management -- limit max worker executions - very fast (~250k calls per second on Ryzen 1700X over 16 threads) - works on Windows @@ -95,7 +95,6 @@ func (p *Pool) Exec(rqs *Payload) (rsp *Payload, err error) { return nil, errors.Wrap(err, "unable to allocate worker") } - //todo: timeout rsp, err = w.Exec(rqs) if err != nil { @@ -165,6 +164,8 @@ func (p *Pool) replaceWorker(w *Worker, caused interface{}) { go p.destroyWorker(w) nw, _ := p.createWorker() + + // if unable to create, retry ? or report error p.free <- nw } @@ -207,7 +208,6 @@ func (p *Pool) createWorker() (*Worker, error) { log.Println(err) - //todo: automatic replace } }(w) |