diff options
author | Valery Piashchynski <[email protected]> | 2021-04-20 12:09:39 +0300 |
---|---|---|
committer | Valery Piashchynski <[email protected]> | 2021-04-20 12:09:39 +0300 |
commit | 2faf7bc2cd883294306466282f313bc5a1dc79ef (patch) | |
tree | a1e94592452e7840a5ce7c615766330e0a23fdb7 /plugins/http/plugin.go | |
parent | a3ced86a77b406bd8d127135636d33e12517d7f8 (diff) |
- Make http.Serve() async
Signed-off-by: Valery Piashchynski <[email protected]>
Diffstat (limited to 'plugins/http/plugin.go')
-rw-r--r-- | plugins/http/plugin.go | 42 |
1 files changed, 30 insertions, 12 deletions
diff --git a/plugins/http/plugin.go b/plugins/http/plugin.go index 8c8a86b4..403f8fd1 100644 --- a/plugins/http/plugin.go +++ b/plugins/http/plugin.go @@ -126,13 +126,21 @@ func (s *Plugin) logCallback(event interface{}) { // Serve serves the svc. func (s *Plugin) Serve() chan error { - s.Lock() - defer s.Unlock() - - const op = errors.Op("http_plugin_serve") errCh := make(chan error, 2) + // run whole process in the goroutine + go func() { + // protect http initialization + s.Lock() + s.serve(errCh) + s.Unlock() + }() + return errCh +} + +func (s *Plugin) serve(errCh chan error) { var err error + const op = errors.Op("http_plugin_serve") s.pool, err = s.server.NewWorkerPool(context.Background(), pool.Config{ Debug: s.cfg.Pool.Debug, NumWorkers: s.cfg.Pool.NumWorkers, @@ -143,7 +151,7 @@ func (s *Plugin) Serve() chan error { }, s.cfg.Env, s.logCallback) if err != nil { errCh <- errors.E(op, err) - return errCh + return } s.handler, err = NewHandler( @@ -154,7 +162,7 @@ func (s *Plugin) Serve() chan error { ) if err != nil { errCh <- errors.E(op, err) - return errCh + return } s.handler.AddListener(s.logCallback) @@ -173,7 +181,7 @@ func (s *Plugin) Serve() chan error { err = s.appendRootCa() if err != nil { errCh <- errors.E(op, err) - return errCh + return } } @@ -181,7 +189,7 @@ func (s *Plugin) Serve() chan error { if s.cfg.HTTP2Config != nil { if err := s.initHTTP2(); err != nil { errCh <- errors.E(op, err) - return errCh + return } } } @@ -202,8 +210,6 @@ func (s *Plugin) Serve() chan error { go func() { s.serveFCGI(errCh) }() - - return errCh } func (s *Plugin) serveHTTP(errCh chan error) { @@ -305,7 +311,10 @@ func (s *Plugin) Stop() error { } } - s.pool.Destroy(context.Background()) + // check for safety + if s.pool != nil { + s.pool.Destroy(context.Background()) + } return err } @@ -335,7 +344,10 @@ func (s *Plugin) ServeHTTP(w http.ResponseWriter, r *http.Request) { // Workers returns slice with the process states for the workers func (s *Plugin) Workers() []process.State { - workers := s.pool.Workers() + s.RLock() + defer s.RUnlock() + + workers := s.workers() ps := make([]process.State, 0, len(workers)) for i := 0; i < len(workers); i++ { @@ -412,6 +424,9 @@ func (s *Plugin) AddMiddleware(name endure.Named, m Middleware) { // Status return status of the particular plugin func (s *Plugin) Status() status.Status { + s.RLock() + defer s.RUnlock() + workers := s.workers() for i := 0; i < len(workers); i++ { if workers[i].State().IsActive() { @@ -428,6 +443,9 @@ func (s *Plugin) Status() status.Status { // Ready return readiness status of the particular plugin func (s *Plugin) Ready() status.Status { + s.RLock() + defer s.RUnlock() + workers := s.workers() for i := 0; i < len(workers); i++ { // If state of the worker is ready (at least 1) |