mirror of
https://github.com/docker/docker-bench-security.git
synced 2025-01-18 16:22:33 +01:00
3a9deae328
Signed-off-by: Thomas Sjögren <konstruktoid@users.noreply.github.com>
60 lines
2.4 KiB
Bash
60 lines
2.4 KiB
Bash
#!/bin/bash
|
|
|
|
check_6() {
|
|
logit ""
|
|
local id="6"
|
|
local desc="Docker Security Operations"
|
|
checkHeader="$id - $desc"
|
|
info "$checkHeader"
|
|
startsectionjson "$id" "$desc"
|
|
}
|
|
|
|
check_6_1() {
|
|
local id="6.1"
|
|
local desc="Ensure that image sprawl is avoided (Manual)"
|
|
local remediation="You should keep only the images that you actually need and establish a workflow to remove old or stale images from the host. Additionally, you should use features such as pull-by-digest to get specific images from the registry."
|
|
local remediationImpact="docker system prune -a removes all exited containers as well as all images and volumes that are not referenced by running containers, including for UCP and DTR."
|
|
local check="$id - $desc"
|
|
starttestjson "$id" "$desc"
|
|
|
|
images=$(docker images -q | sort -u | wc -l | awk '{print $1}')
|
|
active_images=0
|
|
|
|
for c in $(docker inspect --format "{{.Image}}" "$(docker ps -qa)" 2>/dev/null); do
|
|
if docker images --no-trunc -a | grep "$c" > /dev/null ; then
|
|
active_images=$(( active_images += 1 ))
|
|
fi
|
|
done
|
|
|
|
info -c "$check"
|
|
info " * There are currently: $images images"
|
|
|
|
if [ "$active_images" -lt "$((images / 2))" ]; then
|
|
info " * Only $active_images out of $images are in use"
|
|
fi
|
|
logcheckresult "INFO" "$active_images active/$images in use"
|
|
}
|
|
|
|
check_6_2() {
|
|
local id="6.2"
|
|
local desc="Ensure that container sprawl is avoided (Manual)"
|
|
local remediation="You should periodically check your container inventory on each host and clean up containers which are not in active use with the command: docker container prune"
|
|
local remediationImpact="You should retain containers that are actively in use, and delete ones which are no longer needed."
|
|
local check="$id - $desc"
|
|
starttestjson "$id" "$desc"
|
|
|
|
total_containers=$(docker info 2>/dev/null | grep "Containers" | awk '{print $2}')
|
|
running_containers=$(docker ps -q | wc -l | awk '{print $1}')
|
|
diff="$((total_containers - running_containers))"
|
|
info -c "$check"
|
|
if [ "$diff" -gt 25 ]; then
|
|
info " * There are currently a total of $total_containers containers, with only $running_containers of them currently running"
|
|
else
|
|
info " * There are currently a total of $total_containers containers, with $running_containers of them currently running"
|
|
fi
|
|
logcheckresult "INFO" "$total_containers total/$running_containers running"
|
|
}
|
|
|
|
check_6_end() {
|
|
endsectionjson
|
|
}
|