DDOS之syn flood 原理及防護

版權歸原作者所有
作者:Blackhat
原文鏈接:http://bhhacker.lofter.com/post/38b021_29bab8f

一、為什么Syn Flood會造成危害

這要從操作系統(tǒng)的TCP/IP協(xié)議棧的實現說起痢艺。當開放了一個TCP端口后尸折,該端口就處于Listening狀態(tài),不停地監(jiān)視發(fā)到該端口的Syn報文,一旦接收到Client發(fā)來的Syn報文校焦,就需要為該請求分配一個TCB(Transmission Control Block)俏脊,通常一個TCB至少需要280個字節(jié),在某些操作系統(tǒng)中TCB甚至需要1300個字節(jié)吊履,并返回一個SYN ACK命令安皱,立即轉為SYN-RECEIVED即半開連接狀態(tài),而某些操作系統(tǒng)在SOCK的實現上最多可開啟512個半開連接(如Linux2.4.20內核)艇炎。這種過程如下圖所示:

從以上過程可以看到酌伊,如果惡意的向某個服務器端口發(fā)送大量的SYN包,則可以使服務器打開大量的半開連接冕臭,分配TCB腺晾,從而消耗大量的服務器資源,同時也使得正常的連接請求無法被響應辜贵。而攻擊發(fā)起方的資源消耗相比較可忽略不計悯蝉。

二、如何防御Syn Flood攻擊

我們先來看一下Syn Flood有哪些種類托慨,如下圖所示:

  1. Direct Attack 攻擊方使用固定的源地址發(fā)起攻擊鼻由,這種方法對攻擊方的消耗最小

  2. Spoofing Attack 攻擊方使用變化的源地址發(fā)起攻擊,這種方法需要攻擊方不停地修改源地址厚棵,實際上消耗也不大

  3. Distributed Direct Attack 這種攻擊主要是使用僵尸網絡進行固定源地址的攻擊

對于第一種攻擊的防范可以使用比較簡單的方法蕉世,即對SYN包進行監(jiān)視,如果發(fā)現某個IP發(fā)起了較多的攻擊報文婆硬,直接將這個IP列入黑名單即可狠轻。當然下述的方法也可以對其進行防范。

對于源地址不停變化的攻擊使用上述方法則不行彬犯,首先從某一個被偽裝的IP過來的Syn報文可能不會太多向楼,達不到被拒絕的閾值查吊,其次從這個被偽裝的IP(真實的)的請求會被拒絕掉。因此必須使用其他的方法進行處理湖蜕。

1.無效連接監(jiān)視釋放

這種方法不停監(jiān)視系統(tǒng)的半開連接和不活動連接逻卖,當達到一定閾值時拆除這些連接,從而釋放系統(tǒng)資源昭抒。這種方法對于所有的連接一視同仁评也,而且由于SYN Flood造成的半開連接數量很大,正常連接請求也被淹沒在其中被這種方式誤釋放掉灭返,因此這種方法屬于入門級的SYN Flood方法盗迟。

2.延緩TCB分配方法

從前面SYN Flood原理可以看到,消耗服務器資源主要是因為當SYN數據報文一到達婆殿,系統(tǒng)立即分配TCB诈乒,從而占用了資源。而SYN Flood由于很難建立起正常連接婆芦,因此怕磨,當正常連接建立起來后再分配TCB則可以有效地減輕服務器資源的消耗。常見的方法是使用Syn Cache和Syn Cookie技術消约。

  • Syn Cache技術:這種技術是在收到SYN數據報文時不急于去分配TCB肠鲫,而是先回應一個SYN ACK報文,并在一個專用HASH表(Cache)中保存這種半開連接信息或粮,直到收到正確的回應ACK報文再分配TCB导饲。在FreeBSD系統(tǒng)中這種Cache每個半開連接只需使用160字節(jié),遠小于TCB所需的736個字節(jié)氯材。在發(fā)送的SYN ACK中需要使用一個己方的Sequence Number渣锦,這個數字不能被對方猜到,否則對于某些稍微智能一點的Syn Flood攻擊軟件來說氢哮,它們在發(fā)送Syn報文后會發(fā)送一個ACK報文袋毙,如果己方的Sequence Number被對方猜測到,則會被其建立起真正的連接冗尤。因此一般采用一些加密算法生成難于預測的Sequence Number听盖。

  • Syn Cookie技術:對于SYN攻擊,Syn Cache雖然不分配TCB裂七,但是為了判斷后續(xù)對方發(fā)來的ACK報文中的Sequence Number的正確性皆看,還是需要使用一些空間去保存己方生成的Sequence Number等信息,也造成了一些資源的浪費背零。Syn Cookie技術則完全不使用任何存儲資源腰吟,這種方法比較巧妙,它使用一種特殊的算法生成Sequence Number徙瓶,這種算法考慮到了對方的IP毛雇、端口录语、己方IP、端口的固定信息禾乘,以及對方無法知道而己方比較固定的一些信息,如MSS虽缕、時間等始藕,在收到對方的ACK報文后,重新計算一遍氮趋,看其是否與對方回應報文中的(Sequence Number-1)相同伍派,從而決定是否分配TCB資源。

3.使用SYN Proxy防火墻

Syn Cache技術和Syn Cookie技術總的來說是一種主機保護技術剩胁,需要系統(tǒng)的TCP/IP協(xié)議棧的支持诉植,而目前并非所有的操作系統(tǒng)支持這些技術。因此很多防火墻中都提供一種SYN代理的功能昵观,其主要原理是對試圖穿越的SYN請求進行驗證后才放行晾腔,下圖描述了這種過程:


從上圖(左圖)中可以看出,防火墻在確認了連接的有效性后啊犬,才向內部的服務器(Listener)發(fā)起SYN請求灼擂,在右圖中,所有的無效連接均無法到達內部的服務器觉至。而防火墻采用的驗證連接有效性的方法則可以是Syn Cookie或Syn Flood等其他技術剔应。采用這種方式進行防范需要注意的一點就是防火墻需要對整個有效連接的過程發(fā)生的數據包進行代理,如下圖所示:


因為防火墻代替發(fā)出的SYN ACK包中使用的序列號為c语御,而服務器真正的回應包中序列號為c’峻贮,這其中有一個差值|c-c’|,在每個相關數據報文經過防火墻的時候進行序列號的修改应闯。

TCP Safe Reset技術:

這也是防火墻Syn代理的一種方式纤控,其工作過程如下圖所示:

TCP Safe Reset技術

這種方法在驗證了連接之后立即發(fā)出一個Safe Reset命令包,從而使得Client重新進行連接孽锥,這時出現的Syn報文防火墻就直接放行嚼黔。在這種方式中,防火墻就不需要對通過防火墻的數據報文進行序列號的修改了惜辑。這需要客戶端的TCP協(xié)議棧支持RFC 793中的相關約定唬涧,同時由于Client需要兩次握手過程,連接建立的時間將有所延長盛撑。

參考文獻

  1. Traffic Anomaly Detector and Guard (Riverhead Networks) FAQ
  2. SYN Cookie原理及其在Linux內核中的實現
  3. Defenses Against TCP SYN Flooding Attacks
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末碎节,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子抵卫,更是在濱河造成了極大的恐慌狮荔,老刑警劉巖胎撇,帶你破解...
    沈念sama閱讀 216,651評論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現場離奇詭異殖氏,居然都是意外死亡晚树,警方通過查閱死者的電腦和手機,發(fā)現死者居然都...
    沈念sama閱讀 92,468評論 3 392
  • 文/潘曉璐 我一進店門雅采,熙熙樓的掌柜王于貴愁眉苦臉地迎上來爵憎,“玉大人,你說我怎么就攤上這事婚瓜”模” “怎么了?”我有些...
    開封第一講書人閱讀 162,931評論 0 353
  • 文/不壞的土叔 我叫張陵巴刻,是天一觀的道長愚铡。 經常有香客問我,道長胡陪,這世上最難降的妖魔是什么沥寥? 我笑而不...
    開封第一講書人閱讀 58,218評論 1 292
  • 正文 為了忘掉前任,我火速辦了婚禮柠座,結果婚禮上营曼,老公的妹妹穿的比我還像新娘。我一直安慰自己愚隧,他們只是感情好蒂阱,可當我...
    茶點故事閱讀 67,234評論 6 388
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著狂塘,像睡著了一般录煤。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上荞胡,一...
    開封第一講書人閱讀 51,198評論 1 299
  • 那天妈踊,我揣著相機與錄音,去河邊找鬼泪漂。 笑死廊营,一個胖子當著我的面吹牛,可吹牛的內容都是我干的萝勤。 我是一名探鬼主播露筒,決...
    沈念sama閱讀 40,084評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼敌卓!你這毒婦竟也來了慎式?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 38,926評論 0 274
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎瘪吏,沒想到半個月后癣防,有當地人在樹林里發(fā)現了一具尸體,經...
    沈念sama閱讀 45,341評論 1 311
  • 正文 獨居荒郊野嶺守林人離奇死亡掌眠,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 37,563評論 2 333
  • 正文 我和宋清朗相戀三年蕾盯,在試婚紗的時候發(fā)現自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片蓝丙。...
    茶點故事閱讀 39,731評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡刑枝,死狀恐怖,靈堂內的尸體忽然破棺而出迅腔,到底是詐尸還是另有隱情,我是刑警寧澤靠娱,帶...
    沈念sama閱讀 35,430評論 5 343
  • 正文 年R本政府宣布沧烈,位于F島的核電站,受9級特大地震影響像云,放射性物質發(fā)生泄漏锌雀。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,036評論 3 326
  • 文/蒙蒙 一迅诬、第九天 我趴在偏房一處隱蔽的房頂上張望腋逆。 院中可真熱鬧,春花似錦侈贷、人聲如沸惩歉。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,676評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽撑蚌。三九已至,卻和暖如春搏屑,著一層夾襖步出監(jiān)牢的瞬間争涌,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,829評論 1 269
  • 我被黑心中介騙來泰國打工辣恋, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留亮垫,地道東北人。 一個月前我還...
    沈念sama閱讀 47,743評論 2 368
  • 正文 我出身青樓伟骨,卻偏偏與公主長得像饮潦,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子携狭,可洞房花燭夜當晚...
    茶點故事閱讀 44,629評論 2 354

推薦閱讀更多精彩內容