43 lines
		
	
	
		
			946 B
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			43 lines
		
	
	
		
			946 B
		
	
	
	
		
			Go
		
	
	
	
	
	
| package supervisor
 | |
| 
 | |
| import (
 | |
| 	"time"
 | |
| 
 | |
| 	"github.com/Sirupsen/logrus"
 | |
| )
 | |
| 
 | |
| type AddProcessEvent struct {
 | |
| 	s *Supervisor
 | |
| }
 | |
| 
 | |
| // TODO: add this to worker for concurrent starts???  maybe not because of races where the container
 | |
| // could be stopped and removed...
 | |
| func (h *AddProcessEvent) Handle(e *Event) error {
 | |
| 	start := time.Now()
 | |
| 	ci, ok := h.s.containers[e.ID]
 | |
| 	if !ok {
 | |
| 		return ErrContainerNotFound
 | |
| 	}
 | |
| 	p, io, err := h.s.runtime.StartProcess(ci.container, *e.Process, e.Console)
 | |
| 	if err != nil {
 | |
| 		return err
 | |
| 	}
 | |
| 	if e.Pid, err = p.Pid(); err != nil {
 | |
| 		return err
 | |
| 	}
 | |
| 	h.s.processes[e.Pid] = &containerInfo{
 | |
| 		container: ci.container,
 | |
| 	}
 | |
| 	l, err := h.s.copyIO(e.Stdin, e.Stdout, e.Stderr, io)
 | |
| 	if err != nil {
 | |
| 		// log the error but continue with the other commands
 | |
| 		logrus.WithFields(logrus.Fields{
 | |
| 			"error": err,
 | |
| 			"id":    e.ID,
 | |
| 		}).Error("log stdio")
 | |
| 	}
 | |
| 	h.s.processes[e.Pid].copier = l
 | |
| 	ExecProcessTimer.UpdateSince(start)
 | |
| 	return nil
 | |
| }
 | 
