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 [01/11/2014 18:37]
Hypathie [Configuration de squid comme proxy transparent]
utilisateurs:hypathie:tutos:proxy-transparent [05/11/2014 15:37]
martinux_qc [Introduction]
Ligne 26: Ligne 26:
 === Configuration d'​iptables (NAT) === === Configuration d'​iptables (NAT) ===
  
-  * Pour faire choses proprement on flush les tables concernées et on ajoute :+  * Pour faire les choses proprement on flush les tables concernées et on ajoute :
  
 <code root> <code root>
Ligne 36: Ligne 36:
 iptables -t nat -A POSTROUTING -o eth0 -j MASQUERADE 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:​3128+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 nat -A PREROUTING -i eth0 -p tcp --dport 80 -j REDIRECT --to-port ​3128+
  
 iptables -t mangle -A PREROUTING -p tcp --dport 3128 -j DROP iptables -t mangle -A PREROUTING -p tcp --dport 3128 -j DROP
 +
 +
 +iptables -t mangle -A PREROUTING -p tcp --dport 3129 -j DROP
 </​code>​ </​code>​
  
Ligne 48: Ligne 50:
  
 <​note>​ <​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**+**Port 3128 et 3129 car j'​utiliserai les deux ports.**
  
 **Pour mangle**, une petite citation extrait du [[http://​wiki.squid-cache.org/​ConfigExamples/​Intercept/​LinuxDnat|site officiel de squid]] : **Pour mangle**, une petite citation extrait du [[http://​wiki.squid-cache.org/​ConfigExamples/​Intercept/​LinuxDnat|site officiel de squid]] :
Ligne 59: Ligne 61:
 </​note>​ </​note>​
  
-  * On conserve nos règles iptables pour le proxy+===On conserve nos règles iptables pour le proxy=== 
 + 
 +  * Méthode 1 : on sauvegarde les règles iptables et on les restaure avec /​etc/​network/​interfaces
 <code root> <code root>
 iptables-save > /​etc/​iptables.squid iptables-save > /​etc/​iptables.squid
 echo "​post-up iptables-restore < /​etc/​iptables.squid"​ >> /​etc/​network/​interfaces</​code>​ echo "​post-up iptables-restore < /​etc/​iptables.squid"​ >> /​etc/​network/​interfaces</​code>​
 +
 +  * Méthode 2 : on utilise le script /​etc/​rc.local
 +<code root>vim /​etc/​rc.local</​code>​
 +<​code>/​sbin/​iptables -t nat -F
 +
 +/​sbin/​iptables -t nat -X
 +
 +/​sbin/​iptables -t mangle -F
 +
 +/​sbin/​iptables -t mangle -X
 +
 +/​sbin/​iptables -t nat -A POSTROUTING -o eth0 -j MASQUERADE
 +
 +/​sbin/​iptables -t nat -A PREROUTING -i eth1 -p tcp --dport 80 -j DNAT --to 192.168.0.1:​3129
 +
 +/​sbin/​iptables -t nat -A PREROUTING -i eth0 -p tcp --dport 80 -j REDIRECT --to-port 3129
 +
 +/​sbin/​iptables -t mangle -A PREROUTING -p tcp --dport 3128 -j DROP
 +
 +/​sbin/​iptables -t mangle -A PREROUTING -p tcp --dport 3129 -j DROP
 +
 +/sbin/route add -net 192.168.0.0 netmask 255.255.255.0 gw 192.168.0.1 dev eth0
 +
 +/sbin/route add -net 192.168.1.0 netmask 255.255.255.0 gw 192.168.1.1 dev eth1
 +
 +exit 0</​code>​
 +
 +Pour activer le script :
 +<code root>
 +/sbin/route add -net 192.168.1.0 netmask 255.255.255.0 gw 192.168.1.1 dev eth1</​code>​
 +
 +
 +
 +  * Côté client l'​adresse IP du proxy squid3 comme route par défaut :
 +<code root>​route add -net 192.168.1.0 netmask 255.255.255.0 gw 192.168.1.1 dev eth0
 +</​code>​
  
 ===Configurer /​etc/​sysctl.conf === ===Configurer /​etc/​sysctl.conf ===
-La première ligne est probablement déjà ​configurer ​tel que ce-dessous. Modifier aussi la seconde+La première ligne est probablement déjà ​configurée ​tel que ci-dessous. Modifier aussi la seconde
 <​code>​ <​code>​
 # Controls IP packet forwarding # Controls IP packet forwarding
Ligne 73: Ligne 113:
 net.ipv4.conf.default.rp_filter = 0 net.ipv4.conf.default.rp_filter = 0
 </​code>​ </​code>​
-  * Faire rendre ​en compte une éventuelle modification :+  * Faire prendre ​en compte une éventuelle modification :
 <code root>​sysctl -p</​code>​ <code root>​sysctl -p</​code>​
  
Ligne 99: Ligne 139:
 <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 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. 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>​
  
-===Vérifier le proxy === +====Vérifier le proxy ==== 
-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''​ : +===Bloquer tous le trafic du LAN === 
-  * On édite /​etc/​squid3/​squid.conf+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 ​3129 transparent''​ : 
 +  ​* **On édite /​etc/​squid3/​squid.conf**
 <code root>vim /​etc/​squid3/​squid.conf</​code>​ <code root>vim /​etc/​squid3/​squid.conf</​code>​
  
-  * Ce qui donne :+  ​* **Ce qui donne :**
  
 <​code>​ <​code>​
Ligne 135: Ligne 176:
 http_access allow localnet http_access allow localnet
 http_access deny all http_access deny all
-http_port ​3128 transparent+http_port ​3129 transparent
 coredump_dir /​var/​spool/​squid3 coredump_dir /​var/​spool/​squid3
 refresh_pattern ^ftp:           ​1440 ​   20%     10080 refresh_pattern ^ftp:           ​1440 ​   20%     10080
Ligne 144: Ligne 185:
 > 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. > 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.
  
 +  * On recharge squid3 :
 +<code root>/​etc/​init.d/​squid3 restart</​code>​
  
-  * Si on tente de naviguer depuis le LAN :+  ​* **Si on tente de naviguer depuis le LAN :**
 {{http://​pix.toile-libre.org/​upload/​img/​1414862596.png|}} {{http://​pix.toile-libre.org/​upload/​img/​1414862596.png|}}
  
-====Configuration détaillée du proxy ====+===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>​
  
-===Mise en place du cache pour le LAN ===+  * **On recharge squid3 :** 
 +<code root>/​etc/​init.d/​squid3 restart</​code>​
  
->''​acl lan src 192.168.0.1 192.168.1.0/​24'':​ Liste de contrôle : le lan seulement utilise squid+=====Configuration détaillée du proxy ===== 
 +====Mise en place du cache pour le LAN  ==== 
 +===Créer un dossier pour le cache===
  
->''​access_log ​/var/log/squid3/access.log squid''​ : On récupère cette ligne dans le fichier ​/etc/squid3/​squid.conf-bak (copie de l'​original) et on l'​ajoute au fichier /​etc/​squid3/​squid.conf+  * 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>
  
 +  * Formater le périphérique en ext3 ou reiserfs :
 +On démonte la partition :
 +<​code>​umount /​dev/​sdg1</​code>​
  
-  * Ce qui donne +  * On vérifie que la partition ne soit pas montée parallèlement par le montage automatique des supports amovibles ​
-<​code ​user>less /​etc/​squid3/​squid.conf</​code>​+<​code ​root>df</​code>​
 <​code>​ <​code>​
-acl manager proto cache_object+Sys. fich.                                              1K-blocks ​  Util. Disponible Uti% Monté 
 +<​...>​ 
 +/​dev/​sdg1 ​                                              ​657618716 ​ 202064 ​ 624011496 ​  1% /media/ 
 +<​...>​ 
 +</​code>​ 
 + 
 +  * Si c'est le cas comme ci-dessus (montée dans /media), on relance umount : 
 +<code root>​umount /​dev/​sdg1</​code>​ 
 + 
 +  * On désactive le montage automatique des supports amovibles : 
 +__Par exemple avec lxde__ :  
 + 
 +-> gestionnaire de fichiers -> Éditer -> Préférences -> Gestion des volumes 
 + 
 + 
 +__Puis on décoche__\\  
 +  -"​Monter les volumes amovibles automatiquement lors du démarrage"​ 
 +  -"​Monter les volumes amovibles automatiquement quand ils sont insérés"​. 
 + 
 +  * On formate la partition : 
 +<code root>​mkfs.ext3 /​dev/​sdg1</​code>​ 
 + 
 +  * Création d'un dossier pour le cache de squid3 :  
 +<code root>​mkdir /​data/</​code>​ 
 + 
 +<code root>​mount /dev/sdg1 /​data</​code>​ 
 + 
 +<code root>​mkdir /​data/​cache/</​code>​ 
 + 
 +  * 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>​ 
 + 
 +  * Connaître UUID de la partition pour le cache de squid3 : 
 +<code root>​blkid /​dev/​sdg1</​code>​ 
 +<​code>​UUID=3e2a6d44-5373-4e69-8c35-54f05443e78d</​code>​ 
 + 
 +  * 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  rw,​noatime,​async 0 2</​code>​ 
 + 
 +<​note>​Ne pas oublier de modifier l'​ordre d'​amorçage du BIOS, si "​usb"​ est positionnée avant le disque dur, pour qu'​elle soit positionnée après celui.</​note>​ 
 +===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.\\  
 + 
 +  * **On désactive squid3** 
 +<code root>/​etc/​init.d/​squid3 stop</​code>​ 
 + 
 +  * **On édite /​etc/​squid3/​squid.conf :** 
 +Pour lui ajouter les directives du fichier "​my-squid.conf en adaptant leurs valeurs à sa configuration 
 +<code root>vim /​etc/​squid3/​squid.conf</​code>​ 
 +<​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.0.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 176: Ligne 289:
 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 182: Ligne 294:
 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
-http_port 3128 transparent 
  
-#​hierarchy_stoplist cgi-bin ?+icp_access allow localhost 
 +icp_access deny all 
 +http_port 3128 
 +http_port 3129 transparent
  
-cache allow LocalNet +cache_mem 256 MB 
-#cache deny QUERY+minimum_object_size 3 KB 
 +maximum_object_size 6 MB
  
-# MEMORY CACHE OPTIONS +ipcache_size 10240 
-#Default: +fqdncache_size 10240
-#cache_mem 256 MB +
-cache_mem 8 MB +
-#Default: +
-maximum_object_size_in_memory 256 KB +
-#​memory_replacement_policy lru +
-# DISK CACHE OPTIONS +
-# 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: +memory_replacement_policy heap GDSF 
-#​store_dir_select_algorithm least-load+cache_replacement_policy heap LFUDA
  
-# A value of 0 indicates no limit. +cache_dir aufs /data/cache 20000 14 256 
-#Default: + 
-max_open_disk_fds 0 +cache_swap_low 95 
-# TAG: minimum_object_size (bytes) +cache_swap_high 99 
-# Objects smaller than this size will NOT be saved on disk. The + 
-# value is specified in kilobytes, and the default is 0 KB, which +cache_effective_user proxy 
-# means there is no minimum. +cache_effective_group proxy
-#Default: +
-minimum_object_size 0 KB +
-#Default: +
-maximum_object_size 10 KB+
  
-# LOG_FILE OPTIONS 
-#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
  
-#Default: +coredump_dir ​/var/spool/squid3
-cache_log ​/var/log/squid3/cache.log+
  
-# Leave coredumps in the first cache dir +cache allow lan
-#​coredump_dir /​var/​spool/​squid3+
  
-# OPTIONS FOR TUNING THE CACHE 
-cache allow all 
 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 235: Ligne 333:
 refresh_pattern .               ​0 ​      ​20% ​    4320 refresh_pattern .               ​0 ​      ​20% ​    4320
  
 +dns_timeout 10 seconds
 +dns_nameservers 192.168.0.1 212.27.40.240 212.27.40.241
 +
 +visible_hostname routeur-debian
 hosts_file /etc/hosts hosts_file /etc/hosts
 </​code>​ </​code>​
- 
-===Activation du cache === 
- 
-Avec squid3 le cache n'est pas activer.\\ ​ 
-Pour l'​activer,​ il va falloir aller chercher dans le fichier original ce qui concerne la mise en cache ! 
-En voilà un résumé ;-) 
  
 <note tip> <note tip>
 **__Voici la définition de quelques options de configuration basiques :__** **__Voici la définition de quelques options de configuration basiques :__**
  
-**''​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.+**''​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’utilisationMais 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''​**\\ ​
  
-  http_port 3128 8080 
  
-**''​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épertoires. Cette arborescence permet de constituer un index rapide d’accès.\\ Par exemple ​:+**''​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épertoires. Cette arborescence permet de constituer un index rapide d’accès.\\ Par défaut ​:
  
   cache_dir ufs /​usr/​local/​squid/​var/​cache/​ 100 16 256   cache_dir ufs /​usr/​local/​squid/​var/​cache/​ 100 16 256
Ligne 260: Ligne 355:
 **''​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 : **''​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 :
  
-  * Définition d'une liste d'​accès 
- 
-  acl localhost src 127.0.0.1/​32 
- 
-  * Définition des droits de cette liste 
- 
-  http_access allow localhost 
- 
-  * Interdiction à toutes les autres listes 
- 
-  http_access deny all 
- 
-**__Concernant la mise en cache les résolutions DNS__** : 
- 
-**''​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. 
-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. 
- 
-**''​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. 
- 
-**__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é. 
- 
-**''​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)) : 
- 
-  debug_options ALL,1 17,2 55,2 56,2 57,2 58,2 
- 
->section **17** Request Forwarding __2__ 
->section **55** HTTP Header __2__ 
->section **56** HTTP Message Body  __2__ 
->section **57** HTTP Status-line ​ __2__ 
->section **58** HTTP Reply (Response) __2__ 
 </​note>​ </​note>​
-  * Il faut donc extraire ce qui nous intéresse concernant le cache du fichier de configuration /​etc/​squid3/​squid.conf : 
  
->#​Default:​ +  * On crée le cache : 
->''#​ cache_mem 256 MB''​ +<code root>​squid3 ​-z</​code>​ 
->#​Default:​ +<​code>​2014/​11/04 12:56:33| Creating Swap Directories 
->''#​ maximum_object_size_in_memory 512 KB''​ +2014/11/04 12:56:33| /data/cache exists 
-># Décommentez et régler les éléments suivants pour ajouter un répertoire de cache disque: +2014/11/04 12:56:33| Making directories in /data/cache/00 
->''#​cache_dir ufs /​var/​spool/​squid3 100 16 256''​ +2014/11/04 12:56:33| Making directories in /data/cache/01 
->#​Default:​ +2014/11/04 12:56:33| Making directories in /data/cache/02 
->''#​ store_dir_select_algorithm least-load''​ +2014/11/04 12:56:33| Making directories in /data/cache/03 
->#       A value of 0 indicates no limit. +2014/11/04 12:56:33| Making directories in /data/cache/04 
->#​Default:​ +2014/11/04 12:56:33| Making directories in /data/cache/05 
->''#​ max_open_disk_fds 0''​ +2014/11/04 12:56:33| Making directories in /data/cache/06 
->#  TAG: minimum_object_size ​    ​(bytes) +2014/11/04 12:56:33| Making directories in /data/cache/07 
->#       ​Objects smaller than this size will NOT be saved on disk.  The +2014/11/04 12:56:33| Making directories in /data/cache/08 
->#       value is specified in kilobytes, and the default is 0 KB, which +2014/11/04 12:56:33| Making directories in /data/cache/09 
->#       means there is no minimum. +2014/11/04 12:56:33| Making directories in /data/cache/0A 
->#​Default:​ +2014/11/04 12:56:33| Making directories in /data/cache/0B 
->''#​ minimum_object_size 0 KB''​ +2014/11/04 12:56:33| Making directories in /data/cache/0C 
->#​Default:​ +2014/11/04 12:56:33| Making directories in /data/cache/​0D</​code>​
->''#​ maximum_object_size 4096 KB''​ +
->''​cache''​ : pour déterminer l'​utilisation du cache\\ ''​cache allow LocalNet''​ ; elle doit remplacer ''​no_cache''​ +
- +
-<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 +
-  Sys. fich.              Taille Util. Dispo Uti% Monté sur +
-  /​dev/​mapper/​systeme-var ​  ​2,8G  1,0G  1,7G  39% /var +
- +
-</​note>​ +
- +
-  ​Grâce à la ligne suivant les fichiers du cache sont créés +
->''​cache_dir ufs /​var/​spool/​squid3 100 16 256''​ +
- +
-Et quand on re-démarre squid3 ​: +
- +
-<code root>/​etc/​init.d/​squid3 ​restart</​code>​ +
-<​code>​2014/​10/17 16:29:49| Creating Swap Directories +
-2014/10/17 16:29:49| /var/spool/​squid3 ​exists +
-2014/10/17 16:29:49| Making directories in /var/spool/​squid3/00 +
-2014/10/17 16:29:49| Making directories in /var/spool/​squid3/01 +
-2014/10/17 16:29:49| Making directories in /var/spool/​squid3/02 +
-2014/10/17 16:29:49| Making directories in /var/spool/​squid3/03 +
-2014/10/17 16:29:49| Making directories in /var/spool/​squid3/04 +
-2014/10/17 16:29:49| Making directories in /var/spool/​squid3/05 +
-2014/10/17 16:29:49| Making directories in /var/spool/​squid3/06 +
-2014/10/17 16:29:49| Making directories in /var/spool/​squid3/07 +
-2014/10/17 16:29:49| Making directories in /var/spool/​squid3/08 +
-2014/10/17 16:29:49| Making directories in /var/spool/​squid3/09 +
-2014/10/17 16:29:49| Making directories in /var/spool/​squid3/0A +
-2014/10/17 16:29:49| Making directories in /var/spool/​squid3/0B +
-2014/10/17 16:29:49| Making directories in /var/spool/​squid3/0C +
-2014/10/17 16:29:49| Making directories in /var/spool/​squid3/0D +
-2014/10/17 16:29:49| Making directories in /​var/​spool/​squid3/​0E +
-2014/10/17 16:29:50| Making directories in /​var/​spool/​squid3/​0F +
-. ok </​code>​+
  
 <​note>​ <​note>​
Ligne 364: Ligne 383:
   * On se déplace dans le répertoire du cache :   * On se déplace dans le répertoire du cache :
 (S'il vous plaît servez-vous de l'​auto-complétion,​ surtout ici) (S'il vous plaît servez-vous de l'​auto-complétion,​ surtout ici)
-<code root>cd /var/spool/​squid3/</​code>​+<code root>cd /data/cache/</​code>​
  
   * On supprime tous les dossiers ​   * On supprime tous les dossiers ​
Ligne 374: Ligne 393:
  
   * On relance squid3 :   * On relance squid3 :
-<code root>/​etc/​init.d/​squid3 ​start</​code>​+<code root>/​etc/​init.d/​squid3 ​restart</​code>​
 </​note>​ </​note>​
  
Ligne 399: Ligne 418:
  
   * Tout en observant côté passerelle (i.e. serveur squid) ​   * Tout en observant côté passerelle (i.e. serveur squid) ​
-le fichier /​var/​log/​squid3/​access.logdes ​logs d'​accès :+le fichier /​var/​log/​squid3/​access.log des logs d'​accès :
  
 <code root> <code root>
Ligne 438: Ligne 457:
   *Il faut un certain temps pour obtenir des HIT   *Il faut un certain temps pour obtenir des HIT
  
-<code root>​tail -f /​var/​log/​squid3/​cache.log | grep  ​TCP_HIT</​code>​ +<code root> tail -f /​var/​log/​squid3/​access.log | grep HIT 
-<​code>​Server: ECS (cdg/​D62E)\r\nX-Cache:​ HIT\r\nContent-Length:​ 471\r\n\r] +</​code>​ 
-1413884011.978     ​66 ​192.168.1.2 TCP_MISS/200 919 POST http://ocsp.digicert.com/ - DIRECT/93.184.220.29 application/ocsp-response [Host: ocsp.digicert.com\r\nUser-Agent:​ Mozilla/5.0 (X11; Linux x86_64; rv:31.0) Gecko/20100101 Firefox/​31.0 Iceweasel/​31.2.0\r\nAccept:​ text/​html,​application/​xhtml+xml,​application/​xml;​q=0.9,​*/​*;​q=0.8\r\nAccept-Language: fr,​fr-fr;​q=0.8,en-us;​q=0.5,​en;​q=0.3\r\nAccept-Encoding:​ gzip, deflate\r\nDNT:​ 1\r\nContent-Length:​ 83\r\nContent-Type:​ application/ocsp-request\r\nConnection:​ keep-alive\r\n] [HTTP/1.1 200 OK\r\nAccept-Ranges:​ bytes\r\nCache-Control:​ max-age=514328\r\nContent-Type:​ application/​ocsp-response\r\nDate:​ Tue, 21 Oct 2014 09:32:42 GMT\r\nETag:​ "​5445fdee-1d7"​\r\nExpires:​ Mon, 27 Oct 2014 21:32:42 GMT\r\nLast-Modified:​ Tue, 21 Oct 2014 06:32:14 GMT\r\nServer:​ ECS (cdg/​4484)\r\nX-Cache:​ HIT\r\nContent-Length:​ 471\r\n\r]</​code>​ +<​code>​1415119957.532      0 192.168.1.10 TCP_MEM_HIT/200 15385 GET http://blog.tfrichet.fr/wp-content/uploads/2013/09/owncloud_acces_mobile-600x150.jpg NONE/- image/jpeg</​code>​
-====Vérifier le cache==== +
-===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.\\  +
- +
-  * Par exemple ci-dessous les DNS enregistrés : +
-<​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| Initializing IP Cache... +
-2014/10/16 13:11:45| DNS Socket created at [::], FD 7 +
-2014/10/16 13:11:45| DNS Socket created at 0.0.0.0, FD 8 +
-2014/10/16 13:11:45| Adding domain mondomaine.hyp from /​etc/​resolv.conf +
-2014/10/16 13:11:45| Adding domain mondomaine.hyp from /​etc/​resolv.conf +
-2014/10/16 13:11:45| Adding nameserver 127.0.0.1 from /​etc/​resolv.conf +
-2014/10/16 13:11:45| Adding nameserver 192.168.0.1 from /​etc/​resolv.conf +
-2014/10/16 13:11:45| Adding nameserver 212.27.40.240 from /​etc/​resolv.conf +
-2014/10/16 13:11:45| Adding nameserver 212.27.40.241 from /​etc/​resolv.conf +
-2014/10/16 13:11:45| Unlinkd pipe opened on FD 13<​...></​code>​ +
- +
- +
 <note tip> <note tip>
 **__Détail sur  /​var/​log/​squid3/​access.log__ :**\\  **__Détail sur  /​var/​log/​squid3/​access.log__ :**\\ 
Ligne 490: Ligne 488:
 >​**''​type''​** : le type de contenu issu du header HTTP de la réponse (Les échanges ICP ne contiennent pas cette information). >​**''​type''​** : le type de contenu issu du header HTTP de la réponse (Les échanges ICP ne contiennent pas cette information).
 </​note>​ </​note>​
 +
 +===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.\\ ​
 +
 +  * 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
 +2014/10/16 13:11:45| With 65535 file descriptors available
 +2014/10/16 13:11:45| Initializing IP Cache...
 +2014/10/16 13:11:45| DNS Socket created at [::], FD 7
 +2014/10/16 13:11:45| DNS Socket created at 0.0.0.0, FD 8
 +2014/10/16 13:11:45| Adding domain mondomaine.hyp from /​etc/​resolv.conf
 +2014/10/16 13:11:45| Adding domain mondomaine.hyp from /​etc/​resolv.conf
 +2014/10/16 13:11:45| Adding nameserver 127.0.0.1 from /​etc/​resolv.conf
 +2014/10/16 13:11:45| Adding nameserver 192.168.0.1 from /​etc/​resolv.conf
 +2014/10/16 13:11:45| Adding nameserver 212.27.40.240 from /​etc/​resolv.conf
 +2014/10/16 13:11:45| Adding nameserver 212.27.40.241 from /​etc/​resolv.conf
 +2014/10/16 13:11:45| Unlinkd pipe opened on FD 13<​...></​code>​
 +
 +===Consulter /​var/​log/​squid3/​store.log ===
 +<code root>​less /​var/​log/​squid3/​store.log</​code>​
 +
  
  

Pied de page des forums

Propulsé par FluxBB