Suricata的IPS模式研究

1.IPS模式说明

suricata具有IDS的功能外,还具有IPS功能,所谓的IPS即是Intrusion Prevention System(入侵防护系统),对不符合配置规则的报文进行直接阻断。
suricata的阻断功能,是其本身所不具备的,只是通过和linux下通用的网络防火墙iptables/netfilter的联通来达到阻断网络的目的。
suricata的IPS分为两种:
1)drop:
包含签名的数据包立即被丢弃,不会再发送。 接收器不会收到导致超时的消息。 流的所有后续数据包都被丢弃。(实际测试http,用浏览器仍然可以访问,wget却不能访问)
2)reject:
主动拒绝数据包,接收者和发送者都会收到一个拒绝数据包。 如果数据包涉及TCP,则它将成为重置数据包,否则将成为所有其他协议的ICMP错误数据包。
NFQ支持多个队列处理,您应该在iptables规则和suricata命令行选项中明确指定。 例如,您可以使用NFQ配置负载平衡,如下所示:

iptables -A INPUT -j NFQUEUE --queue-balance 0:3
suricata -c /etc/suricata/suricata.yaml -q 0 -q 1 -q 2 -q 3

2. 原理

通过iptables 将网络报文发送到特定的队列中去,放入到用户态中,然后通过suricata进行规则匹配,最后返回对报文的处理,是丢弃还是接受。
在iptables中,一般在iptables中的target有以下五种(ACCEPT,DROP,RETURN,QUEUE,other_chain)而NFQUEUE是QUEUE的扩展。相比于QUEUE,它可以由用户指定不同的queue number。
示例:
比如做如下配置:
iptables -I FORWARD -j NFQUEUE --queue-num 0
suricata通过如下方式运行:
suricata -c /etc/suricata/suricata.yaml -q 0
操作0 号队列中的数据。
示例图:

image.png

模式:
1)图1的suricata 是运行在网关上,则可以通过和iptables联动,来阻止非法或攻击链接。
2)图2的suricata 是运行在主机上,通过对主机的进出报文进行控制,来达到阻断链接的目的。
网关场景向Suricata发送流量的最简单规则是:

 iptables -I FORWARD -j NFQUEUE

主机场景向Suricata发送流量的简单规则是:

sudo iptables -I INPUT -j NFQUEUE
sudo iptables -I OUTPUT -j NFQUEUE

可以提供队列的号,如果不提供,那么默认的是队列号为0。
假设您希望Suricata检查例如TCP流量,或端口80上的所有传入流量,或目标端口80上的所有流量,您可以这样做:

sudo iptables -I INPUT -p tcp --sport 80  -j NFQUEUE
sudo iptables -I OUTPUT -p tcp --dport 80 -j NFQUEUE
网关或主机上图示

对iptables的使用的描述是将其与IPv4一起使用的方式。 要在IPv6中使用它,所有前面提到的命令都必须以'ip6tables'开头。 也可以让Suricata检查两种流量。
还有一种方法可以使用iptables与多个网络(和接口卡)。 例:


多个网卡
sudo iptables -I FORWARD -i eth0 -o eth1 -j NFQUEUE
sudo iptables -I FORWARD -i eth1 -o eth0 -j NFQUEUE

如果你停止Suricata和使用互联网,交通将不会通过。 为了使互联网正常工作,你必须擦除所有的iptable规则。
要清除所有的iptable规则,请输入:
iptables -F

3 实践

1) 首先要确定安装的suricata是否支持IPS模式,在里面即为NFQ中。
通过命令:suricata --build-info


NFQ支持确认

2)需要在配置的时候提供选项

./configure --enable-nfqueue
--prefix=/usr --sysconfdir=/etc --localstatedir=/var
--enable-lua
重点是enable-nfqueue 需要
开启这项功能需要用到这两个包:libnetfilter_queuelibnfnetlink

安装后仍然报错:

configure: error: Package requirements (libnfnetlink >= 0.0.41) were not met:

设置一个环境变量,后继续运行:

export PKG_CONFIG_PATH=/usr/local/lib/pkgconfig:$PKG_CONFIG_PATH

仍然缺少库,编译后重新运行:

configure: error: Package requirements (libmnl >= 1.0.3) were not met:

No package 'libmnl' found

下载:http://www.netfilter.org/projects/libmnl/downloads.html

发现有点问题,找到rpm包直接安装:

rpm -Uvh http://rules.emergingthreatspro.com/projects/emergingrepo/x86_64/libnetfilter_queue-0.0.17-2.x86_64.rpm
http://rules.emergingthreatspro.com/projects/emergingrepo/x86_64/libnetfilter_queue-devel-0.0.17-2.x86_64.rpm
http://rules.emergingthreatspro.com/projects/emergingrepo/x86_64/libnfnetlink-1.0.0-1.x86_64.rpm
http://rules.emergingthreatspro.com/projects/emergingrepo/x86_64/libnfnetlink-devel-1.0.0-1.x86_64.rpm

编译后安装,再次查看:


image.png

3)验证阻断功能:
新建:test.rules


image.png

更改配置文件:suricata.yaml 将配置文件添加进去:


image.png
配置后,可以看到捕获记录,不过实际测试并没有断开连接,仍然可以正常使用。
用wget则无法下载。

四、参考网址

https://docs.mirantis.com/mcp/1.0/mcp-security-best-practices/use-cases/idps-vnf/install-idps.html

http://blog.csdn.net/leeboy_wang/article/details/50582629
https://linux.cn/article-6985-1.html
http://maskray.me/blog/2013-07-26-ids-ips-with-suricata
https://home.regit.org/netfilter-en/using-nfqueue-and-libnetfilter_queue/
https://redmine.openinfosecfoundation.org/projects/suricata/wiki/Ubuntu_Installation

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,332评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,508评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,812评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,607评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,728评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,919评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,071评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,802评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,256评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,576评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,712评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,389评论 4 332
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,032评论 3 316
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,798评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,026评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,473评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,606评论 2 350

推荐阅读更多精彩内容