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 [16/10/2014 15:14]
Hypathie [configuration d'iptables (NAT)]
utilisateurs:hypathie:tutos:proxy-transparent [16/10/2014 17:44]
Hypathie [Configuration de squid comme proxy transparent]
Ligne 123: Ligne 123:
 acl to_localhost dst 127.0.0.0/8 0.0.0.0/32 # par défaut acl to_localhost dst 127.0.0.0/8 0.0.0.0/32 # par défaut
 acl localnet src 192.168.1.0/​24 # RFC1918 possible internal network acl localnet src 192.168.1.0/​24 # RFC1918 possible internal network
-acl localnet src 172.16.0.0/​12 ​ # RFC1918 possible internal network 
 acl localnet src 192.168.0.0/​16 # RFC1918 possible internal network acl localnet src 192.168.0.0/​16 # RFC1918 possible internal network
 acl SSL_ports port 443          # https acl SSL_ports port 443          # https
Ligne 179: Ligne 178:
 coredump_dir /​var/​spool/​squid coredump_dir /​var/​spool/​squid
 </​code>​ </​code>​
-S'il n'y a pas d'​erreur : 
-<​code>​[ ok ] Restarting Squid HTTP proxy: squid.</​code>​ 
  
 ===Redémarrer squid=== ===Redémarrer squid===
 <code root>/​etc/​init.d/​squid restart</​code>​ <code root>/​etc/​init.d/​squid restart</​code>​
 +
 +S'il n'y a pas d'​erreur :
 +<​code>​[ ok ] Restarting Squid HTTP proxy: squid.</​code>​
 +
 ===== configuration d'​iptables (NAT) ===== ===== configuration d'​iptables (NAT) =====
 Nous n'​avons pour l'​instant que l'IP masquerade mis en place : Nous n'​avons pour l'​instant que l'IP masquerade mis en place :
  
-<​code>#​ proxy IP 
-SQUIDIP=192.168.0.1 
  
-#port du proxy +  * Il faut ajouter :
-SQUIDPORT=3128+
  
-iptables -t nat -A PREROUTING -s $SQUIDIP -p tcp --dport 80 -j ACCEPT 
- 
-iptables -t nat -A PREROUTING -p tcp --dport 80 -j DNAT --to-destination $SQUIDIP:​$SQUIDPORT 
- 
-iptables -t nat -A POSTROUTING -j MASQUERADE 
- 
-iptables -t mangle -A PREROUTING -p tcp --dport $SQUIDPORT -j DROP 
-</​code>​ 
- 
-  * Ce qui donne par exemple pour notre configuration:​ 
 <code root> <code root>
-iptables -t nat -A PREROUTING -s 192.168.0.1 -p tcp --dport 80 -j ACCEPT +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 -PREROUTING -p tcp --dport 80 -j DNAT --to-destination ​192.168.0.1:3128 +iptables -t nat -PREROUTING ​-i eth1 -192.168.1.0/24 -p tcp -m tcp --dport ​80 -J ACCEPT
-#iptables -t nat -A POSTROUTING -o eth0 -j MASQUERADE (déjà dans le pare-feu, sinon à décommenter) +
-iptables -t mangle -A PREROUTING ​-p tcp --dport ​3128 -j DROP+
 </​code>​ </​code>​
  
Ligne 237: Ligne 223:
 # Controls source route verification # Controls source route verification
 net.ipv4.conf.default.rp_filter = 0 net.ipv4.conf.default.rp_filter = 0
- 
-# Do not accept source routing 
-#​net.ipv4.conf.default.accept_source_route = 0 
 </​code>​ </​code>​
   * Faire rendre en compte une éventuelle modification :   * Faire rendre en compte une éventuelle modification :
 <code root>​sysctl -p</​code>​ <code root>​sysctl -p</​code>​
 +
 +=====Vérifications====
 +===Générer du flux ===
 +Tout bêtement, de côté du lan, on navigue.
 +
 +  * 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>​
 +
 +
 +  * Le fichier /​var/​log/​squid3/​access.log
 +Ce dernier répertorie tous les accès faits au serveur, c’est-à-dire toutes les requêtes HTTP reçues et la façon dont elles ont été traitées. Le format de ce fichier est paramétrable via l’option access_log du fichier squid.conf. Le format natif d’une entrée de log est le suivant :\\ **''​time elapsed remotehost code/status bytes method URL rfc931 peerstatus/​peerhost type''​**\\ ​
 +
 +> **''​time''​** : le temps UTC (en ms) auquel la requête a été reçue.
 +
 +>​**''​elapsed''​** : le temps de traitement par le serveur de la requête (en ms). Ce temps de traitement diffère selon le mode utilisé (connecté ou déconnecté) :
 +
 +  * Pour TCP, il s’agit du temps écoulé entre le moment où le serveur a reçu la requête et le moment où il a répondu au client.
 +  * Pour UDP, il s’agit du temps calculé entre le moment où le serveur prévoit de répondre au client et le moment où il lui répond effectivement.
 +
 +>​**''​remotehost''​** : l’adresse IP du client. Cette donnée peut être cachée pour rendre les logs anonymes.
 +
 +>​**''​code/​status''​** : le code résultat de la transaction. Ce champ est composé de deux entrées séparées par un slash : le code de statut de Squid et le code HTTP de la réponse du serveur d’origine. La plupart de ces codes sont détaillés plus bas.
 +
 +>​**''​bytes''​** : la taille de la donnée livrée au client.
 +
 +>​**''​method''​** : la méthode utilisée pour récupérer la ressource (GET, HEAD, etc.).
 +
 +>​**''​URL''​** : l’URL de la ressource demandée.
 +
 +>​**''​rfc931''​** : les informations utilisateurs (désactivé par défaut).
 +
 +>​**''​hierarchy code''​** : un code permettant de savoir comment la requête a été traitée. Ce code peut être suivi par l’adresse IP vers laquelle la requête a été redirigée.
 +
 +>​**''​type''​** : le type de contenu issu du header HTTP de la réponse (Les échanges ICP ne contiennent pas cette information).
 +
 +
 +
 ===== Utilisation ===== ===== Utilisation =====
  
  

Pied de page des forums

Propulsé par FluxBB