package main import ( "fmt" rt "runtime" "github.com/containers/libpod/cmd/podman/libpodruntime" "github.com/containers/libpod/libpod" "github.com/containers/libpod/pkg/rootless" "github.com/pkg/errors" "github.com/urfave/cli" ) var ( stopFlags = []cli.Flag{ cli.UintFlag{ Name: "timeout, time, t", Usage: "Seconds to wait for stop before killing the container", Value: libpod.CtrRemoveTimeout, }, cli.BoolFlag{ Name: "all, a", Usage: "stop all running containers", }, LatestFlag, } stopDescription = ` podman stop Stops one or more running containers. The container name or ID can be used. A timeout to forcibly stop the container can also be set but defaults to 10 seconds otherwise. ` stopCommand = cli.Command{ Name: "stop", Usage: "Stop one or more containers", Description: stopDescription, Flags: sortFlags(stopFlags), Action: stopCmd, ArgsUsage: "CONTAINER-NAME [CONTAINER-NAME ...]", OnUsageError: usageErrorHandler, } ) func stopCmd(c *cli.Context) error { if err := checkAllAndLatest(c); err != nil { return err } if err := validateFlags(c, stopFlags); err != nil { return err } rootless.SetSkipStorageSetup(true) runtime, err := libpodruntime.GetRuntime(c) if err != nil { return errors.Wrapf(err, "could not get runtime") } defer runtime.Shutdown(false) containers, lastError := getAllOrLatestContainers(c, runtime, libpod.ContainerStateRunning, "running") var stopFuncs []workerInput for _, ctr := range containers { con := ctr var stopTimeout uint if c.IsSet("timeout") { stopTimeout = c.Uint("timeout") } else { stopTimeout = ctr.StopTimeout() } f := func() error { return con.StopWithTimeout(stopTimeout) } stopFuncs = append(stopFuncs, workerInput{ containerID: con.ID(), parallelFunc: f, }) } stopErrors := parallelExecuteWorkerPool(rt.NumCPU()*3, stopFuncs) for cid, result := range stopErrors { if result != nil && result != libpod.ErrCtrStopped { fmt.Println(result.Error()) lastError = result continue } fmt.Println(cid) } return lastError }