<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>

<channel>
	<title>Linux Attitude&#187; Firewall</title>
	<atom:link href="http://linux-attitude.fr/tag/firewall/feed" rel="self" type="application/rss+xml" />
	<link>http://linux-attitude.fr</link>
	<description>Le libre est un état d&#039;esprit</description>
	<lastBuildDate>Tue, 20 Jul 2010 19:54:56 +0000</lastBuildDate>
	<generator>http://wordpress.org/?v=2.9.2</generator>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
			<item>
		<title>Firewall en 2 temps 3 mouvements</title>
		<link>http://linux-attitude.fr/post/firewall-en-2-temps-3-mouvements</link>
		<comments>http://linux-attitude.fr/post/firewall-en-2-temps-3-mouvements#comments</comments>
		<pubDate>Wed, 23 Jun 2010 16:44:15 +0000</pubDate>
		<dc:creator>peck</dc:creator>
				<category><![CDATA[Réseau]]></category>
		<category><![CDATA[Firewall]]></category>
		<category><![CDATA[planet-libre]]></category>
		<category><![CDATA[Système]]></category>

		<guid isPermaLink="false">http://linux-attitude.fr/?p=908</guid>
		<description><![CDATA[Niveau&#160;:     
Résumé&#160;: ferm


Ferm

Vous battez-vous toujours avec vos scripts shell pour configurer les firewall de vos serveurs&#160;?
Ne ramez plus, j'ai la solution&#160;: Ferm.


Pourquoi ferm&#160;? Ben pourquoi pas&#160;?


Je l'ai choisi car il ne fait qu'une chose (et le fait bien), il remplace vos scripts shell de lancement de firewall. Et c'est tout&#160;! Pas [...]]]></description>
			<content:encoded><![CDATA[<p><strong>Niveau</strong>&nbsp;: <img src="/public/Pics/s.gif" alt="Star" /> <img src="/public/Pics/s.gif" alt="Star" /> <img src="/public/Pics/s.gif" alt="Star" /> <img src="/public/Pics/e.gif" alt="Empty" /> <img src="/public/Pics/e.gif" alt="Empty" /><br />
<strong>Résumé</strong>&nbsp;: ferm</p>


<h3>Ferm</h3>

<p>Vous battez-vous toujours avec vos scripts shell pour configurer les firewall de vos serveurs&nbsp;?
Ne ramez plus, j'ai la solution&nbsp;: <a href="http://ferm.foo-projects.org/" hreflang="en">Ferm</a>.</p>


<p>Pourquoi ferm&nbsp;? Ben pourquoi pas&nbsp;?</p>


<p>Je l'ai choisi car il ne fait qu'une chose (et le fait bien), il remplace vos scripts shell de lancement de firewall. Et c'est tout&nbsp;! Pas d'interface graphique, pas d'assistance à création de règle, pas de gestion de votre serveur DHCP ...</p>


<p>Donc si votre machine de bureau sert de passerelle vers internet, ou si vous ne connaissez pas bien iptables, ce n'est probablement pas le meilleur outil. Par contre si vous avez l'habitude d'écrire des scripts shell pour gérer votre firewall, ferm est là pour vous simplifier la vie.</p>


<h3>Configuration</h3>

<p>Ferm génère des règles iptables à partir de son fichier de configuration. Il n'invente rien, il ne fait qu'écrire sous forme hiérarchique les règles iptables et vous permet d'utiliser des variable et des listes. Il faut donc les connaître un peu.</p>


<p>Petit exemple pour vous montrer comment gagner du temps (il se comprend tout seul)&nbsp;:
<span id="more-908"></span></p>

<pre>
@def $SERVERS = (10.0.0.2 10.0.0.3);
table filter {
    chain FORWARD {
        policy DROP;
        proto tcp dport (80 443) daddr $SERVERS ACCEPT;
    }
}
</pre>


<p>On demande à ferm de générer les règles iptables mais sans les mettre dans le firewall (pas fou)&nbsp;:</p>
<pre>
$ ferm -n --lines firewall.conf
</pre>


<p>Et on obtient directement nos 4 règles auxquelles on s'attendait&nbsp;:</p>
<pre>
*filter
:FORWARD DROP [0:0]
-A FORWARD --protocol tcp --dport 80 --destination 10.0.0.2 --jump ACCEPT
-A FORWARD --protocol tcp --dport 80 --destination 10.0.0.3 --jump ACCEPT
-A FORWARD --protocol tcp --dport 443 --destination 10.0.0.2 --jump ACCEPT
-A FORWARD --protocol tcp --dport 443 --destination 10.0.0.3 --jump ACCEPT
COMMIT
</pre>


<p>On comprend bien qu'on va gagner du temps en scripting. Il faudra toujours écrire ses propres règles, mais elles seront "standardisées" et factorisées. Donc le <strong>transfert de compétence</strong> d'une personne à l'autre sera facilité. Le transfert de script aussi puisque ferm sait générer des scripts qui devront être poussés et lancés sur d'autres machines. Pratique pour ceux qui veulent une gestion centralisée des firewall de leurs serveurs/routeurs.</p>


<h3>Mieux</h3>

<p>Vous aurez remarqué que ferm génère des règles de type "sauvegarde iptables". Ce que je suis sur que vous ne faites pas dans vos script. Et pourtant c'est un gain de performance et de sécurité car l'ensemble des règles sera chargé en mémoire d'un coup.</p>


<p>De plus ferm gère lui-même le lancement du firewall au boot de la machine.</p>


<h3>La cerise</h3>

<p>Et si vous comptez passer à l'ipv6&nbsp;! Hé bien surtout ne faites rien&nbsp;! Réutilisez le même firewall, entourez vos règles de</p>
<pre>
domain (ip ip6) {
 ....
}
</pre>


<p>Et voila votre firewall dualstack est prêt.</p>
	Tags:<a href="http://linux-attitude.fr/tag/firewall" title="Firewall" rel="tag">Firewall</a>, <a href="http://linux-attitude.fr/tag/planet-libre" title="planet-libre" rel="tag">planet-libre</a>, <a href="http://linux-attitude.fr/tag/systeme" title="Système" rel="tag">Système</a><br />
]]></content:encoded>
			<wfw:commentRss>http://linux-attitude.fr/post/firewall-en-2-temps-3-mouvements/feed</wfw:commentRss>
		<slash:comments>7</slash:comments>
		</item>
		<item>
		<title>Traque sur internet</title>
		<link>http://linux-attitude.fr/post/traque-sur-internet</link>
		<comments>http://linux-attitude.fr/post/traque-sur-internet#comments</comments>
		<pubDate>Wed, 06 May 2009 23:36:00 +0000</pubDate>
		<dc:creator>peck</dc:creator>
				<category><![CDATA[Réseau]]></category>
		<category><![CDATA[Firewall]]></category>
		<category><![CDATA[planet-libre]]></category>

		<guid isPermaLink="false">http://linux-attitude.fr/post/traque-sur-internet</guid>
		<description><![CDATA[Niveau&#160;:    
Résumé&#160;: conntrack


I'm back !
Désolé de vous avoir fait attendre, j'étais en quelque sorte en vacances.


Firewall

Cette fois nous allons parler de firewall. Comme vous le savez, netfilter, le firewall intégré à linux, est statefull par défaut. Ce qui veut dire que si on ne lui dit pas de ne pas le faire, [...]]]></description>
			<content:encoded><![CDATA[<p><strong>Niveau</strong>&nbsp;: <img src="/public/Pics/s.gif" alt="Star" /> <img src="/public/Pics/s.gif" alt="Star" /> <img src="/public/Pics/s.gif" alt="Star" /><img src="/public/Pics/e.gif" alt="Empty" /> <img src="/public/Pics/e.gif" alt="Empty" /><br />
<strong>Résumé</strong>&nbsp;: conntrack</p>


<p>I'm back !<br />
Désolé de vous avoir fait attendre, j'étais en quelque sorte en vacances.</p>


<h3>Firewall</h3>

<p>Cette fois nous allons parler de firewall. Comme vous le savez, netfilter, le firewall intégré à linux, est statefull par défaut. Ce qui veut dire que si on ne lui dit pas de ne pas le faire, il trace l'état de toutes les connexions qui le traversent. C'est grâce à cela qu'il sait filtrer les connexions avec des règles "simples" ou qu'il est capable de filtrer proprement le ftp.</p>


<p>Pour cela il garde en mémoire une table des connexions établies, qu'il peut communiquer au reste du monde, autrement appelé espace utilisateur. Il expose ces infos dans /proc/net/ip_conntrack* (entre autre, mais n'hésitez pas à regarder le contenu de ce répertoire pour plein de choses intéressantes).</p>


<p>La commande conntrack, du paquet éponyme sert à manipuler la table en question. Toute machine ayant un firewall, ou presque, on peut s'amuser à l'utiliser sur son PC. Mais c'est bien plus rigolo de faire ça sur un routeur ;-&gt;</p>


<p>D'ailleurs, si vous avez un serveur qui ne fait pas firewall et qui gère beaucoup de connexions (un serveur de twitter par exemple), vous pouvez désactiver le "connection tracking" pour soulager le noyau de cette tâche. Mais il faut entièrement désactiver le module, ce qui n'est pas des plus simple.</p>


<h3>Conntrack</h3>


<p>D'abord, commençons par lister les connexions connues&nbsp;:</p>
<pre>
$ conntrack -L
</pre>


<p>Pour une machine qui ne fait pas routeur, la liste est similaire à celle obtenue par netstat -atu.
Notez les informations intéressantes&nbsp;: état de la connexion, détail de la connexion (remarquez la répétition nécessaire pour le NAT), et surtout nombre de paquets et d'octets passés par cette connexion. Ce compteur peut être réinitialisé avec l'option -z de conntrack&nbsp;:</p>
<pre>
$ conntrack -L -z
</pre>


<p>Pratique quand on veut détecter les changements.</p>


<p>Vous pouvez aussi regarder ce qui se passe en direct sur votre routeur&nbsp;:</p>
<pre>
$ conntrack -E
</pre>


<p>Mais lisez bien le manuel, pour limiter la sortie, car sur un vrai routeur, il faut filtrer. Man conntrack contient toutes les explications.</p>


<p>Et le plus rigolo sur un routeur partagé, on enlève l'entrée&nbsp;:</p>
<pre>
# Attention, il faut tout spécifier pour être sûr qu'on parle de la bonne connexion
$ conntrack -D -s 1.2.3.4 -d 4.3.2.1 -p tcp --orig-port-src 5678 --orig-port-dst 22
</pre>


<p>Cela devrait couper la connexion si le firewall est bien configuré (et probablement aussi s'il est mal configuré).
C'est tout de même moins artisanal que <a href="/post/Coupe-au-bol">l'ancienne technique</a>.</p>
	Tags:<a href="http://linux-attitude.fr/tag/firewall" title="Firewall" rel="tag">Firewall</a>, <a href="http://linux-attitude.fr/tag/planet-libre" title="planet-libre" rel="tag">planet-libre</a>, <a href="http://linux-attitude.fr/tag/reseau" title="Réseau" rel="tag">Réseau</a><br />
]]></content:encoded>
			<wfw:commentRss>http://linux-attitude.fr/post/traque-sur-internet/feed</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
	</channel>
</rss>

<!-- Performance optimized by W3 Total Cache. Learn more: http://www.w3-edge.com/wordpress-plugins/

Minified using disk
Page Caching using apc (user agent is rejected)
Database Caching 2/20 queries in 0.024 seconds using apc

Served from: linux-attitude.fr @ 2010-07-31 03:31:18 -->