Remove redundant goroutine while removing containers (#10449)

don't use goroutine to stop container while removing

Signed-off-by: TP-O <letranphong2k1@gmail.com>
This commit is contained in:
Tran Phong 2023-04-17 21:57:29 +07:00 committed by GitHub
parent af6f0ffb9e
commit 0e7e1b940b
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 15 additions and 13 deletions

View File

@ -237,11 +237,7 @@ func (s *composeService) removeVolume(ctx context.Context, id string, w progress
return err return err
} }
func (s *composeService) stopContainers(ctx context.Context, w progress.Writer, containers []moby.Container, timeout *time.Duration) error { func (s *composeService) stopContainer(ctx context.Context, w progress.Writer, container moby.Container, timeout *time.Duration) error {
eg, ctx := errgroup.WithContext(ctx)
for _, container := range containers {
container := container
eg.Go(func() error {
eventName := getContainerProgressName(container) eventName := getContainerProgressName(container)
w.Event(progress.StoppingEvent(eventName)) w.Event(progress.StoppingEvent(eventName))
timeoutInSecond := utils.DurationSecondToInt(timeout) timeoutInSecond := utils.DurationSecondToInt(timeout)
@ -252,6 +248,14 @@ func (s *composeService) stopContainers(ctx context.Context, w progress.Writer,
} }
w.Event(progress.StoppedEvent(eventName)) w.Event(progress.StoppedEvent(eventName))
return nil return nil
}
func (s *composeService) stopContainers(ctx context.Context, w progress.Writer, containers []moby.Container, timeout *time.Duration) error {
eg, ctx := errgroup.WithContext(ctx)
for _, container := range containers {
container := container
eg.Go(func() error {
return s.stopContainer(ctx, w, container, timeout)
}) })
} }
return eg.Wait() return eg.Wait()
@ -263,10 +267,8 @@ func (s *composeService) removeContainers(ctx context.Context, w progress.Writer
container := container container := container
eg.Go(func() error { eg.Go(func() error {
eventName := getContainerProgressName(container) eventName := getContainerProgressName(container)
w.Event(progress.StoppingEvent(eventName)) err := s.stopContainer(ctx, w, container, timeout)
err := s.stopContainers(ctx, w, []moby.Container{container}, timeout)
if err != nil { if err != nil {
w.Event(progress.ErrorMessageEvent(eventName, "Error while Stopping"))
return err return err
} }
w.Event(progress.RemovingEvent(eventName)) w.Event(progress.RemovingEvent(eventName))