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 17:33]
Hypathie [Introduction]
utilisateurs:hypathie:tutos:proxy-transparent [04/11/2014 14:15]
Hypathie [Configuration détaillée du proxy]
Ligne 35: Ligne 35:
  
 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 eth0 -p tcp --dport 80 -j REDIRECT --to-port 3128 iptables -t nat -A PREROUTING -i eth0 -p tcp --dport 80 -j REDIRECT --to-port 3128
Ligne 45: Ligne 48:
  
 <​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 sur la table FILTER+**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]] : **Pour mangle**, une petite citation extrait du [[http://​wiki.squid-cache.org/​ConfigExamples/​Intercept/​LinuxDnat|site officiel de squid]] :
Ligne 70: Ligne 73:
 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>​
  
  
-===Installer le serveur squid3=== +====Installer le serveur squid3==== 
-<code root>​apt-get install squid3</​code>​+
 <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 94: Ligne 99:
 <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>​
  
-  * On ajoute ou modifie les lignes suivantes : +====Vérifier le proxy ==== 
-Rappel ​de la configuration:​\\  +===Bloquer tous le trafic du LAN === 
-eth0 (vers internet) : 192.168.0.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'' ​: 
-eth1 (vers lan) 192.168.1.1+  * **On édite /​etc/​squid3/​squid.conf** 
 +<code root>vim /​etc/​squid3/​squid.conf</​code>​
  
-> ''​acl localnet src 192.168.1.0/​24''​ : le réseau ​qui doit avoir accès au serveur proxy +  * **Ce qui donne :**
->''​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.+
  
-  * Concernant le cache tout est commenté dans le fichier original 
-On récupère le concernant, et on l'​ajoute aussi dans le fichier /​etc/​squid3/​squid.conf 
- 
-  * Ce qui donne : 
-<code user>​less /​etc/​squid3/​squid.conf</​code>​ 
 <​code>​ <​code>​
 acl manager proto cache_object acl manager proto cache_object
Ligne 133: Ligne 129:
 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 139: Ligne 134:
 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
 +coredump_dir /​var/​spool/​squid3
 +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
 +</​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.
  
-#​hierarchy_stoplist cgi-bin ?+  * On recharge squid3 : 
 +<code root>/​etc/​init.d/​squid3 restart</​code>​
  
-cache allow LocalNet +  * **Si on tente de naviguer depuis le LAN :** 
-#cache deny QUERY+{{http://​pix.toile-libre.org/​upload/​img/​1414862596.png|}}
  
-# MEMORY CACHE OPTIONS +===Autoriser le trafic pour le LAN=== 
-#Default: +  * **On ajoute une acl pour le lan et on l'​autorise !** 
-#cache_mem 256 MB +<code root>vim /​etc/​squid3/​squid.conf</​code>​ 
-cache_mem 8 MB +<​code>​ 
-#Default: +<...> 
-maximum_object_size_in_memory 256 KB +acl lan src 192.168.1.0/​24 
-#​memory_replacement_policy lru +<...> 
-# DISK CACHE OPTIONS +http_access allow localnet 
-# Décommentez et régler les éléments suivants pour ajouter un répertoire de cache disque: +</code>
-cache_dir ufs /var/​spool/​squid3 100 16 256+
  
-#Default+  * **On recharge squid3 ​:** 
-#​store_dir_select_algorithm least-load+<code root>/​etc/​init.d/​squid3 restart</​code>​
  
-# A value of 0 indicates no limit. +=====Configuration détaillée du proxy ===== 
-#Default: +====Mise en place du cache pour le LAN  ==== 
-max_open_disk_fds 0 +===Créer un dossier pour le cache===
-# 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 10 KB+
  
-# LOG_FILE OPTIONS +  * Repérer le périphérique choisi ​
-#Default+<code root>​fdisk -l</code> 
-access_log ​/var/log/squid3/access.log squid+<​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>
  
-#Default+  * Formater le périphérique en ext3 ou reiserfs ​
-cache_log /var/log/squid3/cache.log+On démonte la partition : 
 +<​code>​umount ​/dev/sdg1</code>
  
-# Leave coredumps in the first cache dir +  * On vérifie que la partition ne soit pas montée parallèlement par le montage automatique des supports amovibles : 
-#​coredump_dir ​/var/spool/squid3+<code root>​df<​/code> 
 +<​code>​ 
 +<​...>​ 
 +/dev/​sdg1 ​                                              ​657618716 ​ 202064 ​ 624011496 ​  1% /media/ 
 +<​...>​ 
 +</code>
  
-# OPTIONS FOR TUNING THE CACHE +  * Si c'est le cas on relance umount ​
-cache allow all +<code root>​umount ​/dev/sdg1</​code>​
-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+
  
-hosts_file ​/etc/hosts +  * Et on désactive le montage automatique des supports amovibles : 
-</​code>​+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"​. 
 + 
 +  * 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>​ 
 + 
 +  * 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>​
  
-===Activation du cache === 
  
 +===Configuration de squid3 pour la mise en place du cache===
 Avec squid3 le cache n'est pas activer.\\ ​ 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 ! Pour l'​activer,​ il va falloir aller chercher dans le fichier original ce qui concerne la mise en cache !
Ligne 288: Ligne 308:
 </​note>​ </​note>​
  
-  * Grâce à la ligne suivant les fichiers du cache sont créés +  * **On désactive squid3** 
->''​cache_dir ufs /var/spool/​squid3 ​100 16 256''​+<code root>/etc/init.d/​squid3 ​stop</​code>​
  
-Et quand on re-démarre ​squid3 :+  * **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 root>/​etc/​init.d/​squid3 ​restart</​code>​+  * **Ou télécharger ce fichier :** 
 + 
 +<code texte my-squid.conf>​ 
 +# ACCESS CONTROLS OPTIONS 
 +# ==================== 
 +acl QUERY urlpath_regex -i cgi-bin \? \.php$ \.asp$ \.shtml$ \.cfm$ \.cfml$ \.phtml$ \.php3$ localhost 
 +acl all src 
 +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 localnet src 192.168.0.0/​24 # RFC1918 possible internal network 
 +acl lan src 192.168.1.0/​24 
 +acl safeports port 21 70 80 210 280 443 488 563 591 631 777 901 81 3128 1025-65535 
 +acl sslports port 443 563 81 2087 10000 
 +acl manager proto cache_object 
 +acl purge method PURGE 
 +acl connect method CONNECT 
 + 
 +http_access allow manager localhost 
 +http_access deny manager 
 +http_access deny !safeports 
 +http_access deny CONNECT !sslports 
 +http_access allow localhost 
 +http_access allow localnet 
 +http_access allow lan 
 +http_access deny all 
 + 
 +# NETWORK OPTIONS 
 +# ==================== 
 +http_port 3128 transparent 
 + 
 +# OPTIONS WHICH AFFECT THE CACHE SIZE 
 +# ============================== 
 + 
 +cache_mem 16 MB 
 +maximum_object_size_in_memory 32 KB 
 +memory_replacement_policy heap GDSF 
 +cache_replacement_policy heap LFUDA 
 +cache_dir aufs /​home/​proxy/​cache 20000 14 256 
 +maximum_object_size 128000 KB  
 +cache_swap_low 95 
 +cache_swap_high 99 
 + 
 +# LOGFILE PATHNAMES AND CACHE DIRECTORIES 
 +# ================================== 
 +access_log /​var/​log/​squid3/​access.log 
 +cache_log /​var/​log/​squid3/​cache.log 
 +cache_store_log none 
 +logfile_rotate 5 
 +log_icp_queries off 
 + 
 +# OPTIONS FOR TUNING THE CACHE 
 +# ======================== 
 + 
 +cache deny QUERY 
 +refresh_pattern ^ftp: 1440 20% 10080 reload-into-ims 
 +refresh_pattern ^gopher: 1440 0% 1440 
 +refresh_pattern -i \.(gif|png|jp?​g|ico|bmp|tiff?​)$ 10080 95% 43200 override-expire override-lastmod reload-into-ims ignore-no-cache ignore-private 
 +refresh_pattern -i \.(rpm|cab|deb|exe|msi|msu|zip|tar|xz|bz|bz2|lzma|gz|tgz|rar|bin|7z|doc?​|xls?​|ppt?​|pdf|nth|psd|sis)$ 10080 90% 43200 override-expire override-lastmod reload-into-ims ignore-no-cache ignore-private 
 +refresh_pattern -i \.(avi|iso|wav|mid|mp?​|mpeg|mov|3gp|wm?​|swf|flv|x-flv|axd)$ 43200 95% 432000 override-expire override-lastmod reload-into-ims ignore-no-cache ignore-private 
 +refresh_pattern -i \.(html|htm|css|js)$ 1440 75% 40320 
 +refresh_pattern -i \.index.(html|htm)$ 0 75% 10080 
 +refresh_pattern -i (/​cgi-bin/​|\?​) 0 0% 0 
 +refresh_pattern . 1440 90% 10080 
 +
 +quick_abort_min 0 KB 
 +quick_abort_max 0 KB 
 +quick_abort_pct 100 
 +store_avg_object_size 13 KB 
 + 
 +# HTTP OPTIONS 
 +# =========== 
 +vary_ignore_expire on 
 + 
 +# ANONIMITY OPTIONS 
 +# =============== 
 + 
 +request_header_access From deny all 
 +request_header_access Server deny all 
 +request_header_access Link deny all 
 +request_header_access Via deny all 
 +request_header_access X-Forwarded-For deny all 
 + 
 +# TIMEOUTS 
 +# ======= 
 + 
 +forward_timeout 240 second 
 +connect_timeout 30 second 
 +peer_connect_timeout 5 second 
 +read_timeout 600 second 
 +request_timeout 60 second 
 +shutdown_lifetime 10 second 
 + 
 +# ADMINISTRATIVE PARAMETERS 
 +# ===================== 
 + 
 +cache_mgr routeur-debian 
 +cache_effective_user proxy 
 +cache_effective_group proxy 
 +httpd_suppress_version_string on 
 +visible_hostname routeur-debian 
 +ftp_list_width 32 
 +ftp_passive on 
 +ftp_sanitycheck on 
 + 
 +# DNS OPTIONS 
 +# ========== 
 + 
 +dns_timeout 10 seconds 
 +dns_nameservers 192.168.0.1 212.27.40.240 212.27.40.241 
 + 
 +# MISCELLANEOUS 
 +# =========== 
 +memory_pools off 
 +client_db off 
 +reload_into_ims on 
 +coredump_dir /​var/​log/​squid 
 +pipeline_prefetch on 
 +offline_mode off 
 +</​code>​ 
 + 
 +  * Copie du précédent fichier squid.conf : 
 +<code root>mv /​etc/​squid3/​squid.conf /​etc/​squid3/​squid.conf-BAK2</​code>​ 
 +  * Mise en place du nouveau fichier /​etc/​squid3/​squid.conf 
 +<code root>mv /​home/​hypathie/​Téléchargements/​my-squid.conf /​etc/​squid3/​squid.conf</​code>​ 
 + 
 +  * **Et quand on re-démarre squid3 :** 
 +> Grâce à la directive ''​cache_dir''​ les fichiers du cache sont créés 
 +<code root>/​etc/​init.d/​squid3 ​start</​code>​
 <​code>​2014/​10/​17 16:29:49| Creating Swap Directories <​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| /​var/​spool/​squid3 exists
Ligne 321: Ligne 470:
   * 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 /home/cache</​code>​
  
   * On supprime tous les dossiers ​   * On supprime tous les dossiers ​
Ligne 356: Ligne 505:
  
   * 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