互联网< -128kbps链接 - > Cisco路由器(公共IP)< -LAN-> Linux路由器/服务器(公共IP)< -LAN->普通电脑(公共IP)
Cisco路由器:
>第一个分配给我的公共IP
机构(/ 29)
>被编程为发送所有数据包
通过Linux路由器
Linux路由器
>分配给我的第二个公共IP
机构
>被编程为转发数据包
常规PC和思科之间
路由器
>也充当服务器(邮件,网络等)
常规PC(其中4个):
>其余的公共IP
>使用Linux路由器作为网关
我启用了Linux路由器上的iptables数据包登录,有时我发现:
>有些数据包很大,大于
20KB.这是正常的吗? (是的,这是正常的.这些不是数据包,这些是IP数据报,正如Some Guy所说的那样)
>传输数据的次数过多
(在互联网上)比大
16KB.例如在一个特定的
第二个10572字节进入(没有
问题),63521字节输出(到
思科路由器).这需要4个
秒至少发送64KB
通过128kbps链接.与此同时
Linux路由器正在发送更多数据
到思科路由器堵塞它
缓冲区.不好.
现在,我如何配置Linux路由器以这样的方式塑造流量:
>保持传输速度最大化
当交通在这些之间时
普通PC和Linux服务器.
>减慢到外面的流量
世界,以避免堵塞“出”
线,使用所有(或几乎所有)
可用带宽(128 kbps).没有
更多“> 16KB秒”
跟踪.
>保证每个常规24kbps
PC,24kbps到Linux服务器
随时. (剩余8bkps用于开销
如有必要). IOW,5(伪)
“乐队”,每个24kbps.
>如果有任何PC没有使用
它的全频段,相当分享闲置
其余部分的带宽
传输PC
>优先考虑某些数据包
(DNS查找,控制数据包),拿
远离他人的优先权
(洪流!!!),INSIDE每个乐队,和
不影响其他乐队.
我已经为每台PC标记了(使用IP表–set-xmark选项)每个传出数据包:
> Linux路由器对外界,
高prio
> Linux路由器对外界,
正常的prio
> Linux路由器对外界,
低prio
>第一台常规PC到外面
世界,高prio
… 等等.
每个传入的数据包也使用此方案从16开始标记.
对于这个长期的问题,我很抱歉,但是我已经放弃了使用tc命令设置它,关于流量整形的文档太少,我不知道下一步该去哪里.
解决方法
tc qdisc add dev eth0 root handle 1: htb default 2 # 100 mbps tc class add dev eth0 parent 1: classid 1:1 htb rate 100mbit # To LAN traffic tc class add dev eth0 parent 1:1 classid 1:2 htb rate 99000kbit ceil 100mbit # IN traffic tc class add dev eth0 parent 1:1 classid 1:3 htb rate 120kbit # OUT traffic tc class add dev eth0 parent 1:1 classid 1:4 htb rate 120kbit # IN “bands” (one for each PC) tc class add dev eth0 parent 1:3 classid 1:10 htb rate 24kbit ceil 120kbit tc class add dev eth0 parent 1:3 classid 1:11 htb rate 24kbit ceil 120kbit tc class add dev eth0 parent 1:3 classid 1:12 htb rate 24kbit ceil 120kbit tc class add dev eth0 parent 1:3 classid 1:13 htb rate 24kbit ceil 120kbit tc class add dev eth0 parent 1:3 classid 1:14 htb rate 24kbit ceil 120kbit # OUT “bands” (one for each PC) tc class add dev eth0 parent 1:4 classid 1:15 htb rate 24kbit ceil 120kbit tc class add dev eth0 parent 1:4 classid 1:16 htb rate 24kbit ceil 120kbit tc class add dev eth0 parent 1:4 classid 1:17 htb rate 24kbit ceil 120kbit tc class add dev eth0 parent 1:4 classid 1:18 htb rate 24kbit ceil 120kbit tc class add dev eth0 parent 1:4 classid 1:19 htb rate 24kbit ceil 120kbit
会得到这样的东西:
+-----------------------------------------------------------+ | 100 mbits (1:1) | +---------+------------------------+------------------------+ | 99mbits | 120 kbits In (1:3) | 120 kbits Out(1:4) | + (1:2) +----+----+----+----+----+----+----+----+----+----+ +---------+ PC1| PC2| PC3| PC4| PC5| PC1| PC2| PC3| PC4| PC5| |1:10|1:11|1:12|1:13|1:14|1:15|1:16|1:17|1:18|1:19| +----+----+----+----+----+----+----+----+----+----+
对于每个乐队:
# PC1,IN tc qdisc add dev eth0 parent 1:10 handle 20: prio tc qdisc add dev eth0 parent 20:1 handle 22: sfq perturb 10 tc qdisc add dev eth0 parent 20:2 handle 23: sfq perturb 10 tc qdisc add dev eth0 parent 20:3 handle 24: sfq perturb 10 # PC1,OUT tc qdisc add dev eth0 parent 1:15 handle 21: prio tc qdisc add dev eth0 parent 21:1 handle 25: sfq perturb 10 tc qdisc add dev eth0 parent 21:2 handle 26: sfq perturb 10 tc qdisc add dev eth0 parent 21:3 handle 27: sfq perturb 10 +--------------------++--------------------+ | PC1 IN || PC1 OUT | +--------------------++--------------------+ | PRIO (20:0) || PRIO (21:0) | | | | || | | | | Prio | Prio | Prio || Prio | Prio | Prio | | 1 | 2 | 3 || 1 | 2 | 3 | |(20:1)|(20:2)|(20:3)||(21:1)|(21:2)|(21:3)| +------+------+------++------+------+------+ | SFQ | SFQ | SFQ || SFQ | SFQ | SFQ | |(22:0)|(23:0)|(24:0)||(25:0)|(26:0)|(27:0)| +------+------+------++------+------+------+
等等.
规则应该是这样的
# PC1,OUT tc filter add dev eth0 protocol ip parent 1:0 prio 1 handle 1 fw flowid 21:1 tc filter add dev eth0 protocol ip parent 1:0 prio 1 handle 2 fw flowid 21:2 tc filter add dev eth0 protocol ip parent 1:0 prio 1 handle 3 fw flowid 21:3 # PC1,IN tc filter add dev eth0 protocol ip parent 1:0 prio 1 handle 16 fw flowid 20:1 tc filter add dev eth0 protocol ip parent 1:0 prio 1 handle 17 fw flowid 20:2 tc filter add dev eth0 protocol ip parent 1:0 prio 1 handle 18 fw flowid 20:3
等等.
有什么建议,评论等吗? (我没有该领域的经验)