shell腳本-DOS攻擊防範(自動屏蔽攻擊IP)

来源:https://www.cnblogs.com/xuxuxuxuxu/archive/2023/07/22/17572775.html
-Advertisement-
Play Games

# shell腳本-DOS攻擊防範(自動屏蔽攻擊IP) ## 原理: #### **找出異常ip** > 通過獲取伺服器access.log日誌信息,獲取時間在每分鐘之內每個ip訪問的次數來判斷此ip是否是DOS攻擊。 > > grep $(date +%d/%b/%Y:%H:%M) 過濾得到沒分鐘 ...


shell腳本-DOS攻擊防範(自動屏蔽攻擊IP)

原理:

找出異常ip

通過獲取伺服器access.log日誌信息,獲取時間在每分鐘之內每個ip訪問的次數來判斷此ip是否是DOS攻擊。

grep $(date +%d/%b/%Y:%H:%M) 過濾得到沒分鐘之內的page被訪問的信息

awk '{a[$1]++}END{for (i in a)print i,a[i]}' 再通過awk命令過濾得到每分鐘訪問page的ip和次數

示例:

[root@localhost /]# grep $(date +%d/%b/%Y:%H:%M) /usr/local/nginx/logs/access.log | awk '{a[$1]++}END{for (i in a)print i,a[i]}'
192.168.70.1 2

再限制一下次數(例如60次)只取ip:

grep $(date +%d/%b/%Y:%H:%M) /usr/local/nginx/logs/access.log | awk '{a[$1]++}END{for (i in a)if(a[i] > 60)print i}'

屏蔽異常ip

先查看iptables中有沒有對該ip的屏蔽,如果沒有則執行屏蔽

if [ iptables -vnL | grep -c "$IP" -eq 0 ]; then
iptables -I -s $IP -j DROP

shell腳本

#!/bin/bash
DATE=$(date +%d/%b/%Y:%H:%M)
LOG_FILE=/usr/local/nginx/logs/access.log
ABNORMAL_IP=`tail -n5000 $LOG_FILE | grep $DATE |awk '{a[$1]++}END{for(i in a)if(a[i] > 60)print i}'`
for IP in $ABNORMAL_IP; do
        if [ `iptables -vnL | grep -c "$IP"` -eq 0 ]; then
                iptables -I -s $IP -j DROP
                echo "$(date + '%F_%T') $IP" >> /tmp/drop_ip.log
        fi
done

iptables命令補充說明

查看規則

iptables [參數]
  • -L 表示查看當前表的所有規則,預設查看的是 filter 表,如果要查看 nat 表,可以加上 -t nat 參數。
  • -n 表示不對 IP 地址進行反查,加上這個參數顯示速度將會加快。
  • -v 表示輸出詳細信息,包含通過該規則的數據包數量、總位元組數以及相應的網路介面。

iptables命令語法

iptables [-t table] COMMAND [chain] MATCH -j ACTION

規則管理-COMMAND
-A, --append chain rule-specification: 追加新規則於指定鏈的尾部;
-I, --insert chain [rulenum] rule-specification : 插入新規則於指定鏈的指定位置,預設為首部;
-R, --replace chain rulenum rule-specification : 替換指定的規則為新的規則;
-D, --delete chain rulenum : 根據規則編號刪除規則,用–line-numbers查看;匹配的條件或標準-MATCH

MATCH匹配條件包括通用匹配條件擴展匹配條件

通用匹配條件
-s, --source address[/mask][,…] : 檢查報文的源IP地址是否符合此處指定的範圍,或是否等於此處給定的地址;
-d, --destination address[/mask][,…] : 檢查報文的目標IP地址是否符合此處指定的範圍,或是否等於此處給定的地址;
-p, --protocol protocol : 匹配報文中的協議,可用值tcp, udp, udplite, icmp, icmpv6,esp, ah, sctp, mh 或者 “all”, 亦可以數字格式指明協議;
-i, --in-interface name : 限定報文僅能夠從指定的介面流入;only for packets entering the INPUT, FORWARD and PREROUTING chains.
-o, --out-interface name : 限定報文僅能夠從指定的介面流出;for packets entering the FORWARD, OUTPUT and POSTROUTING chains.

-j ACTION------操作動作,ACCEPT、DROP、REJECT

ACCEPT : 接受
DROP : 忽略
REJECT : 拒絕

iptables補充說明主要參考:[第二篇:CentOS7 iptables命令使用詳情_centos7查看報文_hard-cly的博客-CSDN博客](https://blog.csdn.net/weixin_47554522/article/details/120196797?ops_request_misc={"request_id"%3A"168996413216800227431683"%2C"scm"%3A"20140713.130102334.."}&request_id=168996413216800227431683&biz_id=0&utm_medium=distribute.pc_search_result.none-task-blog-2allsobaiduend~default-1-120196797-null-null.142v90control,239v3insert_chatgpt&utm_term=centos7 iptables命令&spm=1018.2226.3001.4187)


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • ## 什麼是 gRPC? gRPC 是由 Google 開發的高性能、開源的 RPC(Remote Procedure Call)框架,用於在客戶端和伺服器之間進行通信。它基於 Protocol Buffers(protobuf)進行消息序列化和反序列化,支持多種通信協議,如 HTTP/2、TCP ...
  • # UDP網路通信編程 - **基本介紹** 1. 類DatagramSocket和DatagramPacket實現了基於UDP協議網路程式。 2. UDP數據報通過數據報套接字DatagramSocket發送和接收,系統不保證UDP數據報一定能夠安全送到目的地,也不能確定什麼時候可以抵達。 3. ...
  • 由於一些歷史原因,重裝系統成為Windows用戶解決疑難雜症的祖傳手藝。受此影響,給硬碟分區幾乎成為了一種執念,少則C、D兩個盤,誇張一點的5~6個盤的也不是沒有。 > PS:macOS和Linux一直都不鼓勵給磁碟分區,雖然不禁止但也不提倡。隨著雲技術和寬頻的提升,越來越多的人更喜歡把自己認為比較 ...
  • 眾所周知,我們是訪問不通OpenAI官方服務的,但是我們可以自己通過代理或者使用第三方代理訪問介面 現在新出台的規定禁止使用境外的AI大模型介面對境內客戶使用,所以我們需要使用國內的大模型介面 國內的效果真的很差,現在如果想合規的使用GPT大模型,可以使用微軟Azure的OpenAI服務,畢竟微軟在 ...
  • # Avalonia 使用EFCore調用SQLite實現Singleton全局註冊 ![image-20230720204001797](https://www.raokun.top/upload/2023/07/image-20230720204001797.png) 本篇博客是我的開源項目[T ...
  • asp.net項目開發過程中用到了多個程式集(dll), 如何根據類型全名(fullname)獲取類型信息? 如果項目(csproj)中設置了引用對應的dll 或nupkg包,但是代碼中沒有任務地方引用改該程式集的類,則實際上運行時,該程式集不會被載入到進程中. 假設有一個 ThirdModels. ...
  • # Unity UGUI的CanvasScaler(畫布縮放器)組件的介紹及使用 ## 1. 什麼是CanvasScaler組件? CanvasScaler是Unity中UGUI系統中的一個組件,用於控制畫布的縮放和適配。通過CanvasScaler組件,可以實現UI界面在不同解析度下的自適應顯示。 ...
  • ### 描述 asp.net Core Identity提供給我們一組工具包和API,能幫助我們應用程式創建授權和認證功能。也可以用它創建賬戶並使用用戶名和密碼進行登錄,同時也提供了角色和角色管理功能。 #### 1.創建項目 - 配置項 - nuget包 - Microsoft.AspNetCor ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...