8.2 KiB
在Ubuntu 15.04中如何安装和使用Snort
对于IT安全而言入侵检测是一件非常重要的事。入侵检测系统用于检测网络中非法与恶意的请求。Snort是一款知名的开源入侵检测系统。Web界面(Snorby)可以用于更好地分析警告。Snort使用iptables/pf防火墙来作为入侵检测系统。本篇中,我们会安装并配置一个开源的IDS系统snort。
Snort 安装
要求
snort所使用的数据采集库(DAQ)用于抽象地调用采集库。这个在snort上就有。下载过程如下截图所示。
解压并运行./configure、make、make install来安装DAQ。然而,DAQ要求其他的工具,因此,./configure脚本会生成下面的错误。
flex和bison错误
libpcap错误
因此在安装DAQ之前先安装flex/bison和libcap。
如下所示安装libpcap开发库
安装完必要的工具后,再次运行./configure脚本,将会显示下面的输出。
make和make install 命令的结果如下所示。
成功安装DAQ之后,我们现在安装snort。如下图使用wget下载它。
使用下面的命令解压安装包。
#tar -xvzf snort-2.9.7.3.tar.gz
创建安装目录并在脚本中设置prefix参数。同样也建议启用包性能监控(PPM)标志。
#mkdir /usr/local/snort
#./configure --prefix=/usr/local/snort/ --enable-sourcefire
配置脚本由于缺少libpcre-dev、libdumbnet-dev 和zlib开发库而报错。
配置脚本由于缺少libpcre库报错。
配置脚本由于缺少dnet(libdumbnet)库而报错。
配置脚本由于缺少zlib库而报错
如下所示,安装所有需要的开发库。
# aptitude install libpcre3-dev
# aptitude install libdumbnet-dev
# aptitude install zlib1g-dev
安装完snort需要的库之后,再次运行配置脚本就不会报错了。
运行make和make install命令在/usr/local/snort目录下完成安装。
#make
#make install
最终snort在/usr/local/snort/bin中运行。现在它对eth0的所有流量都处在promisc模式(包转储模式)。
如下图所示snort转储流量。
Snort的规则和配置
从源码安装的snort需要规则和安装配置,因此我们会从/etc/snort下面复制规则和配置。我们已经创建了单独的bash脚本来用于规则和配置。它会设置下面这些snort设置。
-
在linux中创建snort用户用于snort IDS服务。
-
在/etc下面创建snort的配置文件和文件夹。
-
权限设置并从etc中复制snortsnort源代码
-
从snort文件中移除规则中的#(注释符号)。
#!/bin/bash##PATH of source code of snort snort_src="/home/test/Downloads/snort-2.9.7.3" echo "adding group and user for snort..." groupadd snort &> /dev/null useradd snort -r -s /sbin/nologin -d /var/log/snort -c snort_idps -g snort &> /dev/null#snort configuration echo "Configuring snort..."mkdir -p /etc/snort mkdir -p /etc/snort/rules touch /etc/snort/rules/black_list.rules touch /etc/snort/rules/white_list.rules touch /etc/snort/rules/local.rules mkdir /etc/snort/preproc_rules mkdir /var/log/snort mkdir -p /usr/local/lib/snort_dynamicrules chmod -R 775 /etc/snort chmod -R 775 /var/log/snort chmod -R 775 /usr/local/lib/snort_dynamicrules chown -R snort:snort /etc/snort chown -R snort:snort /var/log/snort chown -R snort:snort /usr/local/lib/snort_dynamicrules ###copy configuration and rules from etc directory under source code of snort echo "copying from snort source to /etc/snort ....." echo $snort_src echo "-------------" cp $snort_src/etc/.conf /etc/snort cp $snort_src/etc/*.map /etc/snort##enable rules sed -i 's/include $RULE_PATH/#include $RULE_PATH/' /etc/snort/snort.conf echo "---DONE---"
改变脚本中的snort源目录并运行。下面是成功的输出。
上面的脚本从snort源中复制下面的文件/文件夹到/etc/snort配置文件中
、snort的配置非常复杂,然而为了IDS能正常工作需要进行下面必要的修改。
ipvar HOME_NET 192.168.1.0/24 # LAN side
ipvar EXTERNAL_NET !$HOME_NET # WAN side
var RULE_PATH /etc/snort/rules # snort signature path
var SO_RULE_PATH /etc/snort/so_rules #rules in shared libraries
var PREPROC_RULE_PATH /etc/snort/preproc_rules # Preproces path
var WHITE_LIST_PATH /etc/snort/rules # dont scan
var BLACK_LIST_PATH /etc/snort/rules # Must scan
include $RULE_PATH/local.rules # file for custom rules
移除ftp.rules、exploit.rules前面的注释符号(#)。
下载下载社区规则并解压到/etc/snort/rules。启用snort.conf中的社区及紧急威胁规则。
进行了上面的更改后,运行下面的命令来检验配置文件。
#snort -T -c /etc/snort/snort.conf
总结
本篇中,我们致力于开源IDPS系统snort在Ubuntu上的安装和配置。默认它用于监控时间,然而它可以被配置成用于网络保护的内联模式。snort规则可以在离线模式中可以使用pcap文件测试和分析
via: http://linoxide.com/security/install-snort-usage-ubuntu-15-04/