-
Notifications
You must be signed in to change notification settings - Fork 6.5k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Do not assume systemd-resolved for resolv.conf #11813
base: master
Are you sure you want to change the base?
Do not assume systemd-resolved for resolv.conf #11813
Conversation
/ok-to-test |
[APPROVALNOTIFIER] This PR is APPROVED This pull-request has been approved by: VannTen The full list of commands accepted by this bot can be found here. The pull request process is described here
Needs approval from an approver in each of these files:
Approvers can indicate their approval by writing |
We currently assume on some distribution that systemd-resolved is used and therefore we can use /run/systemd/resolve/resolv.conf to pass to the kubelet configuration. This breaks if the distribution is configured differently (use another DNS service) and force us to special case. Instead, detect if systemd-resolved is running dynamically and set kube_resolv_conf default accordingly.
aee5e23
to
e4d3a6f
Compare
Thanks @VannTen |
PR needs rebase. Instructions for interacting with me using PR comments are available here. If you have questions or suggestions related to my behavior, please file an issue against the kubernetes-sigs/prow repository. |
If systemd-resolved is not enabled, use
I think that should solve your situation. |
stub-resolv.conf use systemd-resolved stub resolver in
Pods don't have access to localhost network, so stub-resolv.conf wouldn't work. |
@@ -6,7 +6,7 @@ kubelet_address: "{{ ip | default(fallback_ip) }}{{ (',' + ip6) if enable_dual_s | |||
kubelet_bind_address: "{{ ip | default('0.0.0.0') }}" | |||
|
|||
# resolv.conf to base dns config | |||
kube_resolv_conf: "/etc/resolv.conf" | |||
kube_resolv_conf: "{{ '/run/systemd/resolve/resolv.conf' if 'systemd-resolved' in active_dns_services else '/etc/resolv.conf' }}" |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I know that some resolv.conf modes (static if I remember correctly) check /etc/resolv.conf
for files.
Using the systemd-resolved enablement as a check doesn't seem to be accurate.
kube_resolv_conf
is by default still /etc/resolv.conf
.
If systemd-resolved is enabled and /etc/resolv.conf
is a soft link, change kube_resolv_conf
to /run/systemd/resolve/resolv.conf
.
What do you think?
What type of PR is this?
/kind bug
What this PR does / why we need it:
We currently assume on some distribution that systemd-resolved is used
and therefore we can use /run/systemd/resolve/resolv.conf to pass to the
kubelet configuration.
This breaks if the distribution is configured differently (use another
DNS service) and force us to special case.
Instead, detect if systemd-resolved is running dynamically and set
kube_resolv_conf default accordingly.
Which issue(s) this PR fixes:
Fixes #11810
Special notes for your reviewer:
I'm just wondering if this could cause breakage when systemd-resolved is running but /etc/resolv.conf does not point to its managed files and has other settings 🤔
I'm not sure what we should do in that case (but I don't think hardcoding is the answer).
Does this PR introduce a user-facing change?: