Shell ·

linux shell 流量监控脚本

1、实时监控任意网卡的流量
2、统计10秒内平均流量
3、统计每个端口在10秒内的平均流量,基于客户端和服务端端口统计。可以看出哪些端口占流量比较大,对于web服务器,一般是80端口。其它端口受到攻击时,也有可能其它端口流量比较大。所以此功能可以帮助我们端口流量是否正常。
4、统计在10s内占用带宽最大的前10个ip。此项功能可以帮助我们来查出是否有恶意占用带宽的ip。
5、统计连接状态。此项功能可以让我们看出哪些连接状态比较大。如果SYN-RECV状态比较多的话,有可以受到半连接攻击。如果ESTABLISED非常大,但通过日志发现没有那么多请求,或者通过tcpdump发现大量ip只建立连接不请求数据的话,可能是受到了全连接攻击,这时候如果你使用的是nginx服务器,可以在配置文件增加listen 80 deferred来防止。
6、统计各端口连接状态。当可能受到攻击时,此项功能可以帮助我们发现是哪个端口受到攻击。
7、统计端口为80且状态为ESTAB连接数最多的前10个IP。此项功能可以帮助我们来找出创建连接过多的Ip,进而屏蔽。
8、统计端口为80且状态为SYN-RECV连接数最多的前10个IP。当受到半连接攻击时,此项功能可以帮助我们找到恶意ip。

#!/bin/bash#基于操作系统《CentOS 6.7_x64最小化安装》的安全和优化脚本## CentOS/RadHat 5+ Debian 6+ and Ubuntu 12+## 2015年10月1日 by 运维天涯 https://www.fooher.com/20170502_68.html#PATH=/bin:/usr/bin:/sbin:/usr/sbin:/usr/local/bin:/usr/local/sbin;export PATHfunction traffic_monitor { # 系统版本 OS_NAME=$(sed -n '1p' /etc/issue) # 网口名 eth=$1 #判断网卡存在与否,不存在则退出 if [ ! -d /sys/class/net/$eth ];then echo -e "Network-Interface Not Found" echo -e "You system have network-interface:\n`ls /sys/class/net`" exit 5 fi while [ "1" ] do # 状态 STATUS="fine" # 获取当前时刻网口接收与发送的流量-fooher.com RXpre=$(cat /proc/net/dev | grep $eth | tr : " " | awk '{print $2}') TXpre=$(cat /proc/net/dev | grep $eth | tr : " " | awk '{print $10}') # 获取1秒后网口接收与发送的流量 sleep 1 RXnext=$(cat /proc/net/dev | grep $eth | tr : " " | awk '{print $2}') TXnext=$(cat /proc/net/dev | grep $eth | tr : " " | awk '{print $10}') clear # 获取这1秒钟实际的进出流量 RX=$((${RXnext}-${RXpre})) TX=$((${TXnext}-${TXpre})) # 判断接收流量如果大于MB数量级则显示MB单位,否则显示KB数量级-运维天涯 if [[ $RX -lt 1024 ]];then RX="${RX}B/s" elif [[ $RX -gt 1048576 ]];then RX=$(echo $RX | awk '{print $1/1048576 "MB/s"}') $STATUS="busy" else RX=$(echo $RX | awk '{print $1/1024 "KB/s"}') fi # 判断发送流量如果大于MB数量级则显示MB单位,否则显示KB数量级 if [[ $TX -lt 1024 ]];then TX="${TX}B/s" elif [[ $TX -gt 1048576 ]];then TX=$(echo $TX | awk '{print $1/1048576 "MB/s"}') else TX=$(echo $TX | awk '{print $1/1024 "KB/s"}') fi # 打印信息 echo -e "===================================" echo -e "欢迎进入Centos 6.5 流量监控" echo -e "2015.10.25" echo -e "Linux自动化运维 8846514 by 运维天涯" echo -e "BLOG: https://www.fooher.com/20170502_68.html" echo -e "===================================" echo -e "System: $OS_NAME" echo -e "Date: `date +%F`" echo -e "Time: `date +%k:%M:%S`" echo -e "Port: $1" echo -e "Status: $STATUS" echo -e " \t RX \tTX" echo "------------------------------" # 打印实时流量 echo -e "$eth \t $RX $TX " echo "------------------------------" # 退出信息 echo -e "Press 'Ctrl+C' to exit" done}# 判断执行参数if [[ -n "$1" ]];then # 执行函数 traffic_monitor $1else echo -e "没有参数,请在添加系统网口运行脚本! \n例: 'sh monitor eth0'"fi

评论已关闭