热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

一个简单的防止IP攻击的脚本

文章标题:一个简单的防止IP攻击的脚本。Linux是中国IT实验室的一个技术频道。包含桌面应用,Linux系统管理,内核研究,嵌入式系统和开源等一些基本分类

  注意:这个脚本是根据apache服务器的server-status和系统的dmesg分析结果进行防范的,所以非apache用户和没有开启server-status的朋友没法使用

  可以在服务器的crontab里设定每一分钟运行一次脚本,

  复制下面的脚本到autoblock.sh,

  root用户下# chmod u+x autoblock.sh

  QUOTE:

  #!/bin/bash

  # author hao32

  # basic setting

  echo 1 > /proc/sys/net/ipv4/tcp_synCOOKIEs

  # find server-status name

  ss_name="/usr/local/autoblock"

  if [ -e $ss_name/ss_name ];then

  ss_n=`cat $ss_name/ss_name`

  else

  mkdir /usr/local/autoblock >/dev/null 2>&1

  cat `locate httpd.conf|grep -E "httpd/conf/httpd.conf$|apache_ssl/conf/httpd.conf$"`\

  |grep "n /server-status"|cut -d/ -f2|cut -d\> -f1 > $ss_name/ss_name

  ss_n=`cat $ss_name/ss_name`

  fi

  # block setting

  # 设定排除的IP地址

  ip_exclude="192.168.1.*|60.195.249.*|222.76.212.*|218.241.156.*|58.215.87.*|218.107.216.110"

  ip_amou=25

  ss_url="http://127.0.0.1/$ss_n?notable"

  ss_tmp="/tmp/server-status"

  poss_ip="/tmp/poss_ip"

  real_ip="/tmp/real_ip"

  # block start...

  if [ -e "$poss_ip" ];then

  echo "" > $poss_ip

  fi

  if [ -e "$real_ip" ];then

  echo "" > $real_ip

  fi

  # analyse demsg

  dmesg |grep "short"|awk '{if($4!="From"){print $4} else {print $5}}'|awk -F: '{print $1}'|sort|uniq>>$poss_ip

  wget -q -O "$ss_tmp" "$ss_url"

  grep "" $ss_tmp|grep -vE $ip_exclude|awk '{print $1}'|sed 's///g'|sort|uniq -c\

  |awk '{if($1>'$ip_amou') print $2}'>>$poss_ip

  #iptables -nvL|grep "DROP "|awk '{print $8}'|sort|uniq|sed 's/0\/24/*/g'>$rule_ip

  rule_ip=`iptables -nvL|grep "DROP "|awk '{print $8}'|sort|uniq|sed 's/0\/24/*/g'|xargs|sed 's/\ /|/g'`

  if [ -z $rule_ip ];then

  for i in `cat $poss_ip`

  do

  /sbin/iptables -I INPUT -p all -s $i -j DROP

  done

  else

  cat $poss_ip|grep -vE "$rule_ip" > $real_ip

  for i in `cat $real_ip`

  do

  /sbin/iptables -I INPUT -p all -s $i -j DROP

  done

  fi


推荐阅读
author-avatar
逝水无痕--
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有