I’m using the module nethserver-pihole made by @stephdl and it works like a charm.
Today, I’ve updated the docker container as I do regularly, but afterwards, pihole did not came up the way it used to do:
pihole status reported the container in state unhealthy
WebUI showed in top-left status "DNS service not running"
Attaching to the container’s commandline to check and restart FTL inside the container did not work, either
Still inside the container’s bash, displaying the log file finally gave a hint:
tail -f /var/log/pihole-FTL.log
[...snip...]
[2022-03-26 09:34:53.421 11844M] -> Unique clients: 0
[2022-03-26 09:34:53.421 11844M] -> Known forward destinations: 0
[2022-03-26 09:34:53.421 11844M] Successfully accessed setupVars.conf
[2022-03-26 09:34:53.423 11844M] FATAL ERROR in dnsmasq core: failed to create listening socket for port 53: Permission denied
[2022-03-26 09:34:53.432 11844M] ########## FTL terminated after 57ms (code 1)! ##########
After some research, I’ve found out that there was an upstream change in Januar 2022 (Release 2022.01 · pi-hole/docker-pi-hole · GitHub) in regard to the user running FTL inside the container (formerly: root since 01/22: pihole)
The following surely is not the best or most elegant way to achieve a running instance on Nethserver, but the only way I managed to think of in my need to get it up running again. @stephdl May it be possible that you include this change inside nethserver-pihole?
1. open the e-smith action file in an editor nano /etc/e-smith/events/actions/nethserver-pihole-docker-creation
2. insert the line -e DNSMASQ_USER=root\
in each invocation of docker run
I can confirm this issue but this time the container startet (as I got access to the pihole WebUI). Nevertheless I’ve re-ran pihole upgrade again, testing with and without the modification in nethserver-pihole-docker-creation: Without the addition FTL fails to start.
Two ideas which might change behaviour between our deployments:
I’m using macvlan as network, maybe socket-setup is handled differently?
What about the docker version?
[root@nethserver ~]# docker version
Client: Docker Engine - Community
Version: 20.10.14
API version: 1.41
Go version: go1.16.15
Git commit: a224086
Built: Thu Mar 24 01:49:57 2022
OS/Arch: linux/amd64
Context: default
Experimental: true
Server: Docker Engine - Community
Engine:
Version: 20.10.14
API version: 1.41 (minimum version 1.12)
Go version: go1.16.15
Git commit: 87a90dc
Built: Thu Mar 24 01:48:24 2022
OS/Arch: linux/amd64
Experimental: false
containerd:
Version: 1.5.11
GitCommit: 3df54a852345ae127d1fa3092b95168e4a88e2f8
runc:
Version: 1.0.3
GitCommit: v1.0.3-0-gf46b6ba
docker-init:
Version: 0.19.0
GitCommit: de40ad0
However, at the moment it’s up and running, so everything is fine - let’s see what the next upgrade will bring