Merge pull request #805 from bogdando/dnsmasq_armors
Do not forward private domains for upstream resolvers
This commit is contained in:
commit
be8e5e1fdc
4 changed files with 13 additions and 5 deletions
docs
roles
dnsmasq/templates
kubernetes-apps/ansible/templates
kubernetes/preinstall/tasks
|
@ -51,6 +51,13 @@ aforementioned vars:
|
||||||
* Resolvconf's head/base files are disabled from populating anything into the
|
* Resolvconf's head/base files are disabled from populating anything into the
|
||||||
`/etc/resolv.conf`.
|
`/etc/resolv.conf`.
|
||||||
|
|
||||||
|
It is important to note that multiple search domains combined with high ``ndots``
|
||||||
|
values lead to poor performance of DNS stack, so please choose it wisely.
|
||||||
|
The dnsmasq DaemonSet can accept lower ``ndots`` values and return NXDOMAIN
|
||||||
|
replies for [bogus internal FQDNS](https://github.com/kubernetes/kubernetes/issues/19634#issuecomment-253948954)
|
||||||
|
before it even hits the kubedns app. This enables dnsmasq to serve as a
|
||||||
|
protective, but still recursive resolver in front of kubedns.
|
||||||
|
|
||||||
DNS configuration details
|
DNS configuration details
|
||||||
-------------------------
|
-------------------------
|
||||||
|
|
||||||
|
@ -106,8 +113,7 @@ Limitations
|
||||||
[no way to specify a custom value](https://github.com/kubernetes/kubernetes/issues/33554)
|
[no way to specify a custom value](https://github.com/kubernetes/kubernetes/issues/33554)
|
||||||
for the SkyDNS ``ndots`` param via an
|
for the SkyDNS ``ndots`` param via an
|
||||||
[option for KubeDNS](https://github.com/kubernetes/kubernetes/blob/master/cmd/kube-dns/app/options/options.go)
|
[option for KubeDNS](https://github.com/kubernetes/kubernetes/blob/master/cmd/kube-dns/app/options/options.go)
|
||||||
add-on, while SkyDNS supports it though. Thus, DNS SRV records may not work
|
add-on, while SkyDNS supports it though.
|
||||||
as expected as they require the ``ndots:7``.
|
|
||||||
|
|
||||||
* the ``searchdomains`` have a limitation of a 6 names and 256 chars
|
* the ``searchdomains`` have a limitation of a 6 names and 256 chars
|
||||||
length. Due to default ``svc, default.svc`` subdomains, the actual
|
length. Due to default ``svc, default.svc`` subdomains, the actual
|
||||||
|
|
|
@ -7,6 +7,8 @@ addn-hosts=/etc/hosts
|
||||||
strict-order
|
strict-order
|
||||||
# Forward k8s domain to kube-dns
|
# Forward k8s domain to kube-dns
|
||||||
server=/{{ dns_domain }}/{{ skydns_server }}
|
server=/{{ dns_domain }}/{{ skydns_server }}
|
||||||
|
# Reply NXDOMAIN to bogus domains requests like com.cluster.local.cluster.local
|
||||||
|
local=/{{ bogus_domains }}
|
||||||
|
|
||||||
#Set upstream dns servers
|
#Set upstream dns servers
|
||||||
{% if upstream_dns_servers is defined %}
|
{% if upstream_dns_servers is defined %}
|
||||||
|
@ -17,7 +19,7 @@ server={{ srv }}
|
||||||
server={{ default_resolver }}
|
server={{ default_resolver }}
|
||||||
{% endif %}
|
{% endif %}
|
||||||
|
|
||||||
{% if kube_log_level == 4 %}
|
{% if kube_log_level == '4' %}
|
||||||
log-queries
|
log-queries
|
||||||
{% endif %}
|
{% endif %}
|
||||||
bogus-priv
|
bogus-priv
|
||||||
|
|
|
@ -79,7 +79,7 @@ spec:
|
||||||
- --cache-size=1000
|
- --cache-size=1000
|
||||||
- --no-resolv
|
- --no-resolv
|
||||||
- --server=127.0.0.1#10053
|
- --server=127.0.0.1#10053
|
||||||
{% if kube_log_level == 4 %}
|
{% if kube_log_level == '4' %}
|
||||||
- --log-queries
|
- --log-queries
|
||||||
{% endif %}
|
{% endif %}
|
||||||
ports:
|
ports:
|
||||||
|
|
|
@ -10,7 +10,7 @@
|
||||||
{%- if resolvconf.rc == 0 -%}true{%- else -%}false{%- endif -%}
|
{%- if resolvconf.rc == 0 -%}true{%- else -%}false{%- endif -%}
|
||||||
|
|
||||||
- set_fact:
|
- set_fact:
|
||||||
private_domains: |-
|
bogus_domains: |-
|
||||||
{% for d in [ 'default.svc.' + dns_domain, 'svc.' + dns_domain ] + searchdomains|default([]) -%}
|
{% for d in [ 'default.svc.' + dns_domain, 'svc.' + dns_domain ] + searchdomains|default([]) -%}
|
||||||
{{dns_domain}}.{{d}}./{{d}}.{{d}}./com.{{d}}./
|
{{dns_domain}}.{{d}}./{{d}}.{{d}}./com.{{d}}./
|
||||||
{%- endfor %}
|
{%- endfor %}
|
||||||
|
|
Loading…
Reference in a new issue