java - socket類服務(wù)端如何防止被ddos攻擊?
問題描述
比如說我用socket,或者swoole的websocket服務(wù)器編寫一個游戲服務(wù)端,但是客戶端可以通過無限發(fā)包的方式來攻擊我的游戲服務(wù)端,導(dǎo)致服務(wù)端崩潰,請問目前有什么比較好的方案可以防止這類ddos,cc攻擊?(像網(wǎng)上各種cdn都只能防HTTP類型的請求攻擊)
聽別人說有硬件防火墻,但是如果我用阿里云騰訊云之類的服務(wù)器搭建服務(wù)端的話就沒辦法安硬件防火墻啊,有軟件可以做類似的防御嗎?
(不知道這里的朋友是否玩過英雄聯(lián)盟或者穿越火線,這些游戲曾經(jīng)都有各種炸房外掛,原理其實也是向他們的服務(wù)端發(fā)送大量垃圾數(shù)據(jù)包,或者超出正常頻率發(fā)送含有奇怪邏輯的數(shù)據(jù)包,導(dǎo)致同一個房間內(nèi)的其他訂閱了該游戲服務(wù)端某種消息的玩家也會短時間大量收到這些數(shù)據(jù)包從而讓客戶端崩潰掉線,可見連騰訊游戲之前都對這類攻擊沒什么防范措施)
問題解答
回答1:iptables對ip封鎖,限制每秒接受的請求次數(shù)等。。。或加白名單黑名單
回答2:是的。常見的云防火墻和軟件防火墻、流量清洗之類,都是針對的HTTP協(xié)議。針對TCP連接或數(shù)據(jù)過濾的防火墻在WEB開發(fā)中很少。但也不是沒有,例如這篇文章里面提到的DDOS就和題主的問題類似,所以題主的問題應(yīng)該改為“如何防御TCP拒絕服務(wù)攻擊”
回答3:建議控制頻率,和寶合法性驗證。發(fā)現(xiàn)異常的IP,直接封掉。
相關(guān)文章:
1. mac OSX10.12.4 (16E195)下Mysql 5.7.18找不到配置文件my.cnf2. mysql - 怎么生成這個sql表?3. mysql儲存json錯誤4. php - 公眾號文章底部的小程序二維碼如何統(tǒng)計?5. mysql - 表名稱前綴到底有啥用?6. mysql - 數(shù)據(jù)庫表中,兩個表互為外鍵參考如何解決7. Navicat for mysql 中以json格式儲存的數(shù)據(jù)存在大量反斜杠,如何去除?8. 在mybatis使用mysql的ON DUPLICATE KEY UPDATE語法實現(xiàn)存在即更新應(yīng)該使用哪個標簽?9. mysql - 數(shù)據(jù)庫建字段,默認值空和empty string有什么區(qū)別 11010. sql語句 - 如何在mysql中批量添加用戶?
