linux 限制单个ip流量,centos 的單ip流量控制-CentOS下利用iptables限速及限制每IP連接數...

第一步:建立adsl連接,在系統設置——網絡設置處有。在圖形界面下很容易搞定。

第二步:打開IP轉發和偽裝(也就是路由與NAT)

1、作為根用戶打開/etc/sysconfig/network文件,在文件增加以下一行: GATEWAYDEV=PPP0 這句話的作用是設定默認路由,有時沒有也可

2、打開IP轉發功能:打開/etc/sysctl.conf文件,修改net.ipv4.ip_forward=0一行,改0改為1

3、重啟系統 第三步,設置iptables防火牆,決定那些IP能通過linux主機上網。 下面以允許 192.168.0.0網段為例:

(1)、打開終端在#字提示符下輸入以下命令:

iptables -t nat -I POSTROUTING -o ppp0 -j MASQUERADE #這句意思是偽裝從pppo出去的

IP iptables -A FORWARD -s 192.168.0.0/24 -j ACCEPT #這句意思是轉發來自192.168.0.0網段的通訊

iptables -A FORWARD -d 192.168.0.0/24 -j ACCEPT #這句意思是轉發到達192.168.0.0網段的通訊

iptables -A FORWARD -s ! 192.168.0.0/24 -j DROP #這句意思是拒絕轉發非192.168.0.0網段的通訊。

(2)、保存以上防火牆規則,以保證重啟后還有效 輸入下面命令 iptables-save > /etc/sysconfig/iptables 這樣,你的linux路由器應該就能跑起來了。

PS: 所有命令都要區分大小寫。 限速的實現:在linux中有專門限速的軟件--tc,但TC的語法新手難以掌握,我們可以在防火牆上通過限定某個IP或某段IP在一秒內通過的數據包的 數量來限速。 下面以限制192.168.0.2這個IP的網速為例說說。 在桌面環境下打開/etc/syscofngi/iptables 有沒有發現,剛才的設定全記錄在這個文件里,現在做的就在這個文件里添加規則就得了。

1、先要找到filter

2、在filter下面一行增加以下兩行

-A FORWARD -m limit -d 192.168.0.2 --limit 30/sec -j ACCEPT # 這句意思是限定每秒只轉發30個到達192.168.0.2的數據包(約每秒45KB 一個數據包是1.5KB)

-A FORWARD -d 192.168.0.2 -j DROP #這句作用是超過限制的到達192.168.0.2的數據包不通過)

(3)、重啟系統,限速就實現了。

(4)、限制上傳速度也一樣,把上面兩條中的d 改為s就得了。 限制每ip連接數 ,內核 2.3以上,否則要打conlimit補丁,重編譯內核。

iptables -I FORWARD -p tcp -s 192.168.0.0/24 -m connlimit --connlimit-above 20 -j REJECT

iptables -I INPUT -p tcp -s 192.168.0.0/24 -m connlimit --connlimit-above 20 -j REJECT

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值