1.2.29 Ensure that the --etcd-certfile and --etcd-keyfile arguments are set as appropriate - certfile

Warning! Audit Deprecated

This audit has been deprecated and will be removed in a future update.

View Next Audit Version

Information

etcd should be configured to make use of TLS encryption for client connections.

Rationale:

etcd is a highly-available key value store used by Kubernetes deployments for persistent storage of all of its REST API objects. These objects are sensitive in nature and should be protected by client authentication. This requires the API server to identify itself to the etcd server using a client certificate and key.

Solution

Follow the Kubernetes documentation and set up the TLS connection between the apiserver and etcd. Then, edit the API server pod specification file /etc/kubernetes/manifests/kube-apiserver.yaml on the master node and set the etcd certificate and key file parameters.

--etcd-certfile=<path/to/client-certificate-file>
--etcd-keyfile=<path/to/client-key-file>

Impact:

TLS and client certificate authentication must be configured for etcd.

Default Value:

By default, --etcd-certfile and --etcd-keyfile arguments are not set

References:

https://kubernetes.io/docs/admin/kube-apiserver/

https://coreos.com/etcd/docs/latest/op-guide/security.html

See Also

https://workbench.cisecurity.org/files/2662

Item Details

Category: IDENTIFICATION AND AUTHENTICATION

References: 800-53|IA-5(2), CSCv6|9, CSCv7|9

Plugin: Unix

Control ID: fdf2a8b10a4fba3e978f49717ea207186efef883d36bcf4ec1436dbcbafcf849