java - socket類服務端如何防止被ddos攻擊?
問題描述
比如說我用socket,或者swoole的websocket服務器編寫一個游戲服務端,但是客戶端可以通過無限發(fā)包的方式來攻擊我的游戲服務端,導致服務端崩潰,請問目前有什么比較好的方案可以防止這類ddos,cc攻擊?(像網(wǎng)上各種cdn都只能防HTTP類型的請求攻擊)
聽別人說有硬件防火墻,但是如果我用阿里云騰訊云之類的服務器搭建服務端的話就沒辦法安硬件防火墻啊,有軟件可以做類似的防御嗎?
(不知道這里的朋友是否玩過英雄聯(lián)盟或者穿越火線,這些游戲曾經(jīng)都有各種炸房外掛,原理其實也是向他們的服務端發(fā)送大量垃圾數(shù)據(jù)包,或者超出正常頻率發(fā)送含有奇怪邏輯的數(shù)據(jù)包,導致同一個房間內(nèi)的其他訂閱了該游戲服務端某種消息的玩家也會短時間大量收到這些數(shù)據(jù)包從而讓客戶端崩潰掉線,可見連騰訊游戲之前都對這類攻擊沒什么防范措施)
問題解答
回答1:iptables對ip封鎖,限制每秒接受的請求次數(shù)等。。。或加白名單黑名單
回答2:是的。常見的云防火墻和軟件防火墻、流量清洗之類,都是針對的HTTP協(xié)議。針對TCP連接或數(shù)據(jù)過濾的防火墻在WEB開發(fā)中很少。但也不是沒有,例如這篇文章里面提到的DDOS就和題主的問題類似,所以題主的問題應該改為“如何防御TCP拒絕服務攻擊”
回答3:建議控制頻率,和寶合法性驗證。發(fā)現(xiàn)異常的IP,直接封掉。
相關文章:
1. javascript - 關于定時器 與 防止連續(xù)點擊 問題2. javascript - 在IE中(9+)平時的樣式不生效,只有用開發(fā)者工具選中這個元素才生效,是什么原因?3. objective-c - ios百度地圖定位問題4. html - vue里面:src在IE(9-11)下不顯示圖片5. javascript - 關于這組數(shù)據(jù)如何實現(xiàn) 按字母列表分類展示 不改動數(shù)據(jù)結構6. javascript - 求助這種功能有什么好點的插件?7. javascript - ie11以下單擊打開不了file,雙擊可以。求解?8. html5 - rudy編譯sass的時候有中文報錯9. javascript - 寫移動端的頁面的時候,有不一快空白,是怎么回事?10. 微信開放平臺 - Android調(diào)用微信分享不顯示
