shell脚本-根据连接数封IP

#!/bin/bash  
#根据并发连接数,将短时间内PV大于100的封掉,计划任务每三分钟

#environment variable
source /etc/profile


iplist=`netstat -ntu | awk '{print $5}'| cut -d':' -f1| sort |uniq -c | sed 'N;$d;P;D' | awk '{if($1>100)print $2}'`
for ip in $iplist
do
        iptables -I INPUT -s $ip -j DROP
        echo "$ip is drop!" >> ./drop.log
#这里也可以给管理员发送邮件通知

done



----------------------------------------------------------------------------------------------------------



#!/bin/bash
# 执行脚本后,每小时自动找访问日志$1循环一次,访问日志也需要按每小时切割一下,

# sh  while_ip.sh  access_nginx.log

while true

do
        awk '{a[$1]++}END{for (b in a) print b,a[b] }' $1 > /tmp/access.log
        exec < /tmp/access.log
        while read line
        do
                ip=`echo $line|awk '{print $1}'`
                count=`echo $line|awk '{print $2}'`
                if [ $count -gt 500 ]
                then
                        iptables -I INPUT -s $ip -j DROP
                        if [ -d /tmp/`date +%F` ]
                        then
                                echo "$ip is drop!" >> /tmp/`date +%F`/drop`date +%F-%H`.log
#这里也可以给管理员发送邮件通知
                        else
                                mkdir /tmp/`date +%F`
                                echo "$ip is drop!" >> /tmp/`date +%F`/drop`date +%F-%H`.log
#这里也可以给管理员发送邮件通知
                        fi
                fi
        done
        sleep 3600
done 


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值