this post was submitted on 24 Dec 2024
5 points (100.0% liked)
Arch Linux
7891 readers
1 users here now
The beloved lightweight distro
founded 5 years ago
MODERATORS
you are viewing a single comment's thread
view the rest of the comments
view the rest of the comments
The output is an error:
install: cannot stat '/dev/fd/63': No such file or directory
.Don't slap a sudo in front where it doesn't belong. Run this as root, or the shell redirection will fail. Or just create that file with these contents in any other way you like and feel comfortable with, it's not a magic incantation you have to use verbatim, after all.
I ran the command with
sudo
and got the error. I created the file withsudoedit
and added the contents in it andsystemctl reload systemd-resolved
. But the DNS requests are sent with port53
to the default DNS server yet and:Yes, that's why I said don't do that. It's a common, non-intuitive interaction with sudo and shell redirections. Don't stress over it, I shouldn't have done it all that fancy in the first place.
Regarding your problem: Your setup is likely inconsistent now due to your experiments and previous setup attempts. HOLD THE REINSTALL, learn to fix it, it's not that complex. First off: you're not running in the recommended "stub mode" where
/etc/resolv.conf
is symlinked to/run/systemd/resolve/stub-resolv.conf
, and where the configuration you did is actually actively used. Fix that first. Have some docs. This is my stub/etc/resolv.conf
, for example, so you know what to look for, roughly:Don't create that file with these contents manually. Read the docs, follow the instructions, don't ruin your day.
Assert you have no lingering, conflicting setup in the
/etc/systemd/resolved.conf
main config. The default file is effectively empty / commented out, to allow for automatic system updates without conflicts. You could reinstall the package to get the original file back if you're unsure.Make sure the
systemd-resolved.service
is enabled and started:systemctl enable --now systemd-resolved.service
You might want to installsystemd-resolvconf
as well if you commit to a systemd-resolved setup, for maximum compatibility.Make use of
resolvectl status
to verify the status:If that's still not what is expected, crank up debugging and check the logs of the service to see if for some reason your config file isn't loaded due to a typo somewhere, or if it's loaded, any other reason that may override your settings later. It's practically guaranteed there's an inconsistency left somewhere, and reading the debug log points you at the actual problem.
It's worth fixing this in that way. With stub mode, you gain a lot of flexibility in your setup, and it works well in tandem with NetworkManager, DHCP, VPNs, and libvirt/qemu networking. You have to make sure you're not inadvertently setting up some broken "hybrid" of old-school /etc/resolv.conf manual config and systemd-resolved, this will drive you mad, and it's a pain to diagnose. Read that wiki page, do not intermingle with crap you pick up on stackoverflow or AI bullshit, and you'll end up with a DNS config that actually works like magic.
Thank you for spending your time. Yes,
resolvectl status
's output is like yours inGlobal
part, but in the end of the output there is this:As you see,
wlp3s0
uses the default ISP DNS. Wireshark's output confirms this.Yeah, that's normal, intended, and does not prevent general lookups taking the global DNS first. Do you see an issue with this?
I gave this setup a try real quick, to make sure I'm not overlooking something, with dnsmasq for testing on 127.0.0.1:9053:
When triggering a query on that test record, f. ex. with
ping -c1 testme.localnet
, you'll see it's directed to the dnsmasq instance and working as intended:The DNS setup with systemd-resolved is pretty confusing, and outright contradicts many, MANY previously correct instructions of how to set your
/etc/resolv.conf
. I'm not surprised if it is giving you a headache right now, but all I can say is to diligently work through its configuration, and understand how systemd-resolved is supposed to work. From experience, make sure your tests are sound and representative, or you'll continue looking for errors in your setup despite everything actually working just fine, maybe because you missed a reload or had a typo or misunderstanding in your wireshark filter.In the same vein, make sure your DNS listening on :9053 is really working as intended, otherwise you can bark up the wrong tree all day long. Debug logging is your friend, and more accessible and less error prone than tcpdump/wireshark.
You'll figure it out from here, I'm sure.
Thanks! I wasted your time. As you said the problem caused a headache to me. I stop trying on it for some days.
Wise decision! Best of luck for when you give it another try, with fresh eyes and a clear mind, and enjoy your XP gain dopamine on the way.