为了账号安全,请及时绑定邮箱和手机立即绑定

在 Ubuntu 15.04 中如何安装和使用 Snort

对于网络安全而言入侵检测是一件非常重要的事。入侵检测系统(IDS)用于检测网络中非法与恶意的请求。Snort是一款知名的开源的入侵检测系统。其 Web界面(Snorby)可以用于更好地分析警告。Snort使用iptables/pf防火墙来作为入侵检测系统。本篇中,我们会安装并配置一个开源的入侵检测系统snort。

Snort 安装

要求

snort所使用的数据采集库(DAQ)用于一个调用包捕获库的抽象层。这个在snort上就有。下载过程如下截图所示。

downloading_daq

downloading_daq

解压并运行./configure、make、make install来安装DAQ。然而,DAQ要求其他的工具,因此,./configure脚本会生成下面的错误。

flex和bison错误

flexandbison_error

flexandbison_error

libpcap错误

libpcap error

libpcap error

因此在安装DAQ之前先安装flex/bison和libcap。

install_flex

install_flex

如下所示安装libpcap开发库

libpcap-dev installation

libpcap-dev installation

安装完必要的工具后,再次运行./configure脚本,将会显示下面的输出。

without_error_configure

without_error_configure

make和make install 命令的结果如下所示。

make install

make install

make

make

成功安装DAQ之后,我们现在安装snort。如下图使用wget下载它。

downloading_snort

downloading_snort

使用下面的命令解压安装包。

#tar -xvzf  snort-2.9.7.3.tar.gz

snort_extraction

snort_extraction

创建安装目录并在脚本中设置prefix参数。同样也建议启用包性能监控(PPM)的sourcefire标志。

#mkdir /usr/local/snort#./configure --prefix=/usr/local/snort/ --enable-sourcefire

snort_installation

snort_installation

配置脚本会由于缺少libpcre-dev、libdumbnet-dev 和zlib开发库而报错。

配置脚本由于缺少libpcre库报错。

pcre-error

pcre-error

配置脚本由于缺少dnet(libdumbnet)库而报错。

libdnt error

libdnt error

配置脚本由于缺少zlib库而报错

zlib error

zlib error

如下所示,安装所有需要的开发库。

# aptitude install libpcre3-dev

libpcre3-dev install

libpcre3-dev install

# aptitude install libdumbnet-dev

libdumnet-dev installation

libdumnet-dev installation

# aptitude install zlib1g-dev

zlibg-dev installation

zlibg-dev installation

安装完snort需要的库之后,再次运行配置脚本就不会报错了。

运行make和make install命令在/usr/local/snort目录下完成安装。

# make

make snort

make snort

# make install

make install snort

make install snort

最后,从/usr/local/snort/bin中运行snort。现在它对eth0的所有流量都处在promisc模式(包转储模式)。

snort running

snort running

如下图所示snort转储流量。

traffic

traffic

Snort的规则和配置

从源码安装的snort还需要设置规则和配置,因此我们需要复制规则和配置到/etc/snort下面。我们已经创建了单独的bash脚本来用于设置规则和配置。它会设置下面这些snort设置。

  • 在linux中创建用于snort IDS服务的snort用户。

  • 在/etc下面创建snort的配置文件和文件夹。

  • 权限设置并从源代码的etc目录中复制数据。

  • 从snort文件中移除规则中的#(注释符号)。

#!/bin/bash## snort源代码的路径snort_class="lazyload" src="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsQAAA7EAZUrDhsAAAANSURBVBhXYzh8+PB/AAffA0nNPuCLAAAAAElFTkSuQmCC" data-original="/home/test/Downloads/snort-2.9.7.3"echo "adding group and user for snort..."groupadd snort &> /dev/nulluseradd snort -r -s /sbin/nologin -d /var/log/snort -c snort_idps -g snort &> /dev/null#snort configurationecho "Configuring snort..."mkdir -p /etc/snortmkdir -p /etc/snort/rulestouch /etc/snort/rules/black_list.rulestouch /etc/snort/rules/white_list.rulestouch /etc/snort/rules/local.rulesmkdir /etc/snort/preproc_rulesmkdir /var/log/snortmkdir -p /usr/local/lib/snort_dynamicruleschmod -R 775 /etc/snortchmod -R 775 /var/log/snortchmod -R 775 /usr/local/lib/snort_dynamicruleschown -R snort:snort /etc/snortchown -R snort:snort /var/log/snortchown -R snort:snort /usr/local/lib/snort_dynamicrules###copy  configuration and rules from  etc directory under source code of snortecho "copying from snort source to /etc/snort ....."echo $snort_srcecho "-------------"cp $snort_src/etc/*.conf* /etc/snortcp $snort_src/etc/*.map /etc/snort##enable rulessed -i 's/include \$RULE\_PATH/#include \$RULE\_PATH/' /etc/snort/snort.confecho "---DONE---"

改变脚本中的snort源目录路径并运行。下面是成功的输出。

running script

running script

上面的脚本从snort源中复制下面的文件和文件夹到/etc/snort配置文件中

files copied

files copied

snort的配置非常复杂,要让IDS能正常工作需要进行下面必要的修改。

ipvar HOME_NET 192.168.1.0/24  # LAN side

ipvar EXTERNAL_NET !$HOME_NET   # WAN side

veriable set

veriable set

var RULE_PATH /etc/snort/rules     # snort signature pathvar SO_RULE_PATH /etc/snort/so_rules        #rules in shared librariesvar PREPROC_RULE_PATH /etc/snort/preproc_rules  # Preproces pathvar WHITE_LIST_PATH /etc/snort/rules        # dont scanvar BLACK_LIST_PATH /etc/snort/rules        #  Must scan

main path

main path

include $RULE_PATH/local.rules   # file for custom rules

移除ftp.rules、exploit.rules前面的注释符号(#)。

path rules

path rules

现在下载社区规则并解压到/etc/snort/rules。启用snort.conf中的社区及紧急威胁规则。

wget_rules

wget_rules

community rules

community rules

进行了上面的更改后,运行下面的命令来检验配置文件。

# snort -T -c /etc/snort/snort.conf

snort running

snort running

总结

本篇中,我们关注了开源IDPS系统snort在Ubuntu上的安装和配置。通常它用于监控事件,然而它可以被配置成用于网络保护的在线模式。snort规则可以在离线模式中可以使用pcap捕获文件进行测试和分析

编译自:http://linoxide.com/security/install-snort-usage-ubuntu-15-04/作者: nido
原创:LCTT https://linux.cn/article-6135-1.html译者: geekpi

点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
数据库工程师
手记
粉丝
42
获赞与收藏
203

关注作者,订阅最新文章

阅读免费教程

  • 推荐
  • 1
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消