mirror of
https://github.com/LCTT/TranslateProject.git
synced 2025-02-19 00:30:12 +08:00
208 lines
8.3 KiB
Markdown
208 lines
8.3 KiB
Markdown
在 Ubuntu 15.04 中如何安装和使用 Snort
|
||
================================================================================
|
||
|
||
对于网络安全而言入侵检测是一件非常重要的事。入侵检测系统(IDS)用于检测网络中非法与恶意的请求。Snort是一款知名的开源的入侵检测系统。其 Web界面(Snorby)可以用于更好地分析警告。Snort使用iptables/pf防火墙来作为入侵检测系统。本篇中,我们会安装并配置一个开源的入侵检测系统snort。
|
||
|
||
### Snort 安装 ###
|
||
|
||
#### 要求 ####
|
||
|
||
snort所使用的数据采集库(DAQ)用于一个调用包捕获库的抽象层。这个在snort上就有。下载过程如下截图所示。
|
||
|
||
data:image/s3,"s3://crabby-images/4ca8d/4ca8df5794b1fc38cae4f0a27c5e2a6c907e38bd" alt="downloading_daq"
|
||
|
||
解压并运行./configure、make、make install来安装DAQ。然而,DAQ要求其他的工具,因此,./configure脚本会生成下面的错误。
|
||
|
||
flex和bison错误
|
||
|
||
data:image/s3,"s3://crabby-images/ab37c/ab37ca152405201fae72fdb1fced491f1d2a843c" alt="flexandbison_error"
|
||
|
||
libpcap错误
|
||
|
||
data:image/s3,"s3://crabby-images/75161/751611b9cd0e1f05fdff791ce4cc8d9abd29d450" alt="libpcap error"
|
||
|
||
因此在安装DAQ之前先安装flex/bison和libcap。
|
||
|
||
data:image/s3,"s3://crabby-images/638f4/638f41eb520de4b6bc9732755dd76cd374167564" alt="install_flex"
|
||
|
||
如下所示安装libpcap开发库
|
||
|
||
data:image/s3,"s3://crabby-images/c43c5/c43c57a24b095ea2c0806e90bd11ef5213aeddc1" alt="libpcap-dev installation"
|
||
|
||
安装完必要的工具后,再次运行./configure脚本,将会显示下面的输出。
|
||
|
||
data:image/s3,"s3://crabby-images/a3307/a330761f207f929e9b6ab905e974ed858a1afa01" alt="without_error_configure"
|
||
|
||
make和make install 命令的结果如下所示。
|
||
|
||
data:image/s3,"s3://crabby-images/c0a4b/c0a4b86f7b58c05024ac296d4431575ee0b2727d" alt="make install"
|
||
|
||
data:image/s3,"s3://crabby-images/df96d/df96df73c94fd991771c8adc1ad49c474758984f" alt="make"
|
||
|
||
成功安装DAQ之后,我们现在安装snort。如下图使用wget下载它。
|
||
|
||
data:image/s3,"s3://crabby-images/c8bd6/c8bd66dbc43c8d4d3e79f549221f4dae6f3a6dc1" alt="downloading_snort"
|
||
|
||
使用下面的命令解压安装包。
|
||
|
||
#tar -xvzf snort-2.9.7.3.tar.gz
|
||
|
||
data:image/s3,"s3://crabby-images/52821/528216a6ed5b474af7ffc9c937f76eccbc7bf3bd" alt="snort_extraction"
|
||
|
||
创建安装目录并在脚本中设置prefix参数。同样也建议启用包性能监控(PPM)的sourcefire标志。
|
||
|
||
#mkdir /usr/local/snort
|
||
|
||
#./configure --prefix=/usr/local/snort/ --enable-sourcefire
|
||
|
||
data:image/s3,"s3://crabby-images/57c2c/57c2cc8855392b867c5b1dafa53a43ef8c85d088" alt="snort_installation"
|
||
|
||
配置脚本会由于缺少libpcre-dev、libdumbnet-dev 和zlib开发库而报错。
|
||
|
||
配置脚本由于缺少libpcre库报错。
|
||
|
||
data:image/s3,"s3://crabby-images/cfae9/cfae9c0eb76c16d6e598913ae66556078077ac2a" alt="pcre-error"
|
||
|
||
配置脚本由于缺少dnet(libdumbnet)库而报错。
|
||
|
||
data:image/s3,"s3://crabby-images/36fe3/36fe34c07159c965dc753d31bcf8b00525507056" alt="libdnt error"
|
||
|
||
配置脚本由于缺少zlib库而报错
|
||
|
||
data:image/s3,"s3://crabby-images/c6635/c66357a5118bd12ffa1352b3821a3457089993b9" alt="zlib error"
|
||
|
||
如下所示,安装所有需要的开发库。
|
||
|
||
# aptitude install libpcre3-dev
|
||
|
||
data:image/s3,"s3://crabby-images/0145e/0145e4b1358ccde64625cd4b7f4471ca0f1480e5" alt="libpcre3-dev install"
|
||
|
||
# aptitude install libdumbnet-dev
|
||
|
||
data:image/s3,"s3://crabby-images/fc874/fc8747a4fdf5dd52b1a3bd0d321bf577949833e6" alt="libdumnet-dev installation"
|
||
|
||
# aptitude install zlib1g-dev
|
||
|
||
data:image/s3,"s3://crabby-images/2dbbb/2dbbbc6b3d5f121eb37c854db38d18f542705dbb" alt="zlibg-dev installation"
|
||
|
||
安装完snort需要的库之后,再次运行配置脚本就不会报错了。
|
||
|
||
运行make和make install命令在/usr/local/snort目录下完成安装。
|
||
|
||
#make
|
||
|
||
data:image/s3,"s3://crabby-images/626fd/626fdcafb44c2fbc13e5f83db8cca25f38877023" alt="make snort"
|
||
|
||
#make install
|
||
|
||
data:image/s3,"s3://crabby-images/9db1d/9db1d0b85bcf5861e3aa797dccdcbd39abf0175f" alt="make install snort"
|
||
|
||
最后,从/usr/local/snort/bin中运行snort。现在它对eth0的所有流量都处在promisc模式(包转储模式)。
|
||
|
||
data:image/s3,"s3://crabby-images/b0c7b/b0c7b1d47f5e69327eb138d328c4edf9165cb0d8" alt="snort running"
|
||
|
||
如下图所示snort转储流量。
|
||
|
||
data:image/s3,"s3://crabby-images/b2e36/b2e36713072b979e1f553e18ef47ca7f3ff08ab7" alt="traffic"
|
||
|
||
#### Snort的规则和配置 ####
|
||
|
||
从源码安装的snort还需要设置规则和配置,因此我们需要复制规则和配置到/etc/snort下面。我们已经创建了单独的bash脚本来用于设置规则和配置。它会设置下面这些snort设置。
|
||
|
||
- 在linux中创建用于snort IDS服务的snort用户。
|
||
- 在/etc下面创建snort的配置文件和文件夹。
|
||
- 权限设置并从源代码的etc目录中复制数据。
|
||
- 从snort文件中移除规则中的#(注释符号)。
|
||
|
||
-
|
||
|
||
#!/bin/bash#
|
||
# 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源目录路径并运行。下面是成功的输出。
|
||
|
||
data:image/s3,"s3://crabby-images/282ec/282ecb7f636cf41afae4e3e6fe41de8fb8f3745f" alt="running script"
|
||
|
||
上面的脚本从snort源中复制下面的文件和文件夹到/etc/snort配置文件中
|
||
|
||
data:image/s3,"s3://crabby-images/ed5d8/ed5d8c6a28eb81ba43bf916d2d6ee092cbc180e9" alt="files copied"
|
||
|
||
snort的配置非常复杂,要让IDS能正常工作需要进行下面必要的修改。
|
||
|
||
ipvar HOME_NET 192.168.1.0/24 # LAN side
|
||
|
||
----------
|
||
|
||
ipvar EXTERNAL_NET !$HOME_NET # WAN side
|
||
|
||
data:image/s3,"s3://crabby-images/eccd5/eccd55d249727dd22e1c1ec51cb712198dbda45f" alt="veriable set"
|
||
|
||
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
|
||
|
||
data:image/s3,"s3://crabby-images/4704d/4704da4283ca04bf465aff558fde7723ae09c6f5" alt="main path"
|
||
|
||
include $RULE_PATH/local.rules # file for custom rules
|
||
|
||
移除ftp.rules、exploit.rules前面的注释符号(#)。
|
||
|
||
data:image/s3,"s3://crabby-images/e6d79/e6d7952d0a28dbf4a9a3108a7251ad6f4d2c6225" alt="path rules"
|
||
|
||
现在[下载社区规则][1]并解压到/etc/snort/rules。启用snort.conf中的社区及紧急威胁规则。
|
||
|
||
data:image/s3,"s3://crabby-images/7024d/7024d5b92d741d5e32053aa37ba2501620b84b21" alt="wget_rules"
|
||
|
||
data:image/s3,"s3://crabby-images/8b571/8b571097cb72b26c8d95ad29b56481979b4bb3bd" alt="community rules"
|
||
|
||
进行了上面的更改后,运行下面的命令来检验配置文件。
|
||
|
||
#snort -T -c /etc/snort/snort.conf
|
||
|
||
data:image/s3,"s3://crabby-images/1108d/1108d0ee7ce27552b56b082d511d30211980773d" alt="snort running"
|
||
|
||
### 总结 ###
|
||
|
||
本篇中,我们关注了开源IDPS系统snort在Ubuntu上的安装和配置。通常它用于监控事件,然而它可以被配置成用于网络保护的在线模式。snort规则可以在离线模式中可以使用pcap捕获文件进行测试和分析
|
||
|
||
--------------------------------------------------------------------------------
|
||
|
||
via: http://linoxide.com/security/install-snort-usage-ubuntu-15-04/
|
||
|
||
作者:[nido][a]
|
||
译者:[geekpi](https://github.com/geekpi)
|
||
校对:[wxy](https://github.com/wxy)
|
||
|
||
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](https://linux.cn/) 荣誉推出
|
||
|
||
[a]:http://linoxide.com/author/naveeda/
|
||
[1]:https://www.snort.org/downloads/community/community-rules.tar.gz
|