免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1156 | 回复: 5
打印 上一主题 下一主题

需要对某一端口的所有连接做速度限制(如web 限制30k),请问如何实现? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2006-04-24 13:19 |只看该作者 |倒序浏览
需要在linux 路由或网桥上面做
tc是不行的,因为客户端是不固定的。

iptables的扩展模块不知道有没有实现了这个功能的。
如果iptables不行,能否通过netfilter hook做?
netfilter hook->判断dst/src为ip/port 的所有ip包,根据对端ip/port分别做限速计数。(用tbf)
但是netfilter hookl里面能用定时器么?如何使用?
请有经验的给点思路。

论坛徽章:
0
2 [报告]
发表于 2006-04-24 14:00 |只看该作者
tc是可以实现的!

tc qdisc add dev $LAN_IFACE root handle 1: htb default 40
tc class add dev $LAN_IFACE parent 1: classid 1:1 htb rate 2mbit burst 15k
tc class add dev $LAN_IFACE parent 1:1 classid 1:10 htb rate 1600Kbit burst 15k
tc class add dev $LAN_IFACE parent 1:1 classid 1:20 htb rate 1200Kbit ceil 2mbit burst 15k
tc class add dev $LAN_IFACE parent 1:1 classid 1:30 htb rate 30Kbit ceil 2mbit burst 15k

tc qdisc add dev $LAN_IFACE parent 1:10 handle 10: sfq perturb 10
tc qdisc add dev $LAN_IFACE parent 1:20 handle 20: sfq perturb 10
tc qdisc add dev $LAN_IFACE parent 1:30 handle 30: sfq perturb 10

U32="tc filter add dev $LAN_IFACE protocol ip parent 1:0 prio 1 u32"

$U32 match ip dport 80 0xffff flowid 1:30 限制web在30K

论坛徽章:
0
3 [报告]
发表于 2006-04-24 14:14 |只看该作者
你可能没理解我的意思哦,是web每连接30k......不是总共的

论坛徽章:
0
4 [报告]
发表于 2006-04-24 14:25 |只看该作者
apache 自带限速功能,可以限制每个连接的速率

论坛徽章:
0
5 [报告]
发表于 2006-04-25 14:19 |只看该作者
晕。我只是用web做例子唉......
这么跟你说吧,linux路由器后面有个服务器,很多客户端连接上去,现在想给每个客户端分配50k速度。
服务器端没有限速功能,所以想在路由上面做

论坛徽章:
0
6 [报告]
发表于 2006-04-26 11:00 |只看该作者
那就分别在各自的软件上做限速
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP