mirror of
https://github.com/kata-containers/kata-containers.git
synced 2025-10-23 21:28:10 +00:00
shimv2: handle ctx passed by containerd
Sometimes shim process cannot be shutdown because of container list is not empty. This container list is written in shim service, while creating container. We find that if containerd cancel its Create Container Request due to timeout, but runtime didn't handle it properly and continue creating action, then this container cannot be deleted at all. So we should make sure the ctx passed to Create Service rpc call is effective. Fixes #1088 Signed-off-by: Yves Chan <shanks.cyp@gmail.com> Signed-off-by: Chelsea Mafrica <chelsea.e.mafrica@intel.com>
This commit is contained in:
@@ -343,16 +343,27 @@ func (s *service) Create(ctx context.Context, r *taskAPI.CreateTaskRequest) (_ *
|
|||||||
s.mu.Lock()
|
s.mu.Lock()
|
||||||
defer s.mu.Unlock()
|
defer s.mu.Unlock()
|
||||||
|
|
||||||
var c *container
|
type Result struct {
|
||||||
|
container *container
|
||||||
c, err = create(ctx, s, r)
|
err error
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
}
|
||||||
|
ch := make(chan Result, 1)
|
||||||
|
go func() {
|
||||||
|
container, err := create(ctx, s, r)
|
||||||
|
ch <- Result{container, err}
|
||||||
|
}()
|
||||||
|
|
||||||
c.status = task.StatusCreated
|
select {
|
||||||
|
case <-ctx.Done():
|
||||||
|
return nil, errors.Errorf("create container timeout: %v", r.ID)
|
||||||
|
case res := <-ch:
|
||||||
|
if res.err != nil {
|
||||||
|
return nil, res.err
|
||||||
|
}
|
||||||
|
container := res.container
|
||||||
|
container.status = task.StatusCreated
|
||||||
|
|
||||||
s.containers[r.ID] = c
|
s.containers[r.ID] = container
|
||||||
|
|
||||||
s.send(&eventstypes.TaskCreate{
|
s.send(&eventstypes.TaskCreate{
|
||||||
ContainerID: r.ID,
|
ContainerID: r.ID,
|
||||||
@@ -371,6 +382,7 @@ func (s *service) Create(ctx context.Context, r *taskAPI.CreateTaskRequest) (_ *
|
|||||||
return &taskAPI.CreateTaskResponse{
|
return &taskAPI.CreateTaskResponse{
|
||||||
Pid: s.pid,
|
Pid: s.pid,
|
||||||
}, nil
|
}, nil
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Start a process
|
// Start a process
|
||||||
|
Reference in New Issue
Block a user