Basically, the title says it all: Is there any limit in the number of containers running at the same time on a single Docker host?
相关问题
- Docker task in Azure devops won't accept "$(pw
- Unable to run mariadb when mount volume
- Unspecified error (0x80004005) while running a Doc
- What would prevent code running in a Docker contai
- How to reload apache in php-apache docker containe
There are a number of system limits you can run into (and work around) but there's a significant amount of grey area depending on
The figures below are from the boot2docker 1.11.1 vm image which is based on Tiny Core Linux 7. The kernel is 4.4.8
Docker
Docker creates or uses a number of resources to run a container, on top of what you run inside the container.
docker0
bridge (1023 max per bridge)shm
file system (1048576 mounts max per fs type)docker-containerd-shim
management process (~3MB per container on avg andsysctl kernel.pid_max
)cgroup
s and name spacesulimit -n
andsysctl fs.file-max
)Docker options
-p
will run a extra process per port number on the host (~4.5MB per port on avg pre 1.12, ~300k per port > 1.12 and alsosysctl kernel.pid_max
)--net=none
and--net=host
would remove the networking overheads.Container services
The overall limits will normally be decided by what you run inside the containers rather than dockers overhead (unless you are doing something esoteric, like testing how many containers you can run :)
If you are running apps in a virtual machine (node,ruby,python,java) memory usage is likely to become your main issue.
IO across a 1000 processes would cause a lot of IO contention.
1000 processes trying to run at the same time would cause a lot of context switching (see vm apps above for garbage collection)
If you create network connections from a 1000 containers the hosts network layer will get a workout.
It's not much different to tuning a linux host to run a 1000 processes, just some additional Docker overheads to include.
Example
1023 Docker busybox images running
nc -l -p 80 -e echo host
uses up about 1GB of kernel memory and 3.5GB of system memory.1023 plain
nc -l -p 80 -e echo host
processes running on a host uses about 75MB of kernel memory and 125MB of system memoryStarting 1023 containers serially took ~8 minutes.
Killing 1023 containers serially took ~6 minutes
From a post on the mailing list, at about 1000 containers you start running into Linux networking issues.
The reason is: