Configure Custom DNS Service
This article mainly introduces how to use a custom DNS service in the UK8S cluster.
Starting from Kubernetes 1.11, CoreDNS replaced kube-dns as the default DNS scheme. The current version of Kubernetes supported by UK8S is >= 1.11, so this article mainly introduces how to modify the configuration of CoreDNS to achieve the purpose of using a custom DNS service.
Introduction
CoreDNS is a modular, plug-in DNS server, whose configuration file information is saved in the Corefile. UK8S cluster administrators can configure a custom DNS service by modifying the ConfigMap.
In UK8S, the default Corefile configuration information of CoreDNS is as follows:
apiVersion: v1
kind: ConfigMap
data:
Corefile: |
.:53 {
errors
health
kubernetes cluster.local in-addr.arpa ip6.arpa {
pods insecure
upstream
fallthrough in-addr.arpa ip6.arpai
ttl 30
}
prometheus :9153
forward . /etc/resolv.conf {
policy sequential
}
cache 30
loop
reload
loadbalance
}
metadata:
name: coredns
namespace: kube-system
The Corefile configuration information includes the following CoreDNS plugins:
-
errors: error logs will be printed to the container log in standard output;
-
health: The health status of CoreDNS;
-
kubernetes: The Kubernetes plugin is the module used in CoreDNS to replace kube-dns, and it completes the work of converting the domain name of the service to IP. The functions of commonly used parameters are as follows:
-
pods POD-MODES: used to set the processing mode of Pod's A record, such as 1-2-3-4.ns.pod.cluster.local. in A 1.2.3.4. pods disabled is the default value, which means that dns records are not provided for the pod; pods insecure will always return the corresponding A record without verifying ns; pods verified will verify whether ns is correct. If there is a corresponding pod under this ns, then return the A record.
-
upstream [ADDRESS..]: Defines the upstream dns server used to resolve external hosts. If not specified, CoreDNS will handle it by itself, such as using the proxy plugin that will be introduced later.
-
fallthrough [ZONE..]: If this option is specified, the DNS query will be forwarded in the plugin chain. This plugin chain can contain another plugin to handle the query, such as in-addr.arpa.
-
-
prometheus: Metrics exposed by CoreDNS, the default is http://localhost:9153/metrics (opens in a new tab).
-
forward [from to]: Any domain name not belonging to the Kubernetes cluster, its DNS request will point to the DNS server address specified by forward. from is generally ".", representing all domain names. To can be multiple, such as 111.114.114.114 8.8.8.8. It should be noted that the new version of CoreDNS replaces the proxy plugin with the forward plugin, but the usage method is the same. If your cluster is a proxy, it is recommended to change to a forward plugin, which has better performance.
-
reload: allows to automatically load changed Corefile. It is recommended to configure it so that CoreDNS can implement hot updates.
For the meaning of other options, please see the official Kubernetes documentation. Next, let's give an example of how to modify ConfigMap.
Example
Configure the DNS Server for Special Domains
Assuming we have a service domain of ucloudk8s with a private DNS Server address of 10.9.10.8, the cluster administrator can add the following rule in kubectl edit configmap/coredns -n kube-system. This is an independent Server Block, and we can configure different Server Blocks for different domains in the Corefile.
ucloudk8s.com:53 {
errors
cache 30
forward . 10.9.10.8
}
And, we don't want to use the DNS server configured in /etc/resolv.conf as the upstream server, but point to the self-built DNS Server, just directly modify the previously mentioned upstream and proxy options.
upstream 10.9.10.8
forward . 172.16.0.1
The configmap after modifying is as follows:
apiVersion: v1
kind: ConfigMap
data:
Corefile: |
.:53 {
errors
health
kubernetes cluster.local in-addr.arpa ip6.arpa {
pods insecure
upstream 10.9.10.8
fallthrough in-addr.arpa ip6.arpa
}
prometheus :9153
forward . 10.9.10.8
cache 30
loop
reload
loadbalance
}
ucloudk8s.com:53 {
errors
cache 30
forward . 10.9.10.8
}
metadata:
name: coredns
namespace: kube-system
Verification
We install a DNS server on a cloud host under the same VPC (please do not operate in the UK8S Node node) to verify whether the custom DNS is working normally.
Install DNS Server Through Docker
docker run -d -p 53:53/tcp -p 53:53/udp --cap-add=NET_ADMIN --name dns-server andyshinn/dnsmasq:2.75
Enter the Container
docker exec -it dns-server /bin/sh
Configure Upstream DNS Server
vi /etc/resolv.dnsmasq
nameserver 114.114.114.114
nameserver 8.8.8.8
Configure Local Resolution Rules
vi /etc/dnsmasqhosts
110.110.110.110 baidu.com
Modify the dnsmasq configuration file, specify to use the above two custom configuration files, modify the following two options, and restart the container.
vi /etc/dnsmasq.conf
resolv-file=/etc/resolv.dnsmasq
addn-hosts=/etc/dnsmasqhosts
docker restart dns-server
Modify CoreDNS's configmap, add the following rules.
baidu.com:53{
errors
cache 30
forward . 10.9.10.8 (You need to modify it to your DNS address for testing)
}
Enter K8S container and test with dig command. You can see that the resolution address is 110.110.110.110, which is as expected.
bash-4.4# dig baidu.com
; <<>> DiG 9.12.3-P4 <<>> baidu.com
;; global options: +cmd
;; Got answer:
;; ->>HEADER<<- opcode: QUERY, status: NOERROR, id: 39140
;; flags: qr aa rd ra; QUERY: 1, ANSWER: 1, AUTHORITY: 0, ADDITIONAL: 1
;; OPT PSEUDOSECTION:
; EDNS: version: 0, flags:; udp: 4096
;; QUESTION SECTION:
;baidu.com. IN A
;; ANSWER SECTION:
baidu.com. 5 IN A 110.110.110.110
;; Query time: 4 msec
;; SERVER: 172.17.0.2#53(172.17.0.2)
;; WHEN: Mon May 27 09:11:50 UTC 2019
;; MSG SIZE rcvd: 63
FAQs
Modified CoreFile, But the Resolver is not Successful
First, make sure that CoreFile contains the reload plugin. If not, you need to add reload and rebuild CoreDNS to load the latest DNS rules.
Secondly, check the CoreDNS log through ''kubectl logs COREDNS-POD-NAME -n kube-system'' to confirm whether CoreDNS is working normally and whether the DNS configuration is successfully loaded.
If it still doesn't work normally, execute ''dig @YOUR-DNS-SERVER-ADDRESS YOUR-DOMAIN'' in the container or Pod to confirm whether your DNS server is working normally.
If the above operations are all invalid, please contact SurferCloud technical support for assistance.