开源IDS网络流量分析与监控系统Zeek对接GrayLog
一、 开源IDS网络流量分析与监控系统Zeek简单介绍
The Zeek Network Security Monitor:A powerful framework for network traffic analysis and security monitoring.
Zeek网络安全监控:是一款强大的网络流量分析和安全监控的框架 。
data:image/s3,"s3://crabby-images/40f07/40f07240f1601d1eea3e1b48362cae50debe3133" alt=""
- 1、深入分析:Zeek附带了许多协议的分析器,可实现在网络应用层的高级语义分析。
- 2、适应性强且灵活:Zeek的域特定脚本语言可实现特定于站点的监视策略,也意味着不限于任何特定检测方法。
- 3、高效性:Zeek以高性能网络为目标,并在很多各种大型站点上应用和运行。
- 4、高级状态性:Zeek保留有关其监控的网络应用层可扩展状态,并提供网络活动的高级存档功能。
官方文档
https://github.com/zeek/zeek
https://docs.zeek.org/
参考链接
https://blog.ossq.cn/2303.html
http://www.senlt.cn/article/171944181.html
https://blog.ossq.cn/2287.html
在阅读过《将 Zeek 与 ELK 栈集成》的这篇文章后 https://linux.cn/article-14770-1.html
data:image/s3,"s3://crabby-images/2b93a/2b93a8fa26d61d42adaf6b8f7cab8c6c77fb2670" alt=""
决定尝试是否可以将zeek的网络流量监控日志吐到GrayLog,并在GrayLog上进行呈现
具体实现思路,以及要解决的问题汇总
- 1、zeek的部署(能否rpm包的方式部署,编译部署太耗费时间)
- 2、流量镜像问题:zeek服务器的网卡如何配置混杂模式,交换机流量镜像如何配置
- 3、zeek的流量分析日志读取问题:zeek的日志转成json格式日志,使用graylog-sidecar+filebeat方式读取,并json提取器获取字段信息
- 4、GrayLog上查询,Dashboard配置
具体实践过程如下
二、下载zeek的CentOS7的rpm包并部署zeek
https://zeek.org/get-zeek/
由于网速问题,我这边手动提前下载好zeek相关的rpm依赖包
data:image/s3,"s3://crabby-images/be318/be3189b6b40c5bf639f6a6f70bcb83eaa21ae6b1" alt=""
data:image/s3,"s3://crabby-images/4ed5c/4ed5c6f6546b18f9c36a8ec1e95e7dd2fcc952f7" alt=""
data:image/s3,"s3://crabby-images/fe978/fe978cc821c599e87ac1ff4f98e43d813606870e" alt=""
data:image/s3,"s3://crabby-images/dda25/dda25ade19689b387277553d7385223a96966b29" alt=""
1、安装zeek
yum localinstall *.rpm
2、将/opt/zeek/bin目录加到PATH环境变量中
echo "PATH=$PATH:/opt/zeek/bin" >> /etc/profile
source /etc/profile
echo $PATH
3、将网卡设置成混杂模式
ifconfig ens33 promisc
交换机配置镜像流量的操作这里就不做演示,请参考这个链接中的文章自行探索,根据自身实际网络环境自行解决
https://blog.ossq.cn/2287.html
data:image/s3,"s3://crabby-images/3d48c/3d48cc7d0dc395a57bb746a8ceef98aa0f28240e" alt=""
data:image/s3,"s3://crabby-images/17668/17668678ef43bf64b8a46a94e1a91e94ea804fd1" alt=""
data:image/s3,"s3://crabby-images/94000/94000e367ffaebb2c9372b0880ea4a27d1dcdf11" alt=""
4、vim node.cfg
cd /opt/zeek/etc
vim node.cfg
修改interface为当前实际网卡
data:image/s3,"s3://crabby-images/bd3a4/bd3a4974c8688280f1dc55376a72c780dd4a9fe6" alt=""
5、vim local.zeek
cd /opt/zeek/share/zeek/site/
vim local.zeek
如下位置添加以下行:
@load policy/tuning/json-logs.zeek
data:image/s3,"s3://crabby-images/51790/51790e8bcfabd3094f4073e0523f5d1be571c6dc" alt=""
6、启动zeek
zeekctl
[ZeekControl] > deploy
data:image/s3,"s3://crabby-images/c564f/c564fad49122d5b2779577cce9dd13d01b995e80" alt=""
7、查看zeek的流量分析日志
cd /opt/zeek/logs/
cd current/
ll
目前均为json格式日志
data:image/s3,"s3://crabby-images/84217/84217c7173b850c5455e48b5251161629d7ec2d1" alt=""
三、部署graylog-sidecar+filebeat方式读取zeek的日志
1、下载并安装graylog-sidecar和filebeat的rpm包
https://github.com/Graylog2/collector-sidecar/releases
https://mirrors.cloud.tencent.com/elasticstack/7.x/yum/7.10.2/filebeat-7.10.2-x86_64.rpm
rpm -ivh filebeat-7.10.2-x86_64.rpm
rpm -ivh graylog-sidecar-1.3.0-1.x86_64.rpm
data:image/s3,"s3://crabby-images/816ab/816ab0a0a151d2e38151a58e3ccf12247a16d8fe" alt=""
data:image/s3,"s3://crabby-images/f8ff1/f8ff1626831d4edfa5011b816e75a364221c2863" alt=""
2、创建sidecar的token,及sidecar端的配置修改
vim /etc/graylog/sidecar/sidecar.yml
并修改如下5处的配置
server_url: "http://192.168.31.170:9000/api/"
server_api_token: "hkoa0tv9gl9u09drhtckjbdv90v98v5mor5jropo0p0741oib3g"
node_name: "zeek"
update_interval: 10
send_status: true
data:image/s3,"s3://crabby-images/9e810/9e810e1983de7ad4d2ac657b38efdf0c16fb3fa1" alt=""
data:image/s3,"s3://crabby-images/c757a/c757a48eef2e8990431d8fac1d48806475f6bbbc" alt=""
3、graylog-sidecar启动,并下发配置
graylog-sidecar -service install
graylog-sidecar -service start
data:image/s3,"s3://crabby-images/b5a20/b5a203a8caae4498840b5f426b36e0b9afee9a2a" alt=""
data:image/s3,"s3://crabby-images/77fed/77fed5ba7b2aaee9592a6420b5586c3e60564ee2" alt=""
data:image/s3,"s3://crabby-images/15ce8/15ce835cd935cb243df76c72d8f115dfc8216512" alt=""
4、Graylog上面配置Beat类型的Input
data:image/s3,"s3://crabby-images/5d7bf/5d7bfa154ce1972ceb8ab7d6d2b93c919048d83c" alt=""
防火墙开放5044端口
firewall-cmd --permanent --zone=public --add-port=5044/tcp
firewall-cmd --reload
5、确认是否收到日志
data:image/s3,"s3://crabby-images/55562/555627f1273277b9b1467d62e3a7247c4ac5d191" alt=""
四、Graylog上配置json格式字段提取并配置大屏
data:image/s3,"s3://crabby-images/e679e/e679e4f3bce639a6ee4cc9441217770eeb79b921" alt=""
data:image/s3,"s3://crabby-images/9970b/9970b01c34a3374713a803f38b38d6cdebce4e55" alt=""
data:image/s3,"s3://crabby-images/6c423/6c423c80fdb2f25d36a9c4940f3ad587717dd790" alt=""
data:image/s3,"s3://crabby-images/b52f7/b52f75f153a5222cfafbb05a78dc816fbbbef228" alt=""
data:image/s3,"s3://crabby-images/289b9/289b9d9a0e236bc7331841315a0628c5a8950d31" alt=""
data:image/s3,"s3://crabby-images/4324e/4324e2ef2f7d7bcf4526f7ce4d44b191bce4a223" alt=""
五、总结
1、本文中所用到的rpm安装包已全部打包,下载链接如下
链接:https://caiyun.139.com/m/i?165CkbChzt8CJ
提取码:yrBK
2、扩展
zeek流量日志如果可以的话,可以与微步API接口进行关联查询,这样可以实现异常DNS等其他流量检测与告警
参考之前的文章
GrayLog使用HTTP JSONPath方式调用微步在线云API识别威胁IP
data:image/s3,"s3://crabby-images/a8cb0/a8cb01ee740c3949e34461a5dbcf63d896d7e0e5" alt=""