this post was submitted on 31 Mar 2026
36 points (100.0% liked)

Linux

13082 readers
574 users here now

A community for everything relating to the GNU/Linux operating system (except the memes!)

Also, check out:

Original icon base courtesy of lewing@isc.tamu.edu and The GIMP

founded 2 years ago
MODERATORS
 

I run CachyOS on my desktop. I host Homepage for myself on a home server. This is reached at home.mydomain.tld. Pihole on my local network catches that request and points it at my local nginx, which reverse proxies me to the homepage.

Now, I set this all up a while back and it all worked totally fine for several weeks. Then, about a week or so ago, for some reason almost every, but not every time I boot my PC, home.mydomain.tld gives me a "cannot be reached" error in my browser... until I run systemctl restart NetworkManager and then it works completely normally.

Can anyone help me troubleshoot why oh why that would suddenly be a thing? Does anyone have suggestions of a way I can troubleshoot a permanent fix to this so that I don't have to restart NetworkManager almost every boot?

top 21 comments
sorted by: hot top controversial new old
[–] Pogogunner@sopuli.xyz 12 points 3 days ago (2 children)

The output of dmseg or journalctl might show you an error message related to networkmanager to give you some clues

[–] iamthetot@piefed.ca 2 points 2 days ago

There's a lot in there and I'm not seeing any errors related to NetworkManager.

[–] iamthetot@piefed.ca 4 points 3 days ago

Thank you for the suggestion, I will check these next time.

[–] frongt@lemmy.zip 9 points 3 days ago

Ugh, this is the bane of my existence. For decades, this worked reliably. Then they introduced networkmanager and systemd-resolved, and everything went out the window and now it's impossible to trace behavior.

I would verify your network and dns settings. One or both of those things I mentioned are probably interfering in resolution.

[–] Petter1@discuss.tchncs.de 6 points 3 days ago (2 children)

Do you see the dns calls in pi-hole when it is not reaching its destination?

[–] iamthetot@piefed.ca 1 points 2 days ago (1 children)

No, the DNS calls do not show up in pi-hole log when it's not reaching destination. If I do it from my phone, which works fine and has never not resolved for me, they show up on pi-hole as expected.

[–] Petter1@discuss.tchncs.de 3 points 2 days ago

Hmm, interesting…

But we learned now, that your desktop somehow isn’t reaching your DNS (pi-hole) until restart of Network Manager

So next thing i would do is traceroute and dig on your desktop while it is not working, to see what DnS is used in this state

[–] iamthetot@piefed.ca 1 points 3 days ago

I will check this next time it occurs.

[–] ligma_centauri@lemmy.world 2 points 2 days ago

Do you have multiple NIC? I sporadically run into issues where traffic will try to route itself via a secondary network which has limited external access and it is resolved in a similar manner, by bringing down all networks, then re-starting them in a specific order.

Realistically I should probably define some static routes, but it works automatically 99% of the time so I never bother.

If this sounds like a possible cause, check your routes while in failed, and functional states, and set static routes as needed to resolve.

[–] MangoPenguin@piefed.social 3 points 3 days ago (1 children)

So I would start with checking if the request is reaching PiHole.

Next time it breaks, before restarting networkmanager, go check the pihole requests log and see if your DNS queries are even showing up there.

If they are, what does pihole show it's returning for the query, is it the correct IP?

If that's working properly then I would check if you can ping the server by IP directly, make sure that connection is working.

[–] iamthetot@piefed.ca 2 points 3 days ago (1 children)

I will check this next time it happens (I'm very confident that will be later today lol)

Out of curiosity, can you think of a reason why a problem with Pihole would be fixed by restarting my NetworkManager? I was certain the problem had to be on my pc.

[–] MangoPenguin@piefed.social 2 points 2 days ago* (last edited 2 days ago) (1 children)

I don't think it's a problem with PiHole realistically, it sounds more like for some reason your DNS requests are not getting to PiHole.

[–] iamthetot@piefed.ca 2 points 2 days ago (1 children)

Can confirm, when this happens my requests from desktop are not getting to pi-hole. Works from my phone without issue.

[–] MangoPenguin@piefed.social 2 points 2 days ago

Nice, narrowing it down!

Next thing I would check is your configured DNS servers on the desktop, it needs to have only the pihole IP, if it has any other servers configured that is likely the issue.

Also worth pinging the pihole IP next time it's not working, to check if it's actually a networking issue instead of a DNS issue.

[–] chromeleon@lemmy.world 4 points 3 days ago

I'm pretty clueless, but perhaps try putting a short time delay on the NetworkManager service startup.

[–] Scoopta@programming.dev 3 points 3 days ago (1 children)

Is your pihole server the only DNS server set? Either on your PC or router? Is network manager sometimes using a different nameserver?

[–] iamthetot@piefed.ca 2 points 3 days ago (2 children)
[–] Scoopta@programming.dev 3 points 2 days ago (1 children)

nmcli device show eth0

Or replace eth0 with whatever interface it is. Will give you a list of all network parameters including the DNS servers. There ideally should only be one, your pihole

[–] iamthetot@piefed.ca 2 points 2 days ago (1 children)

There is only one IP4 DNS address, however there are two IP6 DNS addresses for my ethernet interface. However, I also notice that the GENERAL.CON-PATH ends in 2, whereas I have another interface lo which ends in 1. Would that be a clue of anything?

[–] Scoopta@programming.dev 2 points 1 day ago* (last edited 1 day ago)

It's normal for the loopback con path to end in 1, each con path is unique for each interface. My guess is that if your pihole sometimes works, the IPv4 server is your pihole and the IPv6 servers are ISP provided (especially if there are 2), so they work for the internet but not your internal network. Ideally you would set your pihole's IPv6 address as your IPv6 DNS as well. Failing that, setting the IPv6 mode in your network manager UI to "Automatic, addresses only" will make it not used for DNS

[–] Flyswat@lemmy.dbzer0.com 2 points 2 days ago

resolvectl status