unpause.go 1.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849
  1. package daemon // import "github.com/docker/docker/daemon"
  2. import (
  3. "context"
  4. "fmt"
  5. "github.com/containerd/log"
  6. "github.com/docker/docker/api/types/events"
  7. "github.com/docker/docker/container"
  8. )
  9. // ContainerUnpause unpauses a container
  10. func (daemon *Daemon) ContainerUnpause(name string) error {
  11. ctr, err := daemon.GetContainer(name)
  12. if err != nil {
  13. return err
  14. }
  15. return daemon.containerUnpause(ctr)
  16. }
  17. // containerUnpause resumes the container execution after the container is paused.
  18. func (daemon *Daemon) containerUnpause(ctr *container.Container) error {
  19. ctr.Lock()
  20. defer ctr.Unlock()
  21. // We cannot unpause the container which is not paused
  22. if !ctr.Paused {
  23. return fmt.Errorf("Container %s is not paused", ctr.ID)
  24. }
  25. tsk, err := ctr.GetRunningTask()
  26. if err != nil {
  27. return err
  28. }
  29. if err := tsk.Resume(context.Background()); err != nil {
  30. return fmt.Errorf("Cannot unpause container %s: %s", ctr.ID, err)
  31. }
  32. ctr.Paused = false
  33. daemon.setStateCounter(ctr)
  34. daemon.updateHealthMonitor(ctr)
  35. daemon.LogContainerEvent(ctr, events.ActionUnPause)
  36. if err := ctr.CheckpointTo(daemon.containersReplica); err != nil {
  37. log.G(context.TODO()).WithError(err).Warn("could not save container to disk")
  38. }
  39. return nil
  40. }