diff options
author | baude <bbaude@redhat.com> | 2018-10-29 13:53:39 -0500 |
---|---|---|
committer | baude <bbaude@redhat.com> | 2018-11-01 14:23:55 -0500 |
commit | b559c19c2fa739cf1c8ede50eab8f5acf74f6bf3 (patch) | |
tree | b4d63dfa9418edf29dbbac4b00ae397e93632299 /cmd/podman/shared | |
parent | 732a4c814e575ead4b39f00097f22b2f3b64bfc0 (diff) | |
download | podman-b559c19c2fa739cf1c8ede50eab8f5acf74f6bf3.tar.gz podman-b559c19c2fa739cf1c8ede50eab8f5acf74f6bf3.tar.bz2 podman-b559c19c2fa739cf1c8ede50eab8f5acf74f6bf3.zip |
Make kill, pause, and unpause parallel.
Operations like kill, pause, and unpause -- which can operation on one or
more containers -- can greatly benefit from parallizing its main job (eq kill).
In the case of pauseand unpause, an --all option as was added. pause --all will
pause all **running** containers. And unpause --all will unpause all **paused**
containers.
Signed-off-by: baude <bbaude@redhat.com>
Diffstat (limited to 'cmd/podman/shared')
-rw-r--r-- | cmd/podman/shared/parallel.go | 15 |
1 files changed, 15 insertions, 0 deletions
diff --git a/cmd/podman/shared/parallel.go b/cmd/podman/shared/parallel.go index dbf43a982..633781a45 100644 --- a/cmd/podman/shared/parallel.go +++ b/cmd/podman/shared/parallel.go @@ -72,6 +72,16 @@ func ParallelExecuteWorkerPool(workers int, functions []ParallelWorkerInput) map func Parallelize(job string) int { numCpus := runtime.NumCPU() switch job { + case "kill": + if numCpus <= 3 { + return numCpus * 3 + } + return numCpus * 4 + case "pause": + if numCpus <= 3 { + return numCpus * 3 + } + return numCpus * 4 case "ps": return 8 case "restart": @@ -88,6 +98,11 @@ func Parallelize(job string) int { } else { return numCpus * 3 } + case "unpause": + if numCpus <= 3 { + return numCpus * 3 + } + return numCpus * 4 } return 3 } |