mirror of https://github.com/docker/compose.git
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:
parent
af6f0ffb9e
commit
0e7e1b940b
|
@ -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))
|
||||||
|
|
Loading…
Reference in New Issue