DNS¶
CLARA can analyze the logs of CoreDNS (the default Kubernetes DNS server) to discover communication of components via DNS queries.
For that feature to work correctly, it is crucial that the DNS server is configured to log DNS queries by enabling the log
plugin.
Other DNS servers
Your cluster might come with additional DNS servers to reduce the load.
A prominent example is the node-local-dns for caching DNS.
There, you must also enable the log
plugin.
Compatible DNS servers
Because CLARA analyzes the logged DNS queries,
- query logging must be activated
- the query logs must be compatible with the CoreDNS logs.
Currently, CLARA analyzes all logs from the pods with the labels k8s-app=kube-dns
or k8s-app=node-local-dns
in the namespace kube-system
.
Managed Kubernetes cluster¶
Using a managed Kubernetes cluster from a service provider
When using a managed cluster from a service provider, changes to core components of Kubernetes might be not allowed directly. Please consult the documentation of your respective provider.
DigitalOcean¶
For DigitalOcean, the correct way of enabling logging is to create a special ConfigMap:
ConfigMap to activate query logging for CoreDNS in a Kubernetes cluster managed by DigitalOcean | |
---|---|
DNS debugging¶
As described in the Kubernetes Documentation, you can use dnsutils to debug DNS resolution. For CLARA, this is also a simple way of creating DNS queries explicitly and checking if CLARA detects the communication. Just create a dnsutils-pod with the following manifest:
Then you can use the following command to execute DNS queries:
Execute the following command to check the DNS server logs:
Concept¶
The log DNS analysis uses the obtained information from the Kubernetes API to match the hostnames and ip-addresses in a DNS log to components of the cluster.
An example log can look like this and provides disclosure about the source and target of a communication.