etcd servers should make use of TLS encryption for client connections
이 페이지는 아직 영어로 제공되지 않습니다. 번역 작업 중입니다.
현재 번역 프로젝트에 대한 질문이나 피드백이 있으신 경우
언제든지 연락주시기 바랍니다.Description
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.
Audit
Run the following command on the master node:
ps -ef | grep kube-apiserver
Verify that the --etcd-certfile
and --etcd-keyfile
arguments exist and they are set as appropriate.
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
CIS controls
Version 6 9 Limitation and Control of Network Ports, Protocols, and Services
Version 7 9 Limitation and Control of Network Ports, Protocols, and Services