logo Debian Debian Debian-France Debian-Facile Debian-fr.org Forum-Debian.fr Debian ? Communautés logo inclusivité

Debian-facile

Bienvenue sur Debian-Facile, site d'aide pour les nouveaux utilisateurs de Debian.

Vous n'êtes pas identifié(e).


L'icône rouge permet de télécharger chaque page du wiki visitée au format PDF et la grise au format ODT → ODT PDF Export

Différences

Ci-dessous, les différences entre deux révisions de la page.

Lien vers cette vue comparative

Les deux révisions précédentes Révision précédente
Prochaine révision
Révision précédente
Prochaine révision Les deux révisions suivantes
utilisateurs:hypathie:tutos:proxy-transparent [17/10/2014 16:05]
Hypathie [Vérifications]
utilisateurs:hypathie:tutos:proxy-transparent [04/11/2014 16:13]
Hypathie [Vérifications]
Ligne 8: Ligne 8:
 ===== Introduction ===== ===== Introduction =====
 Voir : [[http://​www.squid-cache.org/​|le site de squid]]\\ ​ Voir : [[http://​www.squid-cache.org/​|le site de squid]]\\ ​
-[[http://​wiki.squid-cache.org/​ConfigExamples/​Intercept/​LinuxDnat|proxy transparent]]+[[http://​wiki.squid-cache.org/​ConfigExamples/​Intercept/​LinuxDnat|proxy transparent]]\\  
 +Voir aussi : [[http://​www.sput.nl/​software/​squid33.html]]\\  
 +[[http://​www.linux-france.org/​prj/​edu/​archinet/​systeme/​ch40s02.html]] 
  
 Lorsqu'​un serveur mandataire est installé, on configure souvent le routage du réseau pour que l'​utilisateur final soit orienté vers le serveur mandataire sans avoir à modifier sa configuration. On parle alors de « proxy transparent ». Cette configuration est obtenue par translation d'​adresse IP. Lorsqu'​un serveur mandataire est installé, on configure souvent le routage du réseau pour que l'​utilisateur final soit orienté vers le serveur mandataire sans avoir à modifier sa configuration. On parle alors de « proxy transparent ». Cette configuration est obtenue par translation d'​adresse IP.
  
-===Prérequis===+====Prérequis====
  
 Un serveur DNS est installé sur la passerelle.\\ ​ Un serveur DNS est installé sur la passerelle.\\ ​
Ligne 21: Ligne 24:
 ''​iptables -t nat -A POSTROUTING -o eth0 -j MASQUERADE''​ ''​iptables -t nat -A POSTROUTING -o eth0 -j MASQUERADE''​
  
-Le serveur ​squid est installé ​+=== Configuration d'​iptables (NAT) === 
-<code root>apt-get install squid3</​code>​+ 
 +  * Pour faire choses proprement on flush les tables concernées et on ajoute : 
 + 
 +<code root> 
 +iptables -t nat -F 
 +iptables -t nat -X 
 +iptables -t mangle -F 
 +iptables -t mangle -X 
 + 
 +iptables -t nat -A POSTROUTING -o eth0 -j MASQUERADE 
 + 
 +iptables -t nat -A PREROUTING -i eth1 -p tcp --dport 80 -j DNAT --to 192.168.0.1:​3129 
 + 
 +iptables -t nat -A PREROUTING -i eth0 -p tcp --dport 80 -j REDIRECT --to-port 3129 
 + 
 +iptables -t mangle -A PREROUTING -p tcp --dport 3128 -j DROP 
 +</​code>​ 
 + 
 +Voir un autre exemple : [[http://​sourcelinux.wikidot.com/​setting-up-squid-in-gateway-as-a-transparent-proxy]] 
 + 
 + 
 +<​note>​ 
 +**Ne pas oublier d'​ouvrir éventuellement le port 3128 si un pare-feu posé précédemment met à DROP les chaînes INPUT FORWARD et OUTPUT à DROP la table FILTER** 
 + 
 +**Pour mangle**, une petite citation extrait du [[http://​wiki.squid-cache.org/​ConfigExamples/​Intercept/​LinuxDnat|site officiel de squid]] : 
 + 
 +  Due to the NAT security vulnerabilities it is also a very good idea 
 +  to block external access to the internal receiving port.  
 +  This has to be done in the mangle part of iptables before DNAT happens 
 +  so that intercepted traffic does not get dropped. 
 + 
 +</​note>​ 
 + 
 +  * On conserve nos règles iptables pour le proxy 
 +<code root> 
 +iptables-save > /​etc/​iptables.squid 
 +echo "​post-up iptables-restore < /​etc/​iptables.squid"​ >> /​etc/​network/​interfaces</​code>​ 
 + 
 +===Configurer /​etc/​sysctl.conf === 
 +La première ligne est probablement déjà configurer tel que ce-dessous. Modifier aussi la seconde 
 +<​code>​ 
 +# Controls IP packet forwarding 
 +net.ipv4.ip_forward = 1 
 + 
 +# Controls source route verification  
 +net.ipv4.conf.default.rp_filter = 0 
 +</​code>​ 
 +  * Faire prendre en compte une éventuelle modification ​
 +<code root>sysctl ​-p</​code>​ 
 + 
 + 
 +====Installer le serveur squid3==== 
 <code root>​apt-get build-dep squid3</​code>​ <code root>​apt-get build-dep squid3</​code>​
 +
 +<code root>​apt-get install squid3</​code>​
  
 =====Configuration de squid comme proxy transparent===== =====Configuration de squid comme proxy transparent=====
Ligne 35: Ligne 92:
  
 ===Faire une sauvegarde du fichier de configuration === ===Faire une sauvegarde du fichier de configuration ===
-Le fichier est commenté quasiment entièrement,​ et contient tous les paramètres de lancement de Squid ainsi qu’une description ​assez complète de chacun d’eux. +Le fichier est commenté quasiment entièrement,​ et contient tous les paramètres de lancement de Squid ainsi qu’une description ​très complète de chacun d’eux. 
-  * On sauvegarde l'​original :+  ​* **On sauvegarde l'​original** : 
 +C'est très important pour la suite ! 
 <code root>cp /​etc/​squid3/​squid.conf /​etc/​squid3/​squid.conf_back</​code>​ <code root>cp /​etc/​squid3/​squid.conf /​etc/​squid3/​squid.conf_back</​code>​
  
-  * Puis pour y voir plus clair +  ​* **Puis pour y voir plus clair :** 
-On supprime toutes les lignes commentées et vide du fichier original, et on le re-crée ​afin qu'​il ​ne contienne ​que ces lignes dé-commentées par défaut.+On supprime toutes les lignes commentées et vides du fichier original, et on le recrée ​afin qu'il contienne ​uniquement les lignes ​du fichier original ​dé-commentées par défaut.
  
 <code root>​echo "`grep -v "​^#"​ /​etc/​squid3/​squid.conf | sed -e '/​^$/​d'​`"​ >/​etc/​squid3/​squid.conf</​code>​ <code root>​echo "`grep -v "​^#"​ /​etc/​squid3/​squid.conf | sed -e '/​^$/​d'​`"​ >/​etc/​squid3/​squid.conf</​code>​
  
-  * On ajoute ou modifie les lignes suivantes : +====Vérifier le proxy ==== 
-eth0 (vers internet) : 192.168.0.1\\  +===Bloquer tous le trafic du LAN === 
-eth1 (vers lan) : 192.168.1.1 +Dans un premier temps on va simplement vérifier que le proxy bloque le trafic du LAN, pour ce faire on ajoute seulement une acl pour le réseau ​de la passerelle ​192.168.0.0/​24 ​et on prévient squid qu'il sert de proxy transparent ​''​http_port 3128 transparent''​ : 
-<​code>​ +  * **On édite /​etc/​squid3/​squid.conf** 
-acl localnet src 192.168.1.0/​24 +<code root>vim /etc/squid3/squid.conf</​code>​ 
-acl lan src 192.168.0.1 192.168.1.0/​24 + 
-http_access allow localhost +  * **Ce qui donne :**
-http_access allow localnet +
-http_access allow lan +
-#Default: +
-access_log /​var/​log/​squid3/​access.log squid +
-</​code>​ +
-> ''​acl localnet src 192.168.1.0/​24''​ : le réseau ​qui doit avoir accès au serveur proxy +
->''​acl lan src 192.168.0.1 192.168.1.0/24'': Liste de contrôle : le lan seulement utilise squid +
->''​http_access allow localhost'':​ accès à squid permis au localhost +
->''​http_access allow lan'':​ idem +
->''​http_port 3128''​ : "​http_port 3128" devient "​http_port 3128 transparent"​ +
->''​access_log ​/var/log/squid3/access.log squid'' ​le fichier de log est commenté, on récupère la ligne dans le fichier sauvegardé et on l'​ajoute.+
  
-  * Ce qui donne : 
-<code user>​less /​etc/​squid3/​squid.conf</​code>​ 
 <​code>​ <​code>​
 acl manager proto cache_object acl manager proto cache_object
 acl localhost src 127.0.0.1/​32 ::1 acl localhost src 127.0.0.1/​32 ::1
 acl to_localhost dst 127.0.0.0/8 0.0.0.0/32 ::1 acl to_localhost dst 127.0.0.0/8 0.0.0.0/32 ::1
-acl localnet src 192.168.1.0/24 # RFC1918 possible internal network+acl localnet src 192.168.0.0/24 # RFC1918 possible internal network
 acl SSL_ports port 443 acl SSL_ports port 443
 acl Safe_ports port 80          # http acl Safe_ports port 80          # http
Ligne 82: Ligne 128:
 acl Safe_ports port 777         # multiling http acl Safe_ports port 777         # multiling http
 acl CONNECT method CONNECT acl CONNECT method CONNECT
-acl lan src 192.168.1.0/​24 
 http_access allow manager localhost http_access allow manager localhost
 http_access deny manager http_access deny manager
Ligne 88: Ligne 133:
 http_access deny CONNECT !SSL_ports http_access deny CONNECT !SSL_ports
 http_access allow localhost http_access allow localhost
-http_access allow localnet ​ +http_access allow localnet
-http_access allow lan+
 http_access deny all http_access deny all
 http_port 3128 transparent http_port 3128 transparent
-# Leave coredumps in the first cache dir 
 coredump_dir /​var/​spool/​squid3 coredump_dir /​var/​spool/​squid3
-#Default: 
-access_log /​var/​log/​squid3/​access.log squid 
 refresh_pattern ^ftp:           ​1440 ​   20%     10080 refresh_pattern ^ftp:           ​1440 ​   20%     10080
 refresh_pattern ^gopher: ​       1440    0%      1440 refresh_pattern ^gopher: ​       1440    0%      1440
Ligne 101: Ligne 142:
 refresh_pattern .               ​0 ​      ​20% ​    4320 refresh_pattern .               ​0 ​      ​20% ​    4320
 </​code>​ </​code>​
 +> Il est inutile d'​interdire le trafic du LAN (192.168.1.0/​24) avec une acl ''​acl localnet src 192.168.1.0/​24''​ ; ''​http_access deny localnet''​ car on a tout interdit sauf localhost (127.0.0.0/​8) et localnet.
  
-===Redémarrer squid===+  * On recharge squid3 :
 <code root>/​etc/​init.d/​squid3 restart</​code>​ <code root>/​etc/​init.d/​squid3 restart</​code>​
  
-S'il n'y a pas d'​erreur ​+  * **Si on tente de naviguer depuis le LAN :** 
-<​code>​[ ok ] Restarting Squid HTTP proxysquid.</code>+{{http://pix.toile-libre.org/upload/​img/​1414862596.png|}}
  
-====Activation du cache ====+===Autoriser le trafic pour le LAN=== 
 +  * **On ajoute une acl pour le lan et on l'​autorise !** 
 +<code root>vim /​etc/​squid3/​squid.conf</​code>​ 
 +<​code>​ 
 +<​...>​ 
 +acl lan src 192.168.1.0/​24 
 +<​...>​ 
 +http_access allow localnet 
 +</​code>​
  
-Avec squid3 ​le cache n'est pas activer.\\ ​ +  * **On recharge ​squid3 ​:** 
-Pour l'​activer,​ il va falloir aller chercher dans le fichier original ce qui concerne la mise en cache ! +<code root>/​etc/​init.d/​squid3 restart</​code>​
-En voilà un résumé ;-)+
  
-<note tip> +=====Configuration détaillée du proxy ===== 
-**__Voici la définition de quelques options de configuration basiques :__**+====Mise en place du cache pour le LAN  ==== 
 +===Créer un dossier pour le cache===
  
-**''​http_port''​** ​permet de définir le port sur lequel se lance Squid.\\ Par défaut, Squid se lance sur le port 3128. Il est également possible de définir plusieurs ports.+  ​Repérer le périphérique choisi ​: 
 +<code root>​fdisk -l</​code>​ 
 +<​code>​Périphérique Amorce ​ Début ​       Fin      Blocs     ​Id ​ Système 
 +/​dev/​sdg1 ​             63  1336206374 ​  ​668103156 ​  ​83 ​ Linux 
 +/​dev/​sdg2 ​     1336206375 ​ 3907024064 ​ 1285408845 ​  ​83 ​ Linux</​code>​
  
-  ​http_port 3128 8080+  ​* Formater le périphérique en ext3 ou reiserfs : 
 +On démonte la partition : 
 +<​code>​umount /​dev/​sdg1</​code>​
  
-**''​cache_dir''​** : permet d’indiquer où stocker les données mises en cache sur le disque.\\ Squid est conçu pour travailler en mémoire afin de charger plus rapidement les données mises en cache.\\ Toutefois, lorsque ​la mémoire est insuffisante ou que le serveur doit être stoppé, Squid va basculer les données en cache mémoire sur le disque afin de pouvoir en charger d’autres ou les recharger par la suite.\\ Pour __mettre en place cette politique de remplacement ​des données en cache__ lorsque la mémoire est insuffisante,​ (algorithme de type LRU (Least Recently Used)), il faut utiliser l’**option cache_dir** qui permet de spécifier au serveur où stocker les données de cache sur le disque et de quelle façon.\\ Le premier argument correspond à l’emplacement disque, le second à l’espace alloué (100 Méga-octets dans l’exemple ci-dessous),​ le troisième au nombre de répertoires racine, et le dernier au nombre de sous-répertoiresCette arborescence permet de constituer un index rapide d’accès.\\ Par exemple :+  ​On vérifie que la partition ne soit pas montée parallèlement par le montage automatique ​des supports amovibles : 
 +<code root>​df</​code>​ 
 +<​code>​ 
 +Sys. fich                                             1K-blocks ​  UtilDisponible Uti% Monté 
 +<...> 
 +/​dev/​sdg1 ​                                              ​657618716 ​ 202064 ​ 624011496 ​  1% /media/ 
 +<​...>​ 
 +</​code>​
  
-  ​cache_dir ufs /usr/local/squid/var/cache/ 100 16 256+  ​* Si c'est le cas comme ci-dessus (montée dans /media), on relance umount : 
 +<code root>​umount ​/dev/sdg1</code>
  
-"​Remarque ​Le type ufs de magasin:\\ +  * On désactive le montage automatique des supports amovibles ​
-"​ufs"​ est l'​ancien format de stockage Squid bien connu qui a toujours été là."+__Par exemple avec lxde__ : 
  
-**''​http_access''​**,​ **''​icp_access''​** : permettent ​de restreindre l’accès HTTP et ICP en spécifiant ​des règles de contrôle d’accès (ACls pour access control lists).\\ Chaque requête HTTP ou ICP provoque la vérification de ces règles d’accès. Cet aspect lié à la sécurité est un des points très importants dont il faut se soucier dès l’installation et la mise en route de Squid.\\ Ci-dessous les paramètres par défaut contenus dans le fichier de configuration qui restreignent l’utilisation du serveur au poste local :+-> gestionnaire ​de fichiers -> Éditer -> Préférences -> Gestion ​des volumes
  
-  * Définition d'une liste d'​accès 
  
-  acl localhost src 127.0.0.1/32+__Puis on décoche__\\  
 +  -"​Monter les volumes amovibles automatiquement lors du démarrage"​ 
 +  -"​Monter les volumes amovibles automatiquement quand ils sont insérés"​.
  
-  * Définition des droits de cette liste+  * On formate la partition : 
 +<code root>​mkfs.ext3 /​dev/​sdg1</​code>​
  
-  ​http_access allow localhost+  ​* Création d'un dossier pour le cache de squid3 :  
 +<code root>​mkdir /​data/</​code>​
  
-  * Interdiction à toutes les autres listes+<code root>​mount /dev/sdg1 /​data</​code>​
  
-  http_access deny all+<code root>​mkdir /​data/​cache/</​code>​
  
-**__Concernant la mise en cache les résolutions DNS__** ​:+  ​Mise au point des droits sur le système de répertoire /data/cache
 +<code root>​chmod -R 777 /​data/​cache/</​code>​ 
 +<code root>​chown -R proxy:proxy /​data/​cache/</​code>​
  
-**''​positive_dns_ttl''​** : permet ​de définir ​la limite supérieure au-delà de laquelle ​le serveur invalidera une résolution DNS positive mise en cache+  ​Connaître UUID de la partition pour le cache de squid3 : 
-Par défaut cette option est positionnée à 6 heures (360 minutes). Cette valeur doit être plus grande que celle de l’option negative_dns_ttl.+<code root>​blkid /​dev/​sdg1</​code>​ 
 +<​code>​UUID=3e2a6d44-5373-4e69-8c35-54f05443e78d</​code>​
  
-**''​negative_dns_ttl''​** : permet ​de définir ​la durée pendant laquelle une résolution DNS négative sera gardée en cache. La valeur minimale est de 1 seconde et il n’est pas recommandé d’aller ​au-delà de 10 secondes.+  ​Configurer le montage ​de la partition ​au démarrage du système : 
 +<code root>vim /​etc/​fstab</​code>​ 
 +On ajoute à la fin du fichier : 
 +<​code>​UUID=3e2a6d44-5373-4e69-8c35-54f05443e78d /data  none  bind,​rw,​noatime,​async 0 0</​code>​
  
-**__Concernant l'​affichage des traces de debug__ :** 
  
-**''​log_mime_hdrs''​** : permet d’afficher les en-têtes HTTP des requêtes et des réponses dans les logs d’activité.+===Paramétrage du cache dans /​etc/​squid3/​squid.conf=== 
 +Avec squid3 le cache n'est pas activer par défaut, pour mettre ​en place le cache, il faut récupérer ​les lignes commentées du fichiers ​d'​origine /​etc/​squid3/​squid.conf_back.\\ 
  
-**''​debug_options''​** : cette option permet d’afficher les différentes informations de debug de Squid. Le système de log du serveur est décomposé en sections. Il est donc possible de paramétrer le niveau de log de chacune de ces sections en fonction de ce que l’on souhaite étudier.(( Il existe ​**93** sections et 10 niveaux de debug, de __0 à 9__, 9 étant le plus précis.)) Voici une configuration qui permet d’avoir un peu plus d’informations sur les traitements réalisés par Squid en interne ((attention toutefois car les fichiers de log peuvent très vite devenir volumineux)) :+  ​* **On désactive squid3** 
 +<code root>/​etc/​init.d/squid3 stop</​code>​
  
-  ​debug_options ALL,1 17,2 55,2 56,2 57,2 58,2 +  * **On édite ​/​etc/​squid3/​squid.conf :** 
- +Pour lui ajouter ​les directives du fichier "my-squid.conf en adaptant leurs valeurs à sa configuration 
->​section ​**17** Request Forwarding __2__ +<code root>vim /etc/squid3/squid.conf</code
->section **55** HTTP Header __2__ +<​code>​acl manager proto cache_object
->section **56** HTTP Message Body  __2__ +
->section **57** HTTP Status-line ​ __2__ +
->section **58** HTTP Reply (Response) __2__ +
-</​note>​ +
-  * Il faut donc extraire ce qui nous intéresse concernant le cache du fichier de configuration ​/​etc/​squid3/​squid.conf : +
- +
->#​Default:​ +
->''#​ cache_mem 256 MB''​ +
->#​Default:​ +
->''#​ maximum_object_size_in_memory 512 KB''​ +
-># Décommentez et régler ​les éléments suivants pour ajouter un répertoire de cache disque: +
->''#​cache_dir ufs /​var/​spool/​squid3 100 16 256''​ +
->#​Default:​ +
->''#​ store_dir_select_algorithm least-load''​ +
->#       A value of 0 indicates no limit. +
->#​Default:​ +
->''#​ max_open_disk_fds 0''​ +
->#  TAG: minimum_object_size ​    ​(bytes) +
->#       ​Objects smaller than this size will NOT be saved on disk.  The +
->#       value is specified in kilobytes, and the default is 0 KB, which +
->#       means there is no minimum. +
->#​Default:​ +
->''#​ minimum_object_size 0 KB''​ +
->#​Default:​ +
->''#​ maximum_object_size 4096 KB''​ +
- +
-<note important> +
-Comparer :\\  +
--> ''#​ cache_mem 256 MB''​\\  +
--> ''#​cache_dir ufs /var/spool/​squid3 ​100 16 256''​\\  +
- +
-=> La définition de la mémoire cache (256 MB) serait plus large que l'​espace disque défini (100MB) !\\ +
- +
-Donc attention en dé-commentant ! +
- +
-  df -h /var +
-  Sysfich.              Taille Util. Dispo Uti% Monté sur +
-  /​dev/​mapper/​systeme-var ​  ​2,​8G ​ 1,0G  1,7G  39% /var +
- +
-</note> +
-  * Ce qui donne : +
-<​code>​ +
-acl manager proto cache_object+
 acl localhost src 127.0.0.1/​32 ::1 acl localhost src 127.0.0.1/​32 ::1
 acl to_localhost dst 127.0.0.0/8 0.0.0.0/32 ::1 acl to_localhost dst 127.0.0.0/8 0.0.0.0/32 ::1
-acl localnet ​src 192.168.1.0/​24 ​# RFC1918 possible internal network+acl lan src 192.168.1.0/​24
 acl SSL_ports port 443 acl SSL_ports port 443
 acl Safe_ports port 80          # http acl Safe_ports port 80          # http
Ligne 217: Ligne 248:
 acl Safe_ports port 777         # multiling http acl Safe_ports port 777         # multiling http
 acl CONNECT method CONNECT acl CONNECT method CONNECT
-acl lan src 192.168.0.1 192.168.1.0/​24 
 http_access allow manager localhost http_access allow manager localhost
 http_access deny manager http_access deny manager
Ligne 223: Ligne 253:
 http_access deny CONNECT !SSL_ports http_access deny CONNECT !SSL_ports
 http_access allow localhost http_access allow localhost
-http_access allow localnet ​ 
 http_access allow lan http_access allow lan
 http_access deny all http_access deny all
 +
 +icp_access allow localhost
 +icp_access deny all
 +
 http_port 3128 transparent http_port 3128 transparent
  
-#Default: +cache_mem 256 MB 
-#cache_mem 256 MB +minimum_object_size ​KB 
-cache_mem 100 MB +maximum_object_size ​6 MB
-#Default: +
-maximum_object_size_in_memory 512 KB +
-# Décommentez et régler les éléments suivants pour ajouter un répertoire de cach +
-e disque: +
-cache_dir ufs /​var/​spool/​squid3 100 16 256 +
-#Default: +
-store_dir_select_algorithm least-load +
-# A value of 0 indicates no limit. +
-#Default: +
-max_open_disk_fds 0 +
-# TAG: minimum_object_size ​(bytes) +
-# Objects smaller than this size will NOT be saved on disk. The +
-# value is specified in kilobytes, and the default is 0 KB, which +
-# means there is no minimum. +
-#Default: +
-minimum_object_size 0 KB +
-#Default: +
-maximum_object_size ​4096 KB+
  
 +ipcache_size 10240
 +fqdncache_size 10240
 +
 +memory_replacement_policy heap GDSF
 +cache_replacement_policy heap LFUDA
 +
 +cache_dir aufs /data/cache 20000 14 256
 +
 +cache_swap_low 95
 +cache_swap_high 99
 +
 +cache_effective_user proxy
 +cache_effective_group proxy
  
-# Leave coredumps in the first cache dir 
-coredump_dir /​var/​spool/​squid3 
-#Default: 
 access_log /​var/​log/​squid3/​access.log squid access_log /​var/​log/​squid3/​access.log squid
 +#cache_log /​var/​log/​squid3/​cache.log
 +#​cache_store_log /​var/​log/​squid3/​store.log
 +
 +coredump_dir /​var/​spool/​squid3
 +
 +cache allow lan
 +
 refresh_pattern ^ftp:           ​1440 ​   20%     10080 refresh_pattern ^ftp:           ​1440 ​   20%     10080
 refresh_pattern ^gopher: ​       1440    0%      1440 refresh_pattern ^gopher: ​       1440    0%      1440
 refresh_pattern -i (/​cgi-bin/​|\?​) 0     ​0% ​     0 refresh_pattern -i (/​cgi-bin/​|\?​) 0     ​0% ​     0
 refresh_pattern .               ​0 ​      ​20% ​    4320 refresh_pattern .               ​0 ​      ​20% ​    4320
 +
 +visible_hostname routeur-debian
 +
 +dns_timeout 10 seconds
 +dns_nameservers 192.168.0.1 212.27.40.240 212.27.40.241
 </​code>​ </​code>​
  
-  * Et quand on relance squid3 +<note tip
-<code root>/​etc/​init.d/​squid3 start</​code+**__Voici la définition de quelques options de configuration ​basiques ​:__**
-<​code>​ +
-2014/10/17 09:28:42| Creating Swap Directories +
-2014/10/17 09:28:42| /​var/​spool/​squid3 exists +
-2014/10/17 09:28:42| Making directories in /​var/​spool/​squid3/​00 +
-2014/10/17 09:28:42| Making directories in /​var/​spool/​squid3/​01 +
-2014/10/17 09:28:42| Making directories in /​var/​spool/​squid3/​02 +
-2014/10/17 09:28:42| Making directories in /​var/​spool/​squid3/​03 +
-2014/10/17 09:28:42| Making directories in /​var/​spool/​squid3/​04 +
-2014/10/17 09:28:42| Making directories in /​var/​spool/​squid3/​05 +
-2014/10/17 09:28:42| Making directories in /​var/​spool/​squid3/​06 +
-2014/10/17 09:28:42| Making directories in /​var/​spool/​squid3/​07 +
-2014/10/17 09:28:42| Making directories in /​var/​spool/​squid3/​08 +
-2014/10/17 09:28:42| Making directories in /​var/​spool/​squid3/​09 +
-2014/10/17 09:28:42| Making directories in /​var/​spool/​squid3/​0A +
-2014/10/17 09:28:42| Making directories in /​var/​spool/​squid3/​0B +
-2014/10/17 09:28:42| Making directories in /​var/​spool/​squid3/​0C +
-2014/10/17 09:28:42| Making directories in /​var/​spool/​squid3/​0D +
-2014/10/17 09:28:42| Making directories in /​var/​spool/​squid3/​0E +
-2014/10/17 09:28:43| Making directories in /​var/​spool/​squid3/​0F +
-. ok </​code>​ +
-===== configuration ​d'​iptables (NAT) ===== +
-Nous n'​avons pour l'​instant que l'IP masquerade mis en place :+
  
 +**''​cache_mem''​** : Il s'agit de la taille de la mémoire RAM et la valeur choisie doit être adaptée à son matérielle.\\ Plus squid est configuré avec un stockage disque important via la directive cache_dir plus il aura besoin de mémoire pour en ordonné l’utilisation. Mais en outre plus vous allouez d’espace de mémoire pour squid via la directive cache_mem plus squid aura besoin de mémoire vive, en dehors du quota alloué par cette directive, pour ordonner la aussi les objets stocker dans ce cache.\\ Pour connaître la taille et le détaille de l'​utilisation de la RAM : **''​free -m''​**\\ ​
  
-  * Il faut ajouter : 
  
-<code root> +**''​cache_dir''​** : permet d’indiquer où stocker les données mises en cache sur le disque.\\ Squid est conçu pour travailler en mémoire afin de charger plus rapidement les données mises en cache.\\ Toutefois, lorsque la mémoire est insuffisante ou que le serveur doit être stoppé, Squid va basculer les données en cache mémoire sur le disque afin de pouvoir en charger d’autres ou les recharger par la suite.\\ Pour __mettre en place cette politique de remplacement des données en cache__ lorsque la mémoire est insuffisante,​ (algorithme de type LRU (Least Recently Used)), il faut utiliser l’**option cache_dir** qui permet de spécifier au serveur où stocker les données de cache sur le disque et de quelle façon.\\ Le premier argument correspond à l’emplacement disque, le second à l’espace alloué (100 Méga-octets dans l’exemple ci-dessous), le troisième au nombre de répertoires racine, et le dernier au nombre de sous-répertoiresCette arborescence permet de constituer un index rapide d’accès.\\ Par défaut :
-iptables -t nat -A PREROUTING -s 192.168.0.1 -p tcp --dport 80 -j ACCEPT +
-iptables -t nat -A PREROUTING -p tcp --dport 80 -j DNAT\ +
- ​--to-destination 192.168.0.1:​3128 +
-iptables -t mangle -A PREROUTING -p tcp --dport 3128 -j DROP +
-iptables -t nat -A PREROUTING -i eth1 -s 192.168.1.0/​24\ +
- -p tcp --dport 80 -j REDIRECT --to-port 3128 +
-iptables -t nat -I PREROUTING 1 -i eth1 -s 192.168.1.0/24\ +
- -p tcp -m tcp --dport 80 -J ACCEPT +
-</​code>​+
  
-  ​* Ce qui donne : +  ​cache_dir ufs /usr/​local/​squid/​var/​cache/​ 100 16 256
-<code root>​iptables -L -t nat</code>+
  
-<​code>​Chain PREROUTING (policy ACCEPT) +"​Remarque ​Le type ufs de magasin:\\ 
-target ​    prot opt source ​     destination ​         +"​ufs"​ est l'​ancien format de stockage Squid bien connu qui a toujours été là."
-DNAT       ​tcp ​ --  anywhere ​   anywhere ​     tcp dpt:http to:192.168.1.1:​3128 +
-REDIRECT ​  ​tcp ​ --  anywhere ​   anywhere ​     tcp dpt:http redir ports 3128+
  
-Chain INPUT (policy ACCEPT+**''​http_access''​**,​ **''​icp_access''​** : permettent de restreindre l’accès HTTP et ICP en spécifiant des règles de contrôle d’accès ​(ACls pour access control lists).\\ Chaque requête HTTP ou ICP provoque la vérification de ces règles d’accès. Cet aspect lié à la sécurité est un des points très importants dont il faut se soucier dès l’installation et la mise en route de Squid.\\ Ci-dessous les paramètres par défaut contenus dans le fichier de configuration qui restreignent l’utilisation du serveur au poste local : 
-target ​    prot opt source ​     destination ​        + 
 +</​note>​ 
 + 
 +  * On crée le cache : 
 +<code root>​squid3 -z</​code>​ 
 +<​code>​2014/​11/​04 12:56:33| Creating Swap Directories 
 +2014/11/04 12:56:33| /data/cache exists 
 +2014/11/04 12:56:33| Making directories in /​data/​cache/​00 
 +2014/11/04 12:56:33| Making directories in /​data/​cache/​01 
 +2014/11/04 12:56:33| Making directories in /​data/​cache/​02 
 +2014/11/04 12:56:33| Making directories in /​data/​cache/​03 
 +2014/11/04 12:56:33| Making directories in /​data/​cache/​04 
 +2014/11/04 12:56:33| Making directories in /​data/​cache/​05 
 +2014/11/04 12:56:33| Making directories in /​data/​cache/​06 
 +2014/11/04 12:56:33| Making directories in /​data/​cache/​07 
 +2014/11/04 12:56:33| Making directories in /​data/​cache/​08 
 +2014/11/04 12:56:33| Making directories in /​data/​cache/​09 
 +2014/11/04 12:56:33| Making directories in /​data/​cache/​0A 
 +2014/11/04 12:56:33| Making directories in /​data/​cache/​0B 
 +2014/11/04 12:56:33| Making directories in /​data/​cache/​0C 
 +2014/11/04 12:56:33| Making directories in /​data/​cache/​0D</​code>​ 
 + 
 +<​note>​ 
 +Si pour une raison ou pour une autre, il y a besoin de ré-initialiser le cache, par exemple si la taille de mémoire cache ne convient pas, ne pas hésiter à supprimer ces fichiers manuellement,​ ou tout simplement si on veut le vider complètement :\\  
 +  * Il faut arrêter squid : 
 +<code root>/​etc/​init.d/​squid3 stop</​code>​ 
 + 
 +  * On se déplace dans le répertoire du cache : 
 +(S'il vous plaît servez-vous de l'​auto-complétion,​ surtout ici) 
 +<code root>cd /​data/​cache/</​code>​ 
 + 
 +  * On supprime tous les dossiers  
 + 
 +<code root>rm -rv 0*</​code>​ 
 + 
 +  * On supprime les fichiers 
 +<code root>rm -v swap.state*</​code>​ 
 + 
 +  * On relance squid3 : 
 +<code root>/​etc/​init.d/​squid3 restart</​code>​ 
 +</​note>​
  
-Chain OUTPUT (policy ACCEPT) 
-target ​    prot opt source ​     destination ​         
  
-Chain POSTROUTING (policy ACCEPT) 
-target ​    prot opt source ​     destination ​         
-MASQUERADE ​ all  --  anywhere ​  ​anywhere</​code>​ 
  
-===Configurer /​etc/​sysctl.conf === 
-  * Vérifier que les lignes suivantes comportes ces valeurs : 
  
-<​code>​ 
-# Controls IP packet forwarding 
-net.ipv4.ip_forward = 1 
  
-# Controls source route verification 
-net.ipv4.conf.default.rp_filter = 0 
-</​code>​ 
-  * Faire rendre en compte une éventuelle modification : 
-<code root>​sysctl -p</​code>​ 
  
 =====Vérifications==== =====Vérifications====
-====Passage ​par le proxy ==== +Dans le fichier de configuration /​etc/​squid3/​squid.conf :\\ 
-Vérifie si le sous-réseau qui passe est connecté au web par le passerelle, passe bien par le proxy. + 
-===Générer du flux === +  * les dossiers du cache : /​var/​spool/​squid3 
-Tout bêtement, de côté du lan, on navigue en observant le fichier des logs d'​accès : +  * le fichier de log d'​accès : /​var/​log/​squid3/​access.log 
-  * Le fichier /​var/​log/​squid3/​access.log +  * cache_store_log:​ /​var/​log/​squid3/​store.log\\ Enregistre les activités du gestionnaire de stockage. Cela montre quels les objets sont éjectés de la mémoire cache, et où les objets sont enregistrés et pour combien de temps. Pour désactiver,​ entrez "​none"​ ou supprimer la ligne. Vous pouvez désactiver en toute sécurité. 
-Par exemple ​:+  * mime_table (pour utiliser FTP) : /​usr/​share/​squid3/​mime.conf 
 +  * cache_log /​var/​log/​squid3/​cache.log 
 + 
 + 
 +====Vérifier le passage ​par le proxy ==== 
 +Pour vérifier que le sous-réseau qui est connecté au web via la passerelle, passe bien de même par le proxy.\\  
 +Il faut : 
 +  * Générer du flux depuis le sous-réseau 
 +Tout bêtement, de côté du lan, on navigue ​
 + 
 +  * Tout en observant ​côté passerelle (i.e. serveur squid)  
 +le fichier /​var/​log/​squid3/​access.log ​des logs d'​accès ​: 
 <code root> <code root>
 tail -f /​var/​log/​squid3/​access.log tail -f /​var/​log/​squid3/​access.log
Ligne 352: Ligne 392:
 </​code>​ </​code>​
  
 +====Vérifier le cache ====
 +Ci-dessus, nous avons observé que les connexions passaient par le proxy.\\ ​
 +
 +Pour vérifier que squid sert au client une page de son cache, il faut visiter le même URL plusieurs fois. 
 +La 1ère fois on a normalement dans /​var/​log/​squid3/​access.log,​ ''​TCP_MISS'',​ mais après on doit obtenir ''​TCP_HIT''​.
 +  * TCP_MISS : L'​objet demandé n'est pas dans le cache.
 +  * TCP_HIT : Une copie valide de l'​objet demandé était dans le cache.
 +
 +On peut trouver d'​autres indications :
 +  * TCP_REFRESH_HIT :   ​L'​objet demandé a été mis en cache mais obsolète (ICM -> 304). 
 +  * TCP_REF_FAIL_HIT : L'​objet demandé a été mis en cache mais il obsolète ; la requête IMS a échoué mais l'​objet a été livré.
 +  * TCP_REFRESH_MISS : L'​objet demandé a été mis en cache mais était obsolète. La requête IMS retourné le nouveau contenu.
 +  * TCP_CLIENT_REFRESH_MISS : Le client a émis une certaine demande de cache en même temps que la demande. ​ Ainsi, le cache doit extraire à nouveau l'​objet.
 +  * TCP_IMS_HIT : Le client a émis une demande IMS pour un objet qui est nouvellement dans le cache.
 +  * TCP_NEGATIVE_HIT :Demande d'un objet mis en cache négative, par exemple "404 Not Found"
 +  * TCP_MEM_HIT : Une copie valide de l'​objet demandé a été mis dans la mémoire du cache, évitant ainsi les accès disque.
 +  * TCP_DENIED : Accès a été refusé pour cette demande.
 +  * TCP_OFFLINE_HIT : L'​objet demandé a été récupéré à partir du cache en mode déconnecté. Voir "​offline_mode"​ dans le fichier squid.conf.
 +
 +Se connecter plusieurs fois et tenter la commande :
 +
 +  *Il faut un certain temps pour obtenir des HIT
 +
 +<code root>/​var/​log/​squid3/​access.log | grep  TCP_HIT</​code>​
 +<​code></​code>​
 <note tip> <note tip>
 **__Détail sur  /​var/​log/​squid3/​access.log__ :**\\  **__Détail sur  /​var/​log/​squid3/​access.log__ :**\\ 
Ligne 381: Ligne 446:
 </​note>​ </​note>​
  
-  * Voir le fichier /​var/​log/​squid3/​cache.log+===Voir le fichier /​var/​log/​squid3/​cache.log=== 
 On trouve dans ce fichier beaucoup d’informations allant du nombre de descripteurs de fichiers ouverts jusqu’à la mémoire allouée. Il est possible de se référer à la documentation officielle pour obtenir plus de détails sur ce fichier.\\ ​ On trouve dans ce fichier beaucoup d’informations allant du nombre de descripteurs de fichiers ouverts jusqu’à la mémoire allouée. Il est possible de se référer à la documentation officielle pour obtenir plus de détails sur ce fichier.\\ ​
-Par exemple ci-dessous les DNS enregistrés :+ 
 +  * Par exemple ci-dessous les DNS enregistrés : 
 +<code root>​less /​var/​log/​squid3/​cache.log</​code>​
 <​code>​2014/​10/​16 13:11:45| Process ID 3735 <​code>​2014/​10/​16 13:11:45| Process ID 3735
 2014/10/16 13:11:45| With 65535 file descriptors available 2014/10/16 13:11:45| With 65535 file descriptors available
Ligne 397: Ligne 465:
 2014/10/16 13:11:45| Unlinkd pipe opened on FD 13<​...></​code>​ 2014/10/16 13:11:45| Unlinkd pipe opened on FD 13<​...></​code>​
  
-====Les pages web visitées et le cache==== +===Consulter /​var/​log/​squid3/​store.log ​=== 
 +<code root>​less /​var/​log/​squid3/​store.log</​code>​
  
-===== Utilisation ===== 
  
  

Pied de page des forums

Propulsé par FluxBB