Control: 5.21 Ensure that the host's UTS namespace is not shared
Description
UTS namespaces provide isolation between two system identifiers: the hostname and the NIS domain name. It is used to set the hostname and the domain which are visible to running processes in that namespace. Processes running within containers do not typically require to know either the hostname or the domain name. The UTS namespace should therefore not be shared with the host.
Sharing the UTS namespace with the host provides full permission for each container to change the hostname of the host. This is not in line with good security practice and should not be permitted.
Remediation
You should not start a container with the --uts=host argument. For example, do not start a container using the command below:
docker run --rm --interactive --tty --uts=host rhel7.2
Default Value
By default, all containers have the UTS namespace enabled and the host UTS namespace is not shared with any containers.
Usage
Run the control in your terminal:
powerpipe control run docker_compliance.control.cis_v160_5_21
Snapshot and share results via Turbot Pipes:
powerpipe loginpowerpipe control run docker_compliance.control.cis_v160_5_21 --share
SQL
This control uses a named query:
docker_container_host_uts_namespace_shared