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 [02/11/2014 11:22]
Hypathie [Configuration détaillée du proxy]
utilisateurs:hypathie:tutos:proxy-transparent [04/11/2014 15:30]
Hypathie [Configuration détaillée du proxy]
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
Ligne 168: Ligne 167:
 ===Créer un dossier pour le cache=== ===Créer un dossier pour le cache===
  
-  * **Vérifier la taille de l'​emplacement pour le cache :** +  * Repérer ​le périphérique choisi ​
-Par exemple /home +<code root>fdisk -l</​code>​ 
-<code root>cd /home</​code>​ +<​code>​Périphérique Amorce ​ Début ​       Fin      Blocs     ​Id ​ Système 
-<code root>du -hs</code> +/​dev/​sdg1 ​             63  1336206374 ​  ​668103156 ​  ​83 ​ Linux 
-   +/​dev/​sdg2 ​     1336206375 ​ 3907024064 ​ 1285408845 ​  ​83 ​ Linux</​code>​
-  ​44M+
  
-  * **Création d'un dossier d'une taille prédéfinie de 20M**+  * Formater le périphérique en ext3 ou reiserfs : 
 +On démonte la partition : 
 +<​code>​umount /​dev/​sdg1</​code>​
  
 +  * 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>​
 +<...>
 +/​dev/​sdg1 ​                                              ​657618716 ​ 202064 ​ 624011496 ​  1% /media/
 +<...>
 +</​code>​
  
-<code root>dd if=/dev/zero of=cache bs=1k count=20000</​code>​ +  * Si c'est le cas on relance umount : 
-<code root>ls -sh</​code>​+<code root>umount ​/dev/sdg1</​code>​
  
-  ​total 20M +  ​* Et on désactive le montage automatique des supports amovibles : 
-  20M cache+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"​ et "​Monter les volumes amovibles automatiquement quand ils sont insérés"​.
  
-<code root>​chmod 777 /​home/​cache</​code>​ +  * On formate la partition : 
-<code root>chown proxy:​proxy ​/home/cache</​code>​+<code root>mkfs.ext3 ​/dev/sdg1</​code>​
  
-===Configuration de squid3 ​pour la mise en place du cache=== +  * Création d'un dossier ​pour le cache de squid3 ​ 
-Avec squid3 ​le cache n'est pas activer.\\ ​ +<code root>​mkdir /​data/</​code>​
-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> +<code root>​mount /dev/sdg1 /​data</​code>
-**__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.+<code root>​mkdir /​data/​cache/</​code>​
  
-  ​http_port 3128 8080+  ​* 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>​
  
-**''​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 ​:+  ​Connaître UUID de la partition pour le cache de squid3 ​: 
 +<code root>​blkid /​dev/​sdg1</​code>​
  
-  ​cache_dir ufs /usr/local/squid/var/cache/ 100 16 256+  ​* 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>
  
-"​Remarque : Le type ufs de magasin:\\ 
-"​ufs"​ est l'​ancien format de stockage Squid bien connu qui a toujours été là." 
  
-**''​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 :+===Paramétrage du cache dans /​etc/​squid3/​squid.conf=== 
 +Avec squid3 le cache n'est pas activer par défautpour mettre ​en place le cache, il faut récupérer les lignes commentées du fichiers ​d'​origine /​etc/​squid3/​squid.conf-bak.\\ 
  
-  * Définition ​d'une liste d'​accès+  * **On désactive squid3** 
 +<code root>/​etc/​init.d/squid3 stop</​code>​
  
-  acl localhost src 127.0.0.1/​32+  ​* **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 to_localhost dst 127.0.0.0/8 0.0.0.0/32 ::1 
 +acl lan src 192.168.1.0/​24 
 +acl SSL_ports port 443 
 +acl Safe_ports port 80          # http 
 +acl Safe_ports port 21          # ftp 
 +acl Safe_ports port 443         # https 
 +acl Safe_ports port 70          # gopher 
 +acl Safe_ports port 210         # wais 
 +acl Safe_ports port 1025-65535 ​ # unregistered ports 
 +acl Safe_ports port 280         # http-mgmt 
 +acl Safe_ports port 488         # gss-http 
 +acl Safe_ports port 591         # filemaker 
 +acl Safe_ports port 777         # multiling http 
 +acl CONNECT method CONNECT 
 +http_access allow manager localhost 
 +http_access deny manager 
 +http_access deny !Safe_ports 
 +http_access deny CONNECT !SSL_ports 
 +http_access allow localhost 
 +http_access allow lan 
 +http_access deny all
  
-  * Définition des droits de cette liste+icp_access allow localhost 
 +icp_access deny all
  
-  http_access allow localhost+http_port 3128 transparent
  
-  * Interdiction à toutes les autres listes+cache_mem 256 MB 
 +minimum_object_size 3 KB 
 +maximum_object_size 6 MB
  
-  http_access deny all+ipcache_size 10240 
 +fqdncache_size 10240
  
-**__Concernant la mise en cache les résolutions DNS__** :+memory_replacement_policy heap GDSF 
 +cache_replacement_policy heap LFUDA
  
-**''​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+cache_dir aufs /data/cache 20000 14 256
-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.+cache_swap_low 95 
 +cache_swap_high 99
  
-**__Concernant l'​affichage des traces de debug__ :**+cache_effective_user proxy 
 +cache_effective_group proxy
  
-**''​log_mime_hdrs''​** : permet d’afficher les en-têtes HTTP des requêtes et des réponses dans les logs d’activité.+access_log /​var/​log/​squid3/​access.log squid 
 +#cache_log /​var/​log/​squid3/​cache.log 
 +#​cache_store_log /​var/​log/​squid3/​store.log
  
-**''​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)) :+coredump_dir /​var/​spool/​squid3
  
-  debug_options ALL,17,2 55,2 56,2 57,2 58,2+cache allow lan 
 + 
 +refresh_pattern ^ftp:           ​1440 ​   20%     ​10080 
 +refresh_pattern ^gopher: ​       1440    0%      1440 
 +refresh_pattern -i (/​cgi-bin/​|\?​) 0     ​0% ​     0 
 +refresh_pattern .               ​0 ​      ​20% ​    ​4320 
 + 
 +visible_hostname routeur-debian 
 + 
 +dns_timeout 10 seconds 
 +dns_nameservers 192.168.0.212.27.40.240 212.27.40.241 
 +</​code>​ 
 + 
 +<note tip> 
 +**__Voici la définition de quelques options de configuration basiques :__** 
 + 
 +**''​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''​**\\  
 + 
 + 
 +**''​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 disquele second à l’espace alloué (100 Méga-octets dans l’exemple ci-dessous)le troisième au nombre de répertoires racineet 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 
 + 
 +"​Remarque : Le type ufs de magasin:​\\ 
 +"​ufs"​ est l'​ancien format de stockage Squid bien connu qui a toujours été là."​ 
 + 
 +**''​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 :
  
->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 
->#  TAGminimum_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>​ <note important>​
Ligne 279: Ligne 345:
 </​note>​ </​note>​
  
-  * **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>​ 
  
   * **Ou télécharger ce fichier :**   * **Ou télécharger ce fichier :**
Ligne 305: Ligne 365:
 http_access allow manager localhost http_access allow manager localhost
 http_access deny manager http_access deny manager
-http_access deny safeports +http_access deny !safeports 
-http_access deny CONNECT sslports+http_access deny CONNECT ​!sslports
 http_access allow localhost http_access allow localhost
 http_access allow localnet http_access allow localnet
-http_access deny lan +http_access allow lan
-#http_access allow lan+
 http_access deny all http_access deny all
  
Ligne 324: Ligne 383:
 memory_replacement_policy heap GDSF memory_replacement_policy heap GDSF
 cache_replacement_policy heap LFUDA cache_replacement_policy heap LFUDA
-cache_dir aufs /home/cache 20000 14 256+cache_dir aufs /home/proxy/cache 20000 14 256
 maximum_object_size 128000 KB  maximum_object_size 128000 KB 
 cache_swap_low 95 cache_swap_low 95
Ligne 331: Ligne 390:
 # LOGFILE PATHNAMES AND CACHE DIRECTORIES # LOGFILE PATHNAMES AND CACHE DIRECTORIES
 # ================================== # ==================================
- 
 access_log /​var/​log/​squid3/​access.log access_log /​var/​log/​squid3/​access.log
-cache_log /var/log/squid/cache.log+cache_log /var/log/squid3/cache.log
 cache_store_log none cache_store_log none
 logfile_rotate 5 logfile_rotate 5
Ligne 388: Ligne 446:
 httpd_suppress_version_string on httpd_suppress_version_string on
 visible_hostname routeur-debian visible_hostname routeur-debian
- 
 ftp_list_width 32 ftp_list_width 32
 ftp_passive on ftp_passive on
Ligne 397: Ligne 454:
  
 dns_timeout 10 seconds dns_timeout 10 seconds
-dns_nameservers 192.168.0.1 212.27.40.240 212.27.40.241 ​# DNS Server+dns_nameservers 192.168.0.1 212.27.40.240 212.27.40.241
  
 # MISCELLANEOUS # MISCELLANEOUS
 # =========== # ===========
- 
 memory_pools off memory_pools off
 client_db off client_db off
Ligne 480: Ligne 536:
  
   * 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>

Pied de page des forums

Propulsé par FluxBB