首页
学习
活动
专区
圈层
工具
发布
社区首页 >专栏 >【实践】开源IDS网络流量分析与监控系统Zeek对接GrayLog

【实践】开源IDS网络流量分析与监控系统Zeek对接GrayLog

作者头像
yuanfan2012
发布2023-02-23 16:20:44
发布2023-02-23 16:20:44
6K1
举报
文章被收录于专栏:WalkingCloudWalkingCloud

一、 开源IDS网络流量分析与监控系统Zeek简单介绍

代码语言:javascript
复制
The Zeek Network Security Monitor:A powerful framework for network traffic analysis and security monitoring.

Zeek网络安全监控:是一款强大的网络流量分析和安全监控的框架 。

  • 1、深入分析:Zeek附带了许多协议的分析器,可实现在网络应用层的高级语义分析。
  • 2、适应性强且灵活:Zeek的域特定脚本语言可实现特定于站点的监视策略,也意味着不限于任何特定检测方法。
  • 3、高效性:Zeek以高性能网络为目标,并在很多各种大型站点上应用和运行。
  • 4、高级状态性:Zeek保留有关其监控的网络应用层可扩展状态,并提供网络活动的高级存档功能。

官方文档

代码语言:javascript
复制
https://github.com/zeek/zeek
https://docs.zeek.org/

参考链接

代码语言:javascript
复制
https://linux.cn/article-14770-1.html
http://www.senlt.cn/article/171944181.html
https://blog.csdn.net/u013613428/article/details/110728269

在阅读过《将 Zeek 与 ELK 栈集成》的这篇文章后 https://linux.cn/article-14770-1.html

决定尝试是否可以将zeek的网络流量监控日志吐到GrayLog,并在GrayLog上进行呈现

具体实现思路,以及要解决的问题汇总

  • 1、zeek的部署(能否rpm包的方式部署,编译部署太耗费时间)
  • 2、流量镜像问题:zeek服务器的网卡如何配置混杂模式,交换机流量镜像如何配置
  • 3、zeek的流量分析日志读取问题:zeek的日志转成json格式日志,使用graylog-sidecar+filebeat方式读取,并json提取器获取字段信息
  • 4、GrayLog上查询,Dashboard配置

具体实践过程如下

二、下载zeek的CentOS7的rpm包并部署zeek

代码语言:javascript
复制
https://zeek.org/get-zeek/

由于网速问题,我这边手动提前下载好zeek相关的rpm依赖包

1、安装zeek

代码语言:javascript
复制
yum localinstall *.rpm

2、将/opt/zeek/bin目录加到PATH环境变量中

代码语言:javascript
复制
echo "PATH=$PATH:/opt/zeek/bin" >> /etc/profile
source /etc/profile
echo $PATH

3、将网卡设置成混杂模式

代码语言:javascript
复制
ifconfig ens33 promisc 

交换机配置镜像流量的操作这里就不做演示,请参考这个链接中的文章自行探索,根据自身实际网络环境自行解决

代码语言:javascript
复制
https://blog.csdn.net/u013613428/article/details/110728269

4、vim node.cfg

代码语言:javascript
复制
cd /opt/zeek/etc
vim node.cfg
修改interface为当前实际网卡

5、vim local.zeek

代码语言:javascript
复制
cd /opt/zeek/share/zeek/site/
vim local.zeek 

如下位置添加以下行:
@load policy/tuning/json-logs.zeek

6、启动zeek

代码语言:javascript
复制
zeekctl 
[ZeekControl] > deploy

7、查看zeek的流量分析日志

代码语言:javascript
复制
cd /opt/zeek/logs/
cd current/
ll

目前均为json格式日志

三、部署graylog-sidecar+filebeat方式读取zeek的日志

1、下载并安装graylog-sidecar和filebeat的rpm包

代码语言:javascript
复制
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 

2、创建sidecar的token,及sidecar端的配置修改

代码语言:javascript
复制
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

3、graylog-sidecar启动,并下发配置

代码语言:javascript
复制
graylog-sidecar -service install
graylog-sidecar -service start

4、Graylog上面配置Beat类型的Input

防火墙开放5044端口

代码语言:javascript
复制
firewall-cmd --permanent --zone=public --add-port=5044/tcp
firewall-cmd --reload

5、确认是否收到日志

四、Graylog上配置json格式字段提取并配置大屏

五、总结

1、本文中所用到的rpm安装包已全部打包,下载链接如下

代码语言:javascript
复制
链接:https://share.weiyun.com/knIqb1EA 密码:bk2un9

2、扩展

zeek流量日志如果可以的话,可以与微步API接口进行关联查询,这样可以实现异常DNS等其他流量检测与告警

参考之前的文章

GrayLog使用HTTP JSONPath方式调用微步在线云API识别威胁IP

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2023-01-07,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 WalkingCloud 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 一、 开源IDS网络流量分析与监控系统Zeek简单介绍
    • 官方文档
    • 参考链接
  • 二、下载zeek的CentOS7的rpm包并部署zeek
    • 1、安装zeek
    • 2、将/opt/zeek/bin目录加到PATH环境变量中
    • 3、将网卡设置成混杂模式
    • 4、vim node.cfg
    • 5、vim local.zeek
    • 6、启动zeek
    • 7、查看zeek的流量分析日志
  • 三、部署graylog-sidecar+filebeat方式读取zeek的日志
    • 1、下载并安装graylog-sidecar和filebeat的rpm包
    • 2、创建sidecar的token,及sidecar端的配置修改
    • 3、graylog-sidecar启动,并下发配置
    • 4、Graylog上面配置Beat类型的Input
      • 5、确认是否收到日志
  • 四、Graylog上配置json格式字段提取并配置大屏
  • 五、总结
    • 1、本文中所用到的rpm安装包已全部打包,下载链接如下
    • 2、扩展
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档