写一个Linux服务器自动tcpdum抓包脚本

1、写一个定时tcpdump抓包的sh脚本,方便我们对一些定时的任务数据分析包情况脚本代码放到了下面,给大家说明下里面参数

HOST:抓包过滤主机IP地址

PORT:抓包过滤端口(不需要可以注释掉)

INTERFACE:抓包网卡,any指的是所有网卡,也可指定网卡如:ens1,eth0之类

DURATION:抓包时长300S

OUTPUT_DIR:抓包文件保存路径/data

LOG_FILE:抓包脚本操作日志保存路径/var/log/tcpdump_pcap.log

只需要根据需求修改上述参数就可以,其他的可不用动

bash 复制代码
#!/bin/bash

HOST="192.168.10.1"
PORT="1468"
INTERFACE="any"
DURATION=300  #5分钟
OUTPUT_DIR="/data"
LOG_FILE="/var/log/tcpdump_pcap.log"

TIMESTAMP=$(date '+%Y%m%d_%H%M%S')
OUTPUT_FILE="${OUTPUT_DIR}/pcap_${TIMESTAMP}.pcap"

#开始时间
echo "$(date '+%Y-%m-%d %H:%M:%S') - 开始抓包: host $HOST port $PORT" >> $LOG_FILE

# 执行tcpdump5分钟
timeout $DURATION /usr/sbin/tcpdump -i $INTERFACE host $HOST and port $PORT -vv -w $OUTPUT_FILE

# 检查命令执行结果
if [ $? -eq 0 ]; then
    echo "$(date '+%Y-%m-%d %H:%M:%S') - 抓包完成: $OUTPUT_FILE" >> $LOG_FILE
    
    # 获取文件大小
    FILE_SIZE=$(du -h $OUTPUT_FILE | cut -f1)
    echo "$(date '+%Y-%m-%d %H:%M:%S') - 文件大小: $FILE_SIZE" >> $LOG_FILE
else
    echo "$(date '+%Y-%m-%d %H:%M:%S') - 抓包失败或超时" >> $LOG_FILE
fi

2、我们创建好tcpdump_pcap.sh脚本就可以创建我们的定时任务了

bash 复制代码
crontab -e

添加定时任务如下每天凌晨5点开始执行抓包脚本,可以根据需求自行修改前面时间(0 5 * * *),时间不知道怎么写可以百度例:(crontab每小时执行一次时间格式)

bash 复制代码
0 5 * * * bash /root/tcpdump_pcap.sh
相关推荐
AlfredZhao2 天前
生产环境里,为什么不建议把普通端口直接暴露到公网?
linux·https·443·80
戴为沐3 天前
Linux内存扩容指南
linux
zylyehuo3 天前
Linux 彻底且安全地删除文件
linux
用户805533698034 天前
主线 U-Boot 上 RK3506:和闭源 rkbin 拔河的三个隐性契约
linux·嵌入式
用户034095297914 天前
linux fcitx 5 雾凇拼音 设置在中文输入法下仍然输入英文标点
linux
Web3探索者5 天前
可视化服务器管理和传统命令行区别是什么?新手教程:Linux 运维到底该用图形界面还是 SSH 命令行?
linux·ssh
zylyehuo5 天前
Linux系统中网线与USB网络共享冲突
linux
Sokach10157 天前
Linux Shell 脚本从零到能用:一个新手的一天学习总结
linux
AlfredZhao7 天前
Docker 容器时区不对,`timedatectl` 不存在怎么办?
linux·timezone
zzzzzz3109 天前
9K Star 炸裂开源!这个 C 语言写的代码知识图谱,把 Linux 内核索引压缩到了 3 分钟
linux·服务器·sql