超级NB的防DDOS(小量级)攻击的脚本

# tree /usr/local/ddos//usr/local/ddos/├── ddos.conf

├── ddos.sh

├── ignore.ip.list

└── LICENSE0directories,4files

# ll /usr/local/sbin/ddos

lrwxrwxrwx 1root root23Sep1315:36/usr/local/sbin/ddos -> /usr/local/ddos/ddos.sh

# cat /etc/cron.d/ddos.cron

SHELL=/bin/sh*/1* * * * root /usr/local/ddos/ddos.sh >/dev/null2>&1

查看关键的几个脚本:

# cat ddos.conf

##### Paths of the script and other files

PROGDIR="/usr/local/ddos"PROG="/usr/local/ddos/ddos.sh"IGNORE_IP_LIST="/usr/local/ddos/ignore.ip.list"CRON="/etc/cron.d/ddos.cron"APF="/etc/apf/apf"IPT="/sbin/iptables"##### frequency inminutesfor running the script

##### Caution: Every time thissettingischanged, run the script with --cron

#####          option so that the new frequency takes effect

FREQ=1##### How many connections define a bad IP? Indicate that below.

NO_OF_CONNECTIONS=150##### APF_BAN=1(Make sure your APF versionisatleast0.96)

##### APF_BAN=0(Uses iptablesfor banning ips instead of APF)

#APF_BAN=1APF_BAN=0##### KILL=0(Bad IPs are'nt banned, good for interactive execution of script)##### KILL=1 (Recommended setting)

KILL=1##### An email issent to the following address when an IPis banned.

##### Blank would suppress sending of mails

EMAIL_TO="xxx@xxx.com"##### Number of seconds the banned ip should remain in blacklist.

BAN_PERIOD=600

# cat ddos.sh

#!/bin/sh

##############################################################################

# DDoS-Deflate version0.6Author: Zaf                         #

##############################################################################

# This program isdistributed under the"Artistic License" Agreement        #

#                                                                            #

# The LICENSE file islocatedinthe same directoryasthis program. Please  #

#  read the LICENSE file before you make copies or distribute this program  #

##############################################################################

load_conf()

{

    CONF="/usr/local/ddos/ddos.conf"if[ -f"$CONF"] && [ !"$CONF"=="" ]; then

        source $CONF

    else        head

        echo "\$CONF not found."        exit 1    fi

}

head()

{

    echo "DDoS-Deflate version 0.6"    echo "Copyright (C) 2005, Zaf <zaf@vsnl.com>"    echo

}

showhelp()

{

    head

    echo 'Usage: ddos.sh [OPTIONS] [N]'    echo 'N : number of tcp/udp    connections (default 150)'    echo 'OPTIONS:'    echo '-h | --help: Show    this help screen'    echo '-c | --cron: Create cron job to run this script regularly (default 1 mins)'    echo '-k | --kill: Block the offending ip making more than N connections'}

unbanip()

{

    UNBAN_SCRIPT=`mktemp /tmp/unban.XXXXXXXX`

    TMP_FILE=`mktemp /tmp/unban.XXXXXXXX`

    UNBAN_IP_LIST=`mktemp /tmp/unban.XXXXXXXX`

    echo '#!/bin/sh'> $UNBAN_SCRIPT

    echo "sleep $BAN_PERIOD">> $UNBAN_SCRIPT

    if[ $APF_BAN -eq1 ]; then

        whileread line;do            echo "$APF -u $line">> $UNBAN_SCRIPT

            echo $line >> $UNBAN_IP_LIST

        done < $BANNED_IP_LIST

    elsewhileread line;do            echo "$IPT -D INPUT -s $line -j DROP">> $UNBAN_SCRIPT

            echo $line >> $UNBAN_IP_LIST

        done < $BANNED_IP_LIST

    fi

    echo "grep -v --file=$UNBAN_IP_LIST $IGNORE_IP_LIST > $TMP_FILE">> $UNBAN_SCRIPT

    echo "mv $TMP_FILE $IGNORE_IP_LIST">> $UNBAN_SCRIPT

    echo "rm -f $UNBAN_SCRIPT">> $UNBAN_SCRIPT

    echo "rm -f $UNBAN_IP_LIST">> $UNBAN_SCRIPT

    echo "rm -f $TMP_FILE">> $UNBAN_SCRIPT

    . $UNBAN_SCRIPT &}

add_to_cron()

{

    rm -f $CRON

    sleep 1    service crond restart

    sleep 1    echo "SHELL=/bin/sh"> $CRON

    if[ $FREQ -le2 ]; then

        echo "0-59/$FREQ * * * * root /usr/local/ddos/ddos.sh >/dev/null 2>&1">> $CRON

    else        let "START_MINUTE = $RANDOM % ($FREQ - 1)"        let "START_MINUTE = $START_MINUTE + 1"        let "END_MINUTE = 60 - $FREQ + $START_MINUTE"        echo "$START_MINUTE-$END_MINUTE/$FREQ * * * * root /usr/local/ddos/ddos.sh >/dev/null 2>&1">> $CRON

    fi

    service crond restart

}

load_confwhile[ $1];docase$1in'-h'|'--help'|'?' )

            showhelp

            exit

            ;;

        '--cron'|'-c' )

            add_to_cron

            exit

            ;;

        '--kill'|'-k' )

            KILL=1            ;;

        *[0-9]* )

            NO_OF_CONNECTIONS=$1            ;;

        * )

            showhelp

            exit

            ;;

    esac

    shift

done

TMP_PREFIX='/tmp/ddos'TMP_FILE="mktemp $TMP_PREFIX.XXXXXXXX"BANNED_IP_MAIL=`$TMP_FILE`

BANNED_IP_LIST=`$TMP_FILE`

echo "Banned the following ip addresses on `date`"> $BANNED_IP_MAIL

echo >>    $BANNED_IP_MAIL

BAD_IP_LIST=`$TMP_FILE`

netstat -ntu | awk'{print $5}'| cut -d: -f1 | sort | uniq -c | sort -nr > $BAD_IP_LIST

cat $BAD_IP_LISTif[ $KILL -eq1 ]; then

    IP_BAN_NOW=0whileread line;do        CURR_LINE_CONN=$(echo $line | cut -d""-f1)

        CURR_LINE_IP=$(echo $line | cut -d""-f2)

        if[ $CURR_LINE_CONN -lt $NO_OF_CONNECTIONS ]; then

            break        fi

        IGNORE_BAN=`grep -c $CURR_LINE_IP $IGNORE_IP_LIST`

        if[ $IGNORE_BAN -ge1 ]; then

            continue        fi

        IP_BAN_NOW=1        echo "$CURR_LINE_IP with $CURR_LINE_CONN connections">> $BANNED_IP_MAIL

        echo $CURR_LINE_IP >> $BANNED_IP_LIST

        echo $CURR_LINE_IP >> $IGNORE_IP_LIST

        if[ $APF_BAN -eq1 ]; then

            $APF -d $CURR_LINE_IP

        else            $IPT -I INPUT -s $CURR_LINE_IP -j DROP

        fi

    done < $BAD_IP_LIST

    if[ $IP_BAN_NOW -eq1 ]; then

        dt=`date`

        if[ $EMAIL_TO !="" ]; then

            cat $BANNED_IP_MAIL | mail -s"IP addresses banned on $dt" $EMAIL_TO

        fi

        unbanip

    fi

fi

rm -f $TMP_PREFIX.*

# cat ignore.ip.list 127.0.0.110.100.0.5#不防御的ip

 注意权限:

# ll /etc/cron.d/ddos.cron -rw-r--r--1root root71Sep1417:13/etc/cron.d/ddos.cron

注意软连接:

# ll /usr/local/sbin/ddos

lrwxrwxrwx 1root root23Sep1315:36/usr/local/sbin/ddos -> /usr/local/ddos/ddos.sh


转载于:https://www.cnblogs.com/bass6/p/7522089.htm

    有服务器需求请加QQ1911624872咨询

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 202,723评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,080评论 2 379
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 149,604评论 0 335
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,440评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,431评论 5 364
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,499评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,893评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,541评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,751评论 1 296
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,547评论 2 319
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,619评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,320评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,890评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,896评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,137评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,796评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,335评论 2 342

推荐阅读更多精彩内容