欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Linux系統防CC攻擊自動拉黑IP增強版(Shell腳本)

 更新時間:2015年04月06日 23:00:40   作者:張戈  
這篇文章主要介紹了Linux系統防CC攻擊自動拉黑IP增強版(Shell腳本),需要的朋友可以參考下

前天沒事寫了一個防CC攻擊的Shell腳本,沒想到這么快就要用上了,原因是因為360網站衛(wèi)士的緩存黑名單突然無法過濾后臺,導致WordPress無法登錄!雖然,可以通過修改本地hosts文件來解決這個問題,但是還是想暫時取消CDN加速和防護來測試下服務器的性能優(yōu)化及安全防護。

前天寫的Shell腳本是加入到crontab計劃任務執(zhí)行的,每5分鐘執(zhí)行一次,今天實際測試了下,可還是可以用的,但是感覺5分鐘時間有點過長,無法做到嚴密防護。于是稍微改進了下代碼,現在簡單的分享下!

一、Shell代碼

#!/bin/bash
#Author:ZhangGe
#Desc:Auto Deny Black_IP Script.
#Date:2014-11-05
#取得參數$1為并發(fā)閾值,若留空則默認允許單IP最大100并發(fā)(實際測試發(fā)現,2M帶寬,十來個并發(fā)服務器就已經無法訪問了!)
if [[ -z $1 ]];then
    num=50
else 
    num=$1
fi

#巧妙的進入到腳本工作目錄
cd $(cd $(dirname $BASH_SOURCE) && pwd)

#請求檢查、判斷及拉黑主功能函數
function check(){
    iplist=`netstat -an |grep ^tcp.*:80|egrep -v 'LISTEN|127.0.0.1'|awk -F"[ ]+|[:]" '{print $6}'|sort|uniq -c|sort -rn|awk -v str=$num '{if ($1>str){print $2}}'`
    if [[ ! -z $iplist ]];
        then
        >./iplist/black_ip.txt
        for black_ip in $iplist
        do
            #白名單過濾中已取消IP段的判斷功能,可根據需要自行修改以下代碼(請參考前天寫的腳本)
            #exclude_ip=`echo $black_ip | awk -F"." '{print $1"."$2"."$3}'`
            #grep -q $exclude_ip ./white_ip.txt
            grep -q $black_ip ./white_ip.txt
            if [[ $? -eq 0 ]];then
                echo "$black_ip (white_ip)" >>./black_ip.txt
            else
                echo $black_ip >>./black_ip.txt   
                iptables -nL | grep $black_ip ||(iptables -I INPUT -s $black_ip -j DROP & echo "$black_ip `date +%Y-%m-%H:%M:%S`">>./iplist/denylog.txt & echo 1 >./sendmail)
            fi
        done
        #存在并發(fā)超過閾值的單IP就發(fā)送郵件
        if [[ `cat ./sendmail` == 1 ]];then sendmsg;fi
    fi
}

#發(fā)郵件函數
function sendmsg(){
    netstat -nutlp | grep "sendmail" >/dev/null 2>&1 || /etc/init.d/sendmail start >/dev/null 2>&1
    echo -e "From: 發(fā)郵件地址@qq.com\nTo:收郵件地址@qq.com\nSubject:Someone Attacking your system!!\nIts Ip is" >./message
    cat ./black_ip.txt >>./message
    /usr/sbin/sendmail -f 發(fā)郵件地址@qq.com -t 收郵件地址@qq.com -i <./message
    >./sendmail
}

#間隔10s無限循環(huán)檢查函數
while true
do 
    check
    #每隔10s檢查一次,時間可根據需要自定義
    sleep 10
done

二、執(zhí)行腳本
將以上代碼保存為deny_blackip.sh之后,使用如下命令后臺執(zhí)行腳本(后面的50表示并發(fā)數,可自行調整):

復制代碼 代碼如下:

nohup ./deny_blackip.sh 50 &

執(zhí)行后會出現如下信息:

[root@Mars_Server iptables]# nohup ./deny_blackip.sh 50 & 
[1] 23630
[root@Mars_Server iptables]# nohup: ignoring input and appending output to `nohup.out'

表示如果腳本產生輸出信息,將會寫入到nohup.out文件,可以看到當前目錄已經生成了一個空的nohup.out:

[root@Mars_Server iptables]# ll nohup.out
-rw------- 1 root root 0 Nov 5 21:15 nohup.out

好了,現在你執(zhí)行執(zhí)行ps aux 應該可以找到如下進程:

root   23630 0.0 0.2  5060 1224 pts/0  S  21:15  0:00 /bin/bash ./deny_blackip.sh
root   23964 0.0 0.0  4064  508 pts/0  S  21:19  0:00 sleep 10

①、模擬CC攻擊的服務器截圖:


②、被CC攻擊的服務器截圖:

③、攻擊IP被拉黑后的報警郵件:

測試時,模擬55個并發(fā)攻擊了20s,立馬就被拉黑了,效果很明顯!

四、附加說明

①、腳本發(fā)郵件需要安裝sendmail,若未安裝請執(zhí)行yum -y install sendmail安裝并啟動即可;

②、若要停止后臺運行的腳本,只要使用ps aux命令找到該腳本的pid線程號,然后執(zhí)行kill -9 pid號即可結束;

③、關于腳本的單IP并發(fā)限制,我實際測試同時打開博客多個頁面并持續(xù)刷新,頂多也就產生十來個并發(fā),所以單IP超過50個并發(fā)就已經有很大的問題了!當然,文章的閾值設為50也只是建議值,你可以根據需求自行調整;

④、寫這個腳本,主要是為了彌補用crontab執(zhí)行時間間隔最低只能是1分鐘的不足,可以讓CC防護更嚴密,甚至每隔1S執(zhí)行一次!雖說腳本不怎么占用資源,不過還是建議10s執(zhí)行一次為佳,不用太過極端是吧?

⑤、對于白名單過濾,只要將白名單IP保存到腳本同一目錄下的white_ip.txt文件中即可,若發(fā)現攻擊IP在白名單中,腳本不會直接拉黑,而是發(fā)一封郵件給你,讓你自己判斷這個白名單攻擊你是為毛?如果白名單需要支持IP段,請參考我前天寫的腳本即可。

就啰嗦這么多,主要還是自己用,然后分享出來給有需要的人一些參考,個人vps服務器雖說很少有人攻擊,但是基本的安裝防護還是必須要做的!希望本文對你有所幫助!

原文:http://zhangge.net/4649.html

相關文章

  • Tomcat中的startup.bat原理詳細解析

    Tomcat中的startup.bat原理詳細解析

    在windows操作系統中,我們運行tomcat只需要執(zhí)行startup.bat腳本就好,這個startup.bat腳本到底是什么?下面這篇文章就來給大家詳細的解析了關于Tomcat中startup.bat原理的相關資料,需要的朋友可以參考借鑒,下面來一起看看吧。
    2017-09-09
  • SecureCRT中文顯示亂碼問題的解決方法

    SecureCRT中文顯示亂碼問題的解決方法

    這篇文章主要介紹了SecureCRT中文顯示亂碼問題的解決方法,需要的朋友可以參考下
    2016-07-07
  • 詳解ubuntu14.04如何設置靜態(tài)IP的方法

    詳解ubuntu14.04如何設置靜態(tài)IP的方法

    本篇文章主要介紹了ubuntu14.04如何設置靜態(tài)IP的方法,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-07-07
  • Linux查看分區(qū)文件系統類型的方法總結

    Linux查看分區(qū)文件系統類型的方法總結

    這篇文章主要給大家總結介紹了關于Linux查看分區(qū)文件系統類型的相關資料,文中通過示例代碼介紹的非常詳細,對大家學習或者使用linux系統具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2018-08-08
  • ubuntu下迅雷極速版的安裝與使用

    ubuntu下迅雷極速版的安裝與使用

    Ubuntu是一個完全基于Linux的操作系統,它不但免費,而且有專業(yè)人員和業(yè)余愛好者共同為其提供技術支持。迅雷極速版的推出吸引了眾多追求速度的網友關注。那么這篇文章我們就來學習下在ubuntu下迅雷極速版與QQ旋風的安裝與使用,有需要的朋友們下面來一起看看吧。
    2016-10-10
  • 詳解在Ubuntu下搭建FTP服務器

    詳解在Ubuntu下搭建FTP服務器

    這篇文章主要介紹了詳解在Ubuntu下搭建FTP服務器,,具有一定的參考價值,感興趣的小伙伴們可以參考一下。
    2016-12-12
  • 在Ubuntu中實現人臉識別登錄的完整步驟

    在Ubuntu中實現人臉識別登錄的完整步驟

    這篇文章主要給大家介紹了關于在Ubuntu中實現人臉識別登錄的完整步驟,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧
    2020-06-06
  • 詳解nohup /dev/null 2>&1 含義的使用

    詳解nohup /dev/null 2>&1 含義的使用

    這篇文章主要介紹了詳解nohup /dev/null 2>&1 含義的使用,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-09-09
  • Linux下利用python實現語音識別詳細教程

    Linux下利用python實現語音識別詳細教程

    早期語音識別系統僅能識別單個講話者以及只有約十幾個單詞的詞匯量?,F代語音識別系統已經取得了很大進步,對于 Python 使用者而言,一些語音識別服務可通過 API 在線使用,且其中大部分也提供了 Python SDK,感興趣的小伙伴可以參考閱讀
    2023-03-03
  • centos7.0安裝離線JDK1.8方法詳解

    centos7.0安裝離線JDK1.8方法詳解

    這篇文章主要介紹了centos7.0安裝離線JDK1.8方法,本文給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2018-06-06

最新評論