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
snort_inline [Le 07/12/2009, 16:41]
psychederic
snort_inline [Le 11/09/2022, 11:51] (Version actuelle)
moths-art Suppression des espaces en fin de ligne (détecté et corrigé via le bot wiki-corrector (https://forum.ubuntu-fr.org/viewtopic.php?id=2067892)
Ligne 1: Ligne 1:
-{{tag>​sécurité pare-feu}}+{{tag>​sécurité pare-feu ​ips}}
 ---- ----
  
 ====== Snort Inline :  Système de prévention d'​intrusion ​ ====== ====== Snort Inline :  Système de prévention d'​intrusion ​ ======
 +{{http://​snort-inline.sourceforge.net/​images/​snort_inline_med.gif ​ }}
 +L'IPS Snort Inline est une version modifiée du fameux IDS [[Snort]] ([[http://​fr.wikipedia.org/​wiki/​Syst%C3%A8me_de_d%C3%A9tection_d%27intrusion|Système de détection d'​intrusion]]) pour en faire un IPS ([[http://​fr.wikipedia.org/​wiki/​Syst%C3%A8me_de_pr%C3%A9vention_d%27intrusion|Système de prévention d'​intrusion]] ), une solution capable de bloquer les intrusions/​attaques réseau.
  
-L'IPS Snort Inline est une version modifiée du fameux IDS [[Snort]] (Système de détection d'​intrusion) pour en faire un IPS (Système de prévention d'​intrusion ), une solution capable de bloquer les intrusions/​attaques réseau. +Il reçoit les paquets envoyés par le **firewall [[iptables|Netfilter]]** avec l'aide de la librairie libipq, les compare avec des règles de signature [[Snort]] et les marque en "​drop"​ s'ils correspondent à une règle, puis finalement les renvoie vers Netfilter où les paquets Snort_Inline marqués **sont rejetés**.
- +
-Il reçoit les paquets envoyés par le **firewall [[Netfilter]]** avec l'aide de la librairie libipq, les compare avec des règles de signature [[Snort]] et les marque en "​drop"​ s'ils correspondent à une règle, puis finalement les renvoie vers Netfilter où les paquets Snort_Inline marqués **sont rejetés**. ​+
  
 Site officiel : http://​snort-inline.sourceforge.net/​ Site officiel : http://​snort-inline.sourceforge.net/​
 +
 +Voir pour accompagner snort inline IPS reseau :
 +  * [[Ossec]] un IPS applicatif,
 +
 +{{ http://​openmaniak.com/​inline/​inline_netfilter.gif }}
  
 ===== Installation ===== ===== Installation =====
Ligne 16: Ligne 21:
 ==== 0) Paquets requis : ==== ==== 0) Paquets requis : ====
  
-<​code>​sudo apt-get install apache2 mysql-server php5 php5-mysql build-essential libpcre3-dev iptables-dev libnet0-dev libmysqlclient12-dev ​ libmysqlclient12-dev checkinstall libnet ​libnet-dev</​code>​+Ubuntu 9.10 karmic koala : <​code>​sudo apt-get install apache2 mysql-server php5 php5-mysql build-essential libpcre3-dev iptables-dev libnet1-dev libmysqlclient16-dev ​ checkinstall libnet1 libpcap-dev 
 +</​code>​ 
 + 
 +<​code>​sudo apt-get install libpcap0.8-dev libpcre3-dev libdumbnet-dev libprelude-dev libnetfilter-queue-dev 
 +</​code>​ 
 + 
 +<​code>​sudo apt-get install apache2 mysql-server php5 php5-mysql build-essential libpcre3-dev iptables-dev libnet0-dev libmysqlclient12-dev ​ libmysqlclient12-dev checkinstall libnet</​code>​ 
  
 Soyez attentif à ne pas installer libnet 1.1.x (package libnet1-dev). Sinon, comme indiqué sur le [[http://​snort-inline.sourceforge.net/​FAQ.html#​libnet|site web de Snort_Inline]],​ la compilation de Snort_Inline contre cette version de libnet ne fonctionnera pas. Soyez attentif à ne pas installer libnet 1.1.x (package libnet1-dev). Sinon, comme indiqué sur le [[http://​snort-inline.sourceforge.net/​FAQ.html#​libnet|site web de Snort_Inline]],​ la compilation de Snort_Inline contre cette version de libnet ne fonctionnera pas.
Ligne 36: Ligne 48:
  
 ==== 1) Téléchargement ==== ==== 1) Téléchargement ====
 +
 +Vous pouvez prendre le code du projet [[https://​sourceforge.net/​projects/​snort-inline/​|snort inline]], ou celui de [[https://​www.snort.org/​downloads|snort]] (> 2.8.5) qui a repris les sources de snort inline. L'​installation reste la même.
 +
 +Source du projet snort inline :
  
 <​code>​ <​code>​
Ligne 41: Ligne 57:
 version=2.6.1.5 version=2.6.1.5
  
-http://​prdownloads.sourceforge.net/​snort-inline/​snort_inline-$version.tar.gz?​download+wget http://​prdownloads.sourceforge.net/​snort-inline/​snort_inline-$version.tar.gz?​download
 tar -xvf snort_inline-$version.tar.gz tar -xvf snort_inline-$version.tar.gz
  
 echo "​stocker le fichier de configuration"​ echo "​stocker le fichier de configuration"​
-mkdir /​etc/​snort_inline+sudo mkdir /​etc/​snort_inline
  
 echo "​stocker les règles Snort" echo "​stocker les règles Snort"
-mkdir /​etc/​snort_inline/​rule+sudo mkdir /​etc/​snort_inline/​rules
  
 echo "​Copiez les fichiers de configurations"​ echo "​Copiez les fichiers de configurations"​
-cp snort_inline-$version/​etc/​* /​etc/​snort_inline/​+sudo cp snort_inline-$version/​etc/​* /​etc/​snort_inline/​
  
 </​code>​ </​code>​
Ligne 59: Ligne 75:
 <​code>​ <​code>​
 echo "​classification.config:​ définit des URLs pour les références trouvées dans les règles"​ echo "​classification.config:​ définit des URLs pour les références trouvées dans les règles"​
-cp snort_inline-$version/​etc/​classification.config /​etc/​snort_inline/​rules/​+sudo cp snort_inline-$version/​etc/​classification.config /​etc/​snort_inline/​rules/​
  
 echo "​reference.config:​ inclus de l'​information pour la priorité des règles."​ echo "​reference.config:​ inclus de l'​information pour la priorité des règles."​
-cp snort_inline-$version/​etc/​reference.config /​etc/​snort_inline/​rules/​+sudo cp snort_inline-$version/​etc/​reference.config /​etc/​snort_inline/​rules/​
  
 echo "​dossier de journalisation"​ echo "​dossier de journalisation"​
-mkdir /​var/​log/​snort_inline+sudo mkdir /​var/​log/​snort_inline
 </​code>​ </​code>​
  
 ==== 2) Paramétrer Mysql ==== ==== 2) Paramétrer Mysql ====
-Ajoutez un mot de passe MySQL pour l'​utilisateur root: +Ajoutez un mot de passe MySQL pour l'​utilisateur root:
 <​code>​ <​code>​
-mysqladmin -u root password new_root_password+echo "si vous n'avez pas installer de mot de pass pendant l'​installation de mysql"​ 
 +echo "mysqladmin -u root password new_root_password"
  
-echo "Créez la base de données"​ +echo "accès a mysql en root"
-echo "​create database snort;"+
 mysql -u root -p mysql -u root -p
 +
 +echo "​Créez la base de données"​
 +create database snort;
  
 echo "​créer un utilisateur pour snort" echo "​créer un utilisateur pour snort"
Ligne 89: Ligne 108:
 </​code>​ </​code>​
  
-Ouvrez le fichier snort_inline.conf:​ <​code>​#vi /​etc/​snort_inline/​snort_inline.conf</​code>​+Ouvrez le fichier snort_inline.conf:​ <​code>​sudo gedit /​etc/​snort_inline/​snort_inline.conf</​code>​
  
 Après la ligne avec "​output alert_fast: snort_inline-fast",​ ajoutez:<​code>​ Après la ligne avec "​output alert_fast: snort_inline-fast",​ ajoutez:<​code>​
 output database: log, mysql, user=snortuser password=snortpassword dbname=snort host=localhost ​ output database: log, mysql, user=snortuser password=snortpassword dbname=snort host=localhost ​
 </​code>​ </​code>​
 +
 ==== 3) Compilation de snort ==== ==== 3) Compilation de snort ====
 +
 +Pour snort (>2.8.5 ) :
 +<​code> ​
 +echo " ajouter les options de configuration que vous voulez exemple , support mysql, prelude ..."
 +./configure --enable-inline
 +make
 +make install
 +
 +</​code>​
 +
 +Pour snort inline :
 <​code>​ <​code>​
 echo "​Vérifier les dépendances et préparer l'​outil à être compilé pour MySQL."​ echo "​Vérifier les dépendances et préparer l'​outil à être compilé pour MySQL."​
 cd snort_inline-$version cd snort_inline-$version
 +echo "​./​configure --with-mysql
 +
 +echo "​compilation"​
 +make
 +
 +checkinstall
 +</​code>​
 +
 +Pour la version 2.6.1.5 , nécessite [[http://​www.wzdftpd.net/​trac/​attachment/​wiki/​Misc/​PreludeSnort/​dumbnet.diff?​format=raw|un patch]] ([[http://​sharebee.com/​ff8268d8|miroir]]) :<​code>​
 +cd snort_inline-2.6.1.5
 +
 +patch -p1 < ../​dumbnet.diff
 +./​autojunk.sh
 +
 ./configure --with-mysql ./configure --with-mysql
  
Ligne 105: Ligne 150:
 checkinstall checkinstall
 </​code>​ </​code>​
 +((./​configure ​ --enable-nfnetlink --with-dumbnet --enable-inline-init-failopen
 +))
  
 ====4) Ajout de règles ==== ====4) Ajout de règles ====
Ligne 117: Ligne 164:
 === Site officiel de snort === === Site officiel de snort ===
  
-  * [[http://​www.snort.org/​|Site officiel de snort]] : Pour télécharger les règles Snort, nous avons besoin de créer un compte gratuit sur le  site web de Snort. Une fois connecté avec votre compte Snort, vous pouvez obtenir un code en bas de page.+  * [[https://​www.snort.org/​|Site officiel de snort]] : Pour télécharger les règles Snort, nous avons besoin de créer un compte gratuit sur le  site web de Snort. Une fois connecté avec votre compte Snort, vous pouvez obtenir un code en bas de page.
  
-Ouvrir le fichier /​etc/​oinkmaster.conf :<​code>​sudo gedit /​etc/​oinkmaster.conf<​code>​+Ouvrir le fichier /​etc/​oinkmaster.conf :<​code>​sudo gedit /​etc/​oinkmaster.conf<​/code>
  
-Modifiez le paramètre "​url"​ : <​code>​url = http://​www.snort.org/​pub-bin/​oinkmaster.cgi/​code/​snortrules-snapshot-2.4.tar.gz</​code>​+Modifiez le paramètre "​url"​ : <​code>​url = https://​www.snort.org/​pub-bin/​oinkmaster.cgi/​code/​snortrules-snapshot-2.4.tar.gz</​code>​
  
 Ajoutez la ligne suivante: <​code>​modifysid * "​^alert"​ | "​drop"​ </​code>​ Ajoutez la ligne suivante: <​code>​modifysid * "​^alert"​ | "​drop"​ </​code>​
Ligne 177: Ligne 224:
   * (en) [[http://​www.bleedingsnort.com/​|Bleedingsnort]]   * (en) [[http://​www.bleedingsnort.com/​|Bleedingsnort]]
  
-===== Configuration ​=====+===== Outils de monitoring ​===== 
 +==== Prelude ==== 
 + 
 +[[Prelude]],​ voir [[https://​www.wzdftpd.net/​redmine/​projects/​wzdftpd/​wiki/​MiscPreludeSnort|le tutoriel]]. 
 + 
 +Il n'y a qu'à configurer diffèrément : <​code>​./​configure ​ --enable-nfnetlink ​ --prefix=/​opt/​snort-inline --enable-prelude ​  ​--enable-inline-init-failopen --with-dumbnet 
 +make 
 +</​code>​  
  
 =====Liens ===== =====Liens =====
 +
 +  * [[https://​www.snort.org/​assets/​120/​snort_manual.pdf|Documentation officiel]] (pdf) (anglais)
 +
 Gazette Linux n°118 — Septembre 2005 (traduction en français) : Gazette Linux n°118 — Septembre 2005 (traduction en français) :
-  * [[http://​ftp.traduc.org/​doc-vf/​gazette-linux/​html/​2005/​117/​lg117-G.html|Snort Inline — Première partie]] +  * [[https://​ftp.traduc.org/​doc-vf/​gazette-linux/​html/​2005/​117/​lg117-G.html|Snort Inline — Première partie]] 
-  * [[http://​ftp.traduc.org/​doc-vf/​gazette-linux/​html/​2005/​118/​lg118-F.html|Snort Inline — Deuxième partie]]+  * [[https://​ftp.traduc.org/​doc-vf/​gazette-linux/​html/​2005/​118/​lg118-F.html|Snort Inline — Deuxième partie]]
  
-  * [[http://​tldp.org/​LDP/​LGNET/​118/​savage.html|(en)Snort Inline Part II]]+  * [[https://​tldp.org/​LDP/​LGNET/​118/​savage.html|(en)Snort Inline Part II]]
  
 +  * [[http://​www.unixgarden.com/​index.php/​news/​gnulinux-magazine-hs-n%C2%B041-avrilmai-2009-chez-votre-marchand-de-journaux|GNU/​Linux Magazine HS N°41 – AVRIL/MAI 2009]]
  
 +  * [[http://​andika-lives-here.blogspot.com/​2009/​12/​build-snort-inline-in-ubuntu-910.html|Build snort inline in Ubuntu 9.10]]
 +  * [[http://​www.linux-pour-lesnuls.com/​snortinline.php|Installation de Snort Inline,]]
 ---- ----
 **Contributeurs principaux :** //​[[:​utilisateurs:​psychederic|Psychederic]]//​ **Contributeurs principaux :** //​[[:​utilisateurs:​psychederic|Psychederic]]//​
  • snort_inline.1260200479.txt.gz
  • Dernière modification: Le 07/12/2009, 16:41
  • (modification externe)