summaryrefslogtreecommitdiff
path: root/cmd
diff options
context:
space:
mode:
authorWolfy-J <[email protected]>2018-06-06 15:55:28 +0300
committerWolfy-J <[email protected]>2018-06-06 15:55:28 +0300
commite863c6cdcf7c318fb251e096bf92812ed98ea03c (patch)
tree9eb2cd049dfae0482211a6a212d28cc48304f109 /cmd
parent67b88c9914d922314ce7cd8d3624d64812647758 (diff)
better server re-configuration
Diffstat (limited to 'cmd')
-rw-r--r--cmd/_____/server.go64
1 files changed, 64 insertions, 0 deletions
diff --git a/cmd/_____/server.go b/cmd/_____/server.go
new file mode 100644
index 00000000..5542e7c9
--- /dev/null
+++ b/cmd/_____/server.go
@@ -0,0 +1,64 @@
+package roadrunner
+
+import (
+ "os/exec"
+ "sync"
+)
+
+const (
+ // EventNewPool triggered when server creates new pool.
+ EventNewPool = 60
+
+ // EventDestroyPool triggered when server destroys existed pool.
+ EventDestroyPool = 61
+)
+
+// Service manages pool creation and swapping.
+type Server struct {
+ // configures server, pool, cmd creation and factory.
+ scfg *ServerConfig
+
+ // worker command creator
+ cmd func() *exec.Cmd
+
+ // observes pool events (can be attached to multiple pools at the same time)
+ observer func(event int, ctx interface{})
+
+ // creates and connects to workers
+ factory Factory
+
+ // protects pool while the switch
+ mu sync.Mutex
+}
+
+// todo: do assignment
+
+// Reconfigure configures underlying pool and destroys it's previous version if any.
+func (r *Server) Configure(cfg Config) error {
+ r.mu.Lock()
+ previous := r.pool
+ r.mu.Unlock()
+
+ pool, err := NewPool(r.cmd, r.factory, cfg)
+ if err != nil {
+ return err
+ }
+
+ r.throw(EventNewPool, pool)
+
+ r.mu.Lock()
+
+ r.cfg, r.pool = cfg, pool
+ r.pool.Observe(r.poolObserver)
+
+ r.mu.Unlock()
+
+ if previous != nil {
+ go func(p Pool) {
+ r.throw(EventDestroyPool, p)
+ p.Destroy()
+ }(previous)
+ }
+
+ return nil
+}