 鲜花( 0)  鸡蛋( 0)
|
网吧用ROS的个人看法4 B, M: _) F7 F
2 [0 p7 s% h; y1 v3 W
一直以来,都看论坛上的达人说ROS做软路由器效果是多么的强大,于是偶也搞一个试试看。找了一个2.9.27的完全 *** 版,用了2块D-LINK530的网卡,装完一用还真行。比我那1000的锐捷强多了,网吧120台机器,座满的时候那个锐捷的路由器登陆界面都打不开。用上以后问题就来了,我们30M的光纤,如果不限速,那些下载狂人把带宽全部给占用了,打游戏的顾客很有意见。于是我就做了个限速,每个机器下载最大2M.平均1M。但是群众还是不满意,都所卡。我又找资料,pps影音标准版2010下载,发现原来还有个叫智能动态限速的东西,好偶照做。做好以后,平时喊卡的人没有了,人多的时候一样都喊卡。
/ D& S+ \3 _+ f: m, b偶傻眼了,难道只能不限速。还好天无绝人之路,还有个“小包优先”的高级货,于是照做。结果用简单队列限速后,“小包优先”也是白搭,难道天要忘我。终于经过N次测试以后,魔兽改键精灵4.5下载,我明白了。网吧用简单队列做限速完全是扯蛋。网吧限速最好的办法应该是带宽均分,然后在用简单队列来限制上传。在利用小包优先来处理游戏卡的问题。经过2个网吧,一个月的测试,完全摆脱了到处喊卡的噩梦,现在把经验发来大家分享一下。
. t4 }) `+ T6 k5 G2 t% g9 iROS不要用简单队列来限速,什么智能动态限速也不要用。只需要用小包优先+带宽均分+简单队列限制上传速度,360安全卫士7.0下载。
9 F$ h& I- Y, g小包优先的脚本如下:
0 F% Q4 Q7 X( M+ w B5 R. V, nip firewall mangle
/ U% I5 m6 A' A7 q7 ]) o: Vadd chain=forward p2p=all-p2p action=mark-connection new-connection-mark=p2p_conn passthrough=yes comment="" disabled=no - H% q0 Y" a& t' M0 `3 v# I2 Z2 X
add chain=forward connection-mark=p2p_conn action=mark-packet new-packet-mark=p2p passthrough=yes comment="" disabled=no
, o" z" U/ a2 U' _5 n; l9 eadd chain=forward connection-mark=!p2p_conn action=mark-packet new-packet-mark=general passthrough=yes comment="" disabled=no
& k$ z; f' z! Y- A8 l- H" yadd chain=forward packet-size=32-512 action=mark-packet new-packet-mark=small passthrough=yes comment="" disabled=no " E& f8 u; z8 w# Z) q
add chain=forward packet-size=512-1200 action=mark-packet new-packet-mark=big passthrough=yes comment="" disabled=no0 r/ q3 a n" ?
6 z3 l' f; J! V. \$ ^
/ queue tree
6 Y; m6 B* X* y* L+ U9 `1 M4 nadd name="p2p1" parent=wan packet-mark=p2p limit-at=2000000 queue=default priority=8 max-limit=6000000 burst-limit=0 burst-threshold=0 burst-time=0s disabled=no
7 B) E# L4 x) {0 j. L h$ Fadd name="p2p2" parent=lan packet-mark=p2p limit-at=2000000 queue=default priority=8 max-limit=6000000 burst-limit=0 burst-threshold=0 burst-time=0s disabled=no
$ k! u2 F* `) g+ |! u) v* X+ v- v6 yadd name="ClassA" parent=lan packet-mark="" limit-at=0 queue=default priority=8 max-limit=100000000 burst-limit=0 burst-threshold=0 burst-time=0s disabled=no + q5 ]3 D; [5 ]) N5 K
add name="ClassB" parent=ClassA packet-mark="" limit-at=0 queue=default priority=8 max-limit=0 burst-limit=0 burst-threshold=0 burst-time=0s disabled=no 4 z4 e- n: G; A6 `+ c. g# E& D' }
add name="Leaf1" parent=ClassA packet-mark=general limit-at=0 queue=default priority=7 max-limit=0 burst-limit=0 burst-threshold=0 burst-time=0s disabled=no
# s1 L; Y; M, K8 }7 ^add name="Leaf2" parent=ClassB packet-mark=small limit-at=0 queue=default priority=5 max-limit=0 burst-limit=0 burst-threshold=0 burst-time=0s disabled=no
; R5 H+ ?( ? p+ o/ cadd name="Leaf3" parent=ClassB packet-mark=big limit-at=0 queue=default priority=6 max-limit=0 burst-limit=0 burst-threshold=0 burst-time=0s disabled=no; y: ?9 W! p: p5 d' x
然后是带宽均分:& q9 O7 W8 P4 J- x
/ip firewall mangle add chain=forward src-address=192.168.0.0/24 \/ d0 Q. W9 j6 H- f
action=mark-connection new-connection-mark=users-con
& ~( q3 |6 U' U5 V- A' b+ m. K/ip firewall mangle add connection-mark=users-con action=mark-packet \
2 j: k& ^" y$ ~3 M3 g9 F4 L4 R' |new-packet-mark=users chain=forward+ D2 |2 o' ?4 H, s4 B' U4 r
/queue type add name=pcq-download kind=pcq pcq-classifier=dst-address
$ O3 W% C/ M- i. t& D" n7 g/queue type add name=pcq-upload kind=pcq pcq-classifier=src-address" h( c# L; z5 w6 M$ H
/queue tree add name=Download parent=lan max-limit=30M, ?2 u2 v$ w1 R5 u
/queue tree add parent=Download queue=pcq-download packet-mark=users% X) p% K2 q' q& J
/queue tree add name=Upload parent=wan max-limit=28M; ?* U6 g- l K
/queue tree add parent=Upload queue=pcq-upload packet-mark=users
/ H# X( N5 U4 q: r请根据直接实际修改IP地址段,下载最大速度,上传最大速度,lan为我连接内网的网卡,wan是我连接外网的网卡
; I; e8 `1 s% R! @9 C' T1 R; e限制上传速度的脚本:% A! N' f" Y& p3 O1 z
:for aaa from 2 to 180 do={/queue simple add name=(PC . $aaa) dst-address=(192.168.0. . $aaa) limit-at=10000000/3000000 max-limit=30000000/3000000}6 S7 p2 }& Z+ ]9 q" j
如果是3.2版本的,这个脚本自己要修改下,, U7 h/ d' x$ b, s( W% o
就用这3个部分,别的不需要的,绝对比什么智能动态限速好的多。 |
|