add timeout when wait to get container pid from conmon
Signed-off-by: Yao Zengzeng <yaozengzeng@zju.edu.cn>
This commit is contained in:
parent
792f585c44
commit
3b7d815af1
1 changed files with 24 additions and 5 deletions
29
oci/oci.go
29
oci/oci.go
|
@ -31,6 +31,8 @@ const (
|
||||||
ContainerStateRunning = "running"
|
ContainerStateRunning = "running"
|
||||||
// ContainerStateStopped represents the stopped state of a container
|
// ContainerStateStopped represents the stopped state of a container
|
||||||
ContainerStateStopped = "stopped"
|
ContainerStateStopped = "stopped"
|
||||||
|
// ContainerCreateTimeout represents the value of container creating timeout
|
||||||
|
ContainerCreateTimeout = 3 * time.Second
|
||||||
)
|
)
|
||||||
|
|
||||||
// New creates a new Runtime with options provided
|
// New creates a new Runtime with options provided
|
||||||
|
@ -154,12 +156,29 @@ func (r *Runtime) CreateContainer(c *Container, cgroupParent string) error {
|
||||||
}
|
}
|
||||||
|
|
||||||
// Wait to get container pid from conmon
|
// Wait to get container pid from conmon
|
||||||
// TODO(mrunalp): Add a timeout here
|
type syncStruct struct {
|
||||||
var si *syncInfo
|
si *syncInfo
|
||||||
if err := json.NewDecoder(parentPipe).Decode(&si); err != nil {
|
err error
|
||||||
return fmt.Errorf("reading pid from init pipe: %v", err)
|
}
|
||||||
|
ch := make(chan syncStruct)
|
||||||
|
go func() {
|
||||||
|
var si *syncInfo
|
||||||
|
if err = json.NewDecoder(parentPipe).Decode(&si); err != nil {
|
||||||
|
ch <- syncStruct{err: err}
|
||||||
|
return
|
||||||
|
}
|
||||||
|
ch <- syncStruct{si: si}
|
||||||
|
}()
|
||||||
|
|
||||||
|
select {
|
||||||
|
case ss := <-ch:
|
||||||
|
if ss.err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
logrus.Infof("Received container pid: %q", ss.si.Pid)
|
||||||
|
case <-time.After(ContainerCreateTimeout):
|
||||||
|
return fmt.Errorf("create container timeout")
|
||||||
}
|
}
|
||||||
logrus.Infof("Received container pid: %v", si.Pid)
|
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue