l’Almanet doLys Gnu/Linux – Open Source – Entreprises › Forums › L’almanet doLys Open Source › Tuto: Installer Pi-hole et Unbound avec Docker ; gérer les publicités et les requêtes DNS de manière efficace.
- This topic is empty.
-
AuteurArticles
-
septembre 7, 2024 à 11:02 am #12633nam1962Keymaster
Introduction
Je vais vous montrer ici comment mettre en place Pi-hole, un serveur DNS qui bloque les publicités, en utilisant Docker, tout en configurant Unbound comme résolveur DNS local. Cette configuration vous permettra de naviguer sur Internet sans être dérangé par les publicités indésirables.
Mais ce n’est pas tout ! En contrôlant votre propre infrastructure DNS, vous devenez souverain de vos données. Vous évitez ainsi plusieurs types de menaces courantes :
– Les indiscrétions : Vos requêtes DNS sont souvent interceptées et analysées par des tiers. Avec votre propre serveur, vous gardez le contrôle de ces informations sensibles.
– Les DNS menteurs : les FAI sont sous contrôle des administrations et censurent, redirigent, surveillent les requêtes. Votre serveur DNS personnel préserve l’intégrité de vos connexions.
– Les scripts indiscrets : De nombreux sites web chargent des scripts aux actions diverses et jamais utiles pour vous. Pi-hole peut bloquer ces scripts, renforçant ainsi votre confidentialité en ligne.Cette configuration donne donc un triple avantage : elle bloque les publicités, améliore votre sécurité et renforce votre souveraineté numérique.
Ce tutoriel vous permettra aussi de découvrir Docker et les conteneurs, une technologie de virtualisation légère qui simplifie grandement le déploiement d’applications et… le jour où vous vous amusez à avoir un serveur autohébergé, vous permettra de proposer le service à tous vos appareils connectés.
Prérequis
Avant de commencer, assurez-vous d’avoir :
– Un système Manjaro ou Debian à jour.
– Docker et Docker Compose installés.
– Accès à un terminal avec des privilèges sudo.Étape 1 : Installer Docker et Docker Compose
Si vous n’avez pas encore installé Docker et Docker Compose, voici comment procéder :
Pour Manjaro
Ouvrez votre terminal et exécutez les commandes suivantes :
sudo pacman -S docker docker-compose sudo systemctl start docker sudo systemctl enable docker
Pour Debian
Pour Debian, utilisez ces commandes :
sudo apt update sudo apt install docker-ce docker-compose sudo systemctl start docker sudo systemctl enable docker
Étape 2 : Créer la structure de répertoires
Je vais créer un répertoire pour mon projet et y ajouter les fichiers nécessaires :
mkdir -p ~/docker/pihole cd ~/docker/pihole
Étape 3 : Créer le fichier docker-compose.yml
Dans le répertoire ~/docker/pihole, je crée un fichier docker-compose.yml :
services: pihole: container_name: pihole image: pihole/pihole:latest network_mode: host env_file: -.env volumes: - './etc-pihole:/etc/pihole' - './etc-dnsmasq.d:/etc/dnsmasq.d' - './adlists.list:/etc/pihole/adlists.list' cap_add: - NET_ADMIN restart: unless-stopped deploy: resources: limits: cpus: '0.5' memory: 512M reservations: cpus: '0.2' memory: 256M
Étape 4 : Créer le fichier .env
Je vais maintenant créer un fichier .env pour stocker mes variables d’environnement (remplacez truc123 par votre mot de passe à vous ! ):
WEBPASSWORD=truc123 TZ=Europe/Paris PIHOLE_DNS_=127.0.0.1#5335
Étape 5 : Installer Unbound
Unbound n’est pas en Docker, il vient des paquets officiels. Pour l’installer, j’exécute la commande suivante :
Pour Manjaro
sudo pacman -S unbound
Pour Debian
sudo apt install unbound
Étape 6 : Configurer Unbound
Je vais maintenant configurer Unbound. J’ouvre le fichier de configuration d’Unbound :
sudo nano /etc/unbound/unbound.conf
J’ajoute ou modifie les lignes suivantes pour configurer Unbound :
server: # Network settings interface: 0.0.0.0 interface: ::0 port: 5335 do-ip4: yes do-ip6: yes do-udp: yes do-tcp: yes # Access control access-control: 127.0.0.0/8 allow access-control: ::1/128 allow access-control: 172.24.0.0/16 allow # Docker network access-control: 192.168.0.0/16 allow # Common home network range access-control: 10.0.0.0/8 allow # For potential VPN or other # Basic settings verbosity: 1 num-threads: 2 outgoing-range: 8192 so-rcvbuf: 4m so-sndbuf: 4m edns-buffer-size: 1472 msg-cache-size: 200m rrset-cache-size: 400m cache-min-ttl: 30 cache-max-ttl: 86400 cache-max-negative-ttl: 5 do-not-query-localhost: no # Privacy and security hide-identity: yes hide-version: yes harden-glue: yes harden-dnssec-stripped: yes harden-algo-downgrade: yes harden-short-bufsize: yes use-caps-for-id: yes qname-minimisation: yes qname-minimisation-strict: yes minimal-responses: yes # DNSSEC root-hints: root.hints trust-anchor-file: trusted-key.key auto-trust-anchor-file: "/var/lib/unbound/root.key" # Correct path here # TLS settings tls-cert-bundle: "/etc/ssl/certs/ca-certificates.crt" tls-ciphersuites: "TLS_AES_128_GCM_SHA256:TLS_AES_256_GCM_SHA384:TLS_CHACHA20_POLY1305_SHA256" tls-ciphers: "HIGH:!aNULL:!MD5:!3DES" # Performance optimizations prefetch: yes prefetch-key: yes serve-expired: yes aggressive-nsec: yes ratelimit: 1000 # Module configuration module-config: "iterator" # Pi-hole forward zone forward-zone: name: "pi.hole" forward-addr: 127.0.0.1@53 # Main forward zone with HTTPS upstream forward-zone: name: "." forward-tls-upstream: yes # DNS non censuré, évitant la surveillance des 14 yeux forward-addr: 198.180.150.12#rgnet-iad.anycast.censurfridns.dk # RGnet OU, Estonia forward-addr: 89.233.43.71#unicast.censurfridns.dk # UncensoredDNS, Denmark # OpenNIC, un projet qui offre des serveurs DNS alternatifs forward-addr: 185.121.177.177#ns1.any.dns.opennic.glue # OpenNIC, hors 14 yeux forward-addr: 161.97.219.84#ns2.any.dns.opennic.glue # OpenNIC, hors 14 yeux # DNS alternatif basé en Islande, hors 14 yeux et respectueux de la vie privée forward-addr: 89.187.100.11#dns.isnic.is # ISNIC, Iceland # DNS alternatif basé en Suisse, hors 14 yeux et respectueux de la vie privée forward-addr: 84.200.69.80#dns.watch # DNS.WATCH, Switzerland forward-addr: 84.200.70.40#dns.watch # DNS.WATCH, Switzerland # BlahDNS, pour une option supplémentaire axée sur la confidentialité, basée au Japon forward-addr: 104.238.191.243#dns.blahdns.com # BlahDNS, Japan forward-addr: 2001:19f0:7001:1b5b::1#dns.blahdns.com # BlahDNS, Japan (IPv6)
Étape 7 : Démarrer le conteneur Pi-hole
Maintenant que tout est configuré, je vais démarrer le conteneur Pi-hole. Je m’assure d’être dans le répertoire de Pi-hole, puis j’exécute :
cd ~/docker/pihole sudo docker-compose up -d
La commande
docker-compose up -d
va :
1. Construire l’image si nécessaire
2. Créer et démarrer le conteneur
3. Le faire tourner en arrière-plan (-d signifie detached mode)Bien que nous ayons utilisé docker-compose, cela ne lance qu’un seul conteneur dans notre cas, car notre fichier docker-compose.yml définit uniquement un service nommé « pihole ».
Il est important de noter que :
– Nous utilisons docker-compose même pour un seul conteneur car cela facilite la gestion future si nous devions ajouter d’autres services.
– docker-compos` gère automatiquement les volumes, les ports, et autres paramètres définis dans le fichier docker-compose.yml.
– La consommation de ressources (RAM et CPU) est extrêmement faible, ce qui rend cette configuration idéale pour les systèmes modestes ou les ordinateurs portables.Étape 8 : Vérification de l’installation
Pour vérifier que tout fonctionne correctement, j’ouvre mon navigateur et je vais à l’adresse
http://localhost:80
. Je devrais voir l’interface de Pi-hole. Je me connecte avec le mot de passe que j’ai défini dans le fichier .env.
Étape 9 : Configuration de votre routeur
Pour que tous mes appareils utilisent Pi-hole pour les requêtes DNS, je configure mon routeur pour utiliser l’adresse IP de mon serveur comme serveur DNS principal.
Conclusion
Voilà, j’ai maintenant un système Pi-hole fonctionnant avec Unbound, prêt à bloquer les publicités et à gérer mes requêtes DNS de manière efficace. N’hésitez pas à explorer les différentes options de configuration pour adapter le système à vos besoins. Si vous avez des questions ou des problèmes, consultez la documentation officielle de Pi-hole et Unbound pour des conseils supplémentaires.
Ce tutoriel vous a permis de découvrir Docker et les conteneurs, une technologie puissante pour déployer facilement des applications. J’espère que vous avez apprécié l’expérience et que vous pourrez réutiliser ces compétences pour d’autres projets.
Commandes utiles
– Pour arrêter les conteneurs :
sudo docker-compose down
– Pour voir les logs de Pi-hole :
sudo docker logs pihole
– Pour mettre à jour les images :
sudo docker-compose pull
J’espère que ce tutoriel vous a été utile. N’hésitez pas à partager vos expériences et vos questions dans les commentaires!
Notes supplémentaires :
– Documentation officielle de Pi-hole : https://docs.pi-hole.net/
– Documentation officielle d’Unbound : https://www.nlnetlabs.nl/documentation/unbound/Un jeune site que j'aime bien, la ferrari du T-shirt ...bio en plus : GoudronBlanc
-
AuteurArticles
- Vous devez être connecté pour répondre à ce sujet.