Skip to content

Commit

Permalink
Add troubleshooting section to kube-dns readme
Browse files Browse the repository at this point in the history
  • Loading branch information
MrHohn committed Oct 18, 2016
1 parent 92c443e commit 6390856
Showing 1 changed file with 147 additions and 3 deletions.
150 changes: 147 additions & 3 deletions docs/admin/dns.md
Original file line number Diff line number Diff line change
Expand Up @@ -124,7 +124,7 @@ With v1.3, the following annotations are deprecated: `pod.beta.kubernetes.io/hos

## How do I test if it is working?

### Create a simple Pod to use as a test environment.
### Create a simple Pod to use as a test environment

Create a file named busybox.yaml with the
following contents:
Expand Down Expand Up @@ -152,7 +152,7 @@ Then create a pod using this file:
kubectl create -f busybox.yaml
```

### Wait for this pod to go into the running state.
### Wait for this pod to go into the running state

You can get its status with:
```
Expand All @@ -165,7 +165,7 @@ NAME READY STATUS RESTARTS AGE
busybox 1/1 Running 0 <some-time>
```

### Validate DNS works
### Validate that DNS is working

Once that pod is running, you can exec nslookup in that environment:

Expand All @@ -185,6 +185,122 @@ Address 1: 10.0.0.1

If you see that, DNS is working correctly.

### Troubleshooting Tips

If the nslookup command fails, check the following:

#### Check the local DNS configuration first
Take a look inside the resolv.conf file. (See "Inheriting DNS from the node" and "Known issues" below for more information)

```
cat /etc/resolv.conf
```

Verify that the search path and name server are set up like the following (note that seach path may vary for different cloud providers):

```
search default.svc.cluster.local svc.cluster.local cluster.local google.internal c.gce_project_id.internal
nameserver 10.0.0.10
options ndots:5
```

#### Quick diagnosis

Errors such as the following indicate a problem with the kube-dns add-on or associated Services:

```
/ # nslookup kubernetes
Server: 10.0.0.10
Address 1: 10.0.0.10
nslookup: can't resolve 'kubernetes'
```

or

```
/ # nslookup kubernetes
Server: 10.0.0.10
Address 1: 10.0.0.10 kube-dns.kube-system.svc.cluster.local
nslookup: can't resolve 'kubernetes'
```

#### Check if the DNS pod is running

Use the kubectl get pods command to verify that the DNS pod is running.

```
kubectl get pods --namespace=kube-system -l k8s-app=kube-dns
```

You should see something like:

```
NAME READY STATUS RESTARTS AGE
...
kube-dns-v19-ezo1y 3/3 Running 0 1h
...
```

If you see that no pod is running or that the pod has failed/completed, the dns add-on may not be deployed by default in your current environment and you have not deployed it manually.

#### Check for Errors in the DNS pod

Use `kubectl logs` command for detective work.

```
kubectl logs --namespace=kube-system $(kubectl get pods --namespace=kube-system -l k8s-app=kube-dns -o name) -c kubedns
kubectl logs --namespace=kube-system $(kubectl get pods --namespace=kube-system -l k8s-app=kube-dns -o name) -c dnsmasq
kubectl logs --namespace=kube-system $(kubectl get pods --namespace=kube-system -l k8s-app=kube-dns -o name) -c healthz
```

See if you could find any suspicious log like below:

```
(From kubedns)
F1017 17:39:44.063280 90225 server.go:56] Failed to create a kubernetes client: invalid configuration: no configuration has been provided
```

Please use [kubernetes issues](https://github.com/kubernetes/kubernetes/issues) to trace/report unintended errors.

#### Is dns service up?

Verify that the DNS service is up by using the `kubectl get service` command.

```
kubectl get svc --namespace=kube-system
```

You should see something like:

```
NAME CLUSTER-IP EXTERNAL-IP PORT(S) AGE
...
kube-dns 10.0.0.10 <none> 53/UDP,53/TCP 1h
...
```

If you have created the service or in the case it should be created by default but it does not appear, see this [debugging services page](http://kubernetes.io/docs/user-guide/debugging-services/) for more information.

#### Are dns endpoints exposed?

You can verify that dns endpoints are exposed by using the `kubectl get endpoints` command.

```
kubectl get ep kube-dns --namespace=kube-system
```

You should see something like:
```
NAME ENDPOINTS AGE
kube-dns 10.180.3.17:53,10.180.3.17:53 1h
```

If you do not see the endpoints, see endpoints section in the [debugging services documentation](http://kubernetes.io/docs/user-guide/debugging-services/).

For additional Kubernetes DNS examples, see the [cluster-dns examples](https://github.com/kubernetes/kubernetes/tree/master/examples/cluster-dns) in the Kubernetes GitHub repository.

## Kubernetes Federation (Multiple Zone support)

Release 1.3 introduced Cluster Federation support for multi-site
Expand Down Expand Up @@ -213,6 +329,34 @@ the flag `--cluster-domain=<default local domain>`
The Kubernetes cluster DNS server (based off the [SkyDNS](https://github.com/skynetservices/skydns) library)
supports forward lookups (A records), service lookups (SRV records) and reverse IP address lookups (PTR records).

## Inheriting DNS from the node
When running a pod, kubelet will prepend the cluster DNS server and search
paths to the node's own DNS settings. If the node is able to resolve DNS names
specific to the larger environment, pods should be able to, also. See "Known
issues" below for a caveat.

If you don't want this, or if you want a different DNS config for pods, you can
use the kubelet's `--resolv-conf` flag. Setting it to "" means that pods will
not inherit DNS. Setting it to a valid file path means that kubelet will use
this file instead of `/etc/resolv.conf` for DNS inheritance.

## Known issues
Kubernetes installs do not configure the nodes' resolv.conf files to use the
cluster DNS by default, because that process is inherently distro-specific.
This should probably be implemented eventually.

Linux's libc is impossibly stuck ([see this bug from
2005](https://bugzilla.redhat.com/show_bug.cgi?id=168253)) with limits of just
3 DNS `nameserver` records and 6 DNS `search` records. Kubernetes needs to
consume 1 `nameserver` record and 3 `search` records. This means that if a
local installation already uses 3 `nameserver`s or uses more than 3 `search`es,
some of those settings will be lost. As a partial workaround, the node can run
`dnsmasq` which will provide more `nameserver` entries, but not more `search`
entries. You can also use kubelet's `--resolv-conf` flag.

If you are using Alpine version 3.3 or earlier as your base image, dns may not
work properly owing to a known issue with Alpine. Check [here](https://github.com/kubernetes/kubernetes/issues/30215)
for more information.

## References

Expand Down

0 comments on commit 6390856

Please sign in to comment.