Merge pull request #130 from tonistiigi/wait-stdio

Wait for stdio to close before exiting
This commit is contained in:
Michael Crosby 2016-03-11 15:03:14 -08:00
commit dfad5da97a
2 changed files with 21 additions and 3 deletions

View file

@ -117,6 +117,7 @@ func main() {
}
// runtime has exited so the shim can also exit
if exitShim {
p.Wait()
return
}
}

View file

@ -9,6 +9,7 @@ import (
"os/exec"
"path/filepath"
"strconv"
"sync"
"syscall"
"github.com/docker/containerd/runtime"
@ -16,6 +17,7 @@ import (
)
type process struct {
sync.WaitGroup
id string
bundle string
stdio *stdio
@ -131,7 +133,12 @@ func (p *process) start() error {
cmd.SysProcAttr = &syscall.SysProcAttr{
Pdeathsig: syscall.SIGKILL,
}
if err := cmd.Run(); err != nil {
if err := cmd.Start(); err != nil {
return err
}
p.stdio.stdout.Close()
p.stdio.stderr.Close()
if err := cmd.Wait(); err != nil {
return err
}
data, err := ioutil.ReadFile("pid")
@ -184,9 +191,11 @@ func (p *process) openIO() error {
if err != nil {
return err
}
p.Add(1)
go func() {
io.Copy(stdout, console)
console.Close()
p.Done()
}()
return nil
}
@ -201,10 +210,18 @@ func (p *process) openIO() error {
go io.Copy(i.Stdin, f)
},
p.state.Stdout: func(f *os.File) {
go io.Copy(f, i.Stdout)
p.Add(1)
go func() {
io.Copy(f, i.Stdout)
p.Done()
}()
},
p.state.Stderr: func(f *os.File) {
go io.Copy(f, i.Stderr)
p.Add(1)
go func() {
io.Copy(f, i.Stderr)
p.Done()
}()
},
} {
f, err := os.OpenFile(name, syscall.O_RDWR, 0)