2009-05-09 xiao H Posted in shell
网吧以前是没做限速的,但最近遇到几个狂爱看A片的哥们,用不知什么东西下载的,好几次把带宽占个精光,所以不得不做了限速。
总体思想很简单,为每个IP 打标,然后归入各自的tc 限速规则中去。
#!/bin/sh # xiaoh www.linuxbyte.org # 定义进出设备(eth0 内网,eth1外网) IDEV="eth0" ODEV="eth1" # 定义总的上下带宽 UP="50mbit" DOWN="50mbit" # 定义每个受限制的IP上下带宽 #rate 起始带宽 UPLOAD="4mbit" DOWNLOAD="5mbit" #ceil 最大带宽 MUPLOAD="5mbit" MDOWNLOAD="10mbit" #内网IP段 INET="192.168.0." # 受限IP范围,IPS 起始IP,IPE 结束IP。 IPS="1" IPE="114" # 清除网卡原有队列规则 tc qdisc del dev $ODEV root 2>/dev/null tc qdisc del dev $IDEV root 2>/dev/null # 定义最顶层(根)队列规则,并指定 default 类别编号 tc qdisc add dev $ODEV root handle 10: htb default 256 tc qdisc add dev $IDEV root handle 10: htb default 256 # 定义第一层的 10:1 类别 (上行/下行 总带宽) tc class add dev $ODEV parent 10: classid 10:1 htb rate $UP ceil $UP tc class add dev $IDEV parent 10: classid 10:1 htb rate $DOWN ceil $DOWN #开始iptables 打标和设置具体规则 i=$IPS; while [ $i -le $IPE ] do tc class add dev $ODEV parent 10:1 classid 10:2$i htb rate $UPLOAD ceil $MUPLOAD prio 1 tc qdisc add dev $ODEV parent 10:2$i handle 100$i: pfifo tc filter add dev $ODEV parent 10: protocol ip prio 100 handle 2$i fw classid 10:2$i tc class add dev $IDEV parent 10:1 classid 10:2$i htb rate $DOWNLOAD ceil $MDOWNLOAD prio 1 tc qdisc add dev $IDEV parent 10:2$i handle 100$i: pfifo tc filter add dev $IDEV parent 10: protocol ip prio 100 handle 2$i fw classid 10:2$i iptables -t mangle -A PREROUTING -s $INET$i -j MARK --set-mark 2$i iptables -t mangle -A PREROUTING -s $INET$i -j RETURN iptables -t mangle -A POSTROUTING -d $INET$i -j MARK --set-mark 2$i iptables -t mangle -A POSTROUTING -d $INET$i -j RETURN i=`expr $i + 1` done
除特别声明外,本站作品皆为原创并以知识共享署名-相同方式共享 3.0 许可协议进行许可。
转载请注明 作者:xiao H,出处:linuxbyte.org ,原始链接:Iptables+tc 网吧每IP 限速脚本
不知道是不是正的能用噢
这是我正在使用的脚本,不过这个脚本的效率不行,如果机子很多的话,N多条mangle 规则之后丢包是必然的。现在在考虑针对应用作规则,打上ip2p 补丁,然后限制这类服务的总带宽。
厉害啊
博主
收藏了
会经常来学习的
哈哈,正学LINUX,收藏了!
想用LINUX架服务器,可惜不会,博主的文章。。。真是雪中送炭!谢谢!