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 →
Ci-dessous, les différences entre deux révisions de la page.
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:00] Hypathie [Configuration de squid comme proxy transparent] |
utilisateurs:hypathie:tutos:proxy-transparent [04/11/2014 14:54] Hypathie [Configuration détaillée du proxy] |
||
---|---|---|---|
Ligne 168: | Ligne 168: | ||
===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> |
+ | |||
+ | * Et 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" 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> | ||
+ | |||
+ | |||
+ | ===Création du cache=== | ||
+ | Avec squid3 le cache n'est pas activer par défaut.\\ | ||
+ | |||
+ | * **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 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 | ||
+ | |||
+ | icp_access allow localhost | ||
+ | icp_access deny all | ||
+ | |||
+ | http_port 3128 transparent | ||
+ | |||
+ | cache_mem 256 MB | ||
+ | minimum_object_size 3 KB | ||
+ | maximum_object_size 6 MB | ||
+ | |||
+ | 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 | ||
+ | |||
+ | 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 ^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.1 212.27.40.240 212.27.40.241 | ||
+ | </code> | ||
- | total 20M | ||
- | 20M cache | ||
- | <code root>chmod 777 /home/cache</code> | + | * On crée le cache : |
- | <code root>chown proxy:proxy /home/cache</code> | + | <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> | ||
- | ===Configuration de squid3 pour la mise en place 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’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''**\\ |
- | 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 241: | Ligne 360: | ||
>section **58** HTTP Reply (Response) __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: | ||
- | >''# 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'' | ||
- | >''cache'' : pour déterminer l'utilisation du cache\\ ''cache allow LocalNet'' ; elle doit remplacer ''no_cache'' | ||
<note important> | <note important> | ||
Ligne 279: | Ligne 377: | ||
</note> | </note> | ||
- | * **On désactive squid3** | ||
- | <code root>/etc/init.d/squid3 stop</code> | ||
- | <code root>vim /etc/squid3/squid.conf</code> | ||
- | * **On édite /etc/squid3/squid.conf :** | + | * **Ou télécharger ce fichier :** |
- | <code> | + | |
+ | <code texte my-squid.conf> | ||
# ACCESS CONTROLS OPTIONS | # ACCESS CONTROLS OPTIONS | ||
# ==================== | # ==================== | ||
Ligne 301: | Ligne 397: | ||
http_access allow manager localhost | http_access allow manager localhost | ||
http_access deny manager | http_access deny manager | ||
- | http_access deny !Safe_ports | + | http_access deny !safeports |
- | http_access deny CONNECT !SSL_ports | + | 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 320: | Ligne 415: | ||
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 327: | Ligne 422: | ||
# 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 384: | Ligne 478: | ||
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 393: | Ligne 486: | ||
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 404: | Ligne 496: | ||
pipeline_prefetch on | pipeline_prefetch on | ||
offline_mode off | offline_mode off | ||
- | |||
- | #Marking ZPH | ||
- | #========== | ||
- | zph_mode tos | ||
- | zph_local 0x04 | ||
- | zph_parent 0 | ||
- | zph_option 136 | ||
</code> | </code> | ||
- | > Grâce à la directive ''cache_dir'' les fichiers du cache sont créés | + | * 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 :** | * **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 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 | ||
Ligne 481: | Ligne 568: | ||
* 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> |