 鲜花( 0)  鸡蛋( 0)
|
网吧用ROS的个人看法
" x5 i1 M; M2 [2 X! L0 ]; P ! P0 A* N/ u- |$ w/ W3 y: C; W" B
一直以来,都看论坛上的达人说ROS做软路由器效果是多么的强大,于是偶也搞一个试试看。找了一个2.9.27的完全 *** 版,用了2块D-LINK530的网卡,装完一用还真行。比我那1000的锐捷强多了,网吧120台机器,座满的时候那个锐捷的路由器登陆界面都打不开。用上以后问题就来了,我们30M的光纤,如果不限速,那些下载狂人把带宽全部给占用了,打游戏的顾客很有意见。于是我就做了个限速,每个机器下载最大2M.平均1M。但是群众还是不满意,都所卡。我又找资料,pps影音标准版2010下载,发现原来还有个叫智能动态限速的东西,好偶照做。做好以后,平时喊卡的人没有了,人多的时候一样都喊卡。
/ E" G' }5 O% R偶傻眼了,难道只能不限速。还好天无绝人之路,还有个“小包优先”的高级货,于是照做。结果用简单队列限速后,“小包优先”也是白搭,难道天要忘我。终于经过N次测试以后,魔兽改键精灵4.5下载,我明白了。网吧用简单队列做限速完全是扯蛋。网吧限速最好的办法应该是带宽均分,然后在用简单队列来限制上传。在利用小包优先来处理游戏卡的问题。经过2个网吧,一个月的测试,完全摆脱了到处喊卡的噩梦,现在把经验发来大家分享一下。. E# s9 P' Y1 z( p
ROS不要用简单队列来限速,什么智能动态限速也不要用。只需要用小包优先+带宽均分+简单队列限制上传速度,360安全卫士7.0下载。) g+ F4 a% g; x3 j. y4 R
小包优先的脚本如下:
! c* ~+ b7 }, U- a9 {. Wip firewall mangle
. E( x( R! T& r2 y1 C: _$ madd chain=forward p2p=all-p2p action=mark-connection new-connection-mark=p2p_conn passthrough=yes comment="" disabled=no
# X: v) t$ [5 g aadd chain=forward connection-mark=p2p_conn action=mark-packet new-packet-mark=p2p passthrough=yes comment="" disabled=no + T) \7 g2 n7 j( K
add chain=forward connection-mark=!p2p_conn action=mark-packet new-packet-mark=general passthrough=yes comment="" disabled=no 4 |1 ^$ |3 X0 p
add chain=forward packet-size=32-512 action=mark-packet new-packet-mark=small passthrough=yes comment="" disabled=no ! H3 L, h& S# j0 b, |
add chain=forward packet-size=512-1200 action=mark-packet new-packet-mark=big passthrough=yes comment="" disabled=no: r: \: l) f# {6 y/ v
$ ^9 _9 p/ P4 S! K& x/ F8 a+ v( C6 {
/ queue tree , Z. \5 P1 p& o, I c
add 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
' ~( J/ f1 j: D+ y; Padd 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 6 V' D4 `6 B4 r9 I3 P
add 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
% C1 P; Z: i5 J0 w, R! d5 p" }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 ; `* f9 R6 S) J# M; b
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 $ y/ x$ A6 ^3 q& R, B
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 $ [. M2 X) w: D" C
add 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. Q1 z% S" d8 R+ J' x3 r
然后是带宽均分:8 _3 \* h$ [% H. R7 s. G7 ^0 @
/ip firewall mangle add chain=forward src-address=192.168.0.0/24 \. J4 N% A. E& ^
action=mark-connection new-connection-mark=users-con% q5 `2 K: \7 k1 _% S; q- g
/ip firewall mangle add connection-mark=users-con action=mark-packet \
5 a, I# A) S, G: b, n% t7 I' ?7 u. Gnew-packet-mark=users chain=forward7 ]0 u( n- t$ T
/queue type add name=pcq-download kind=pcq pcq-classifier=dst-address' A# [' n6 }% h% z' H# Q) _' v' e
/queue type add name=pcq-upload kind=pcq pcq-classifier=src-address
$ F6 m' ]# \. Q/queue tree add name=Download parent=lan max-limit=30M
+ ^3 A) O. j/ J9 ]( k# ^6 O( l2 c& G/queue tree add parent=Download queue=pcq-download packet-mark=users
# O2 N; \ w% t! l N7 p/queue tree add name=Upload parent=wan max-limit=28M
* [5 }9 d7 Z# a3 M/queue tree add parent=Upload queue=pcq-upload packet-mark=users/ G1 f) U: W, w% O
请根据直接实际修改IP地址段,下载最大速度,上传最大速度,lan为我连接内网的网卡,wan是我连接外网的网卡
: g4 @) H$ Z% c限制上传速度的脚本:1 M# f k- Q! Q# Z4 O
: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}. O/ M1 M& _- O8 O) r7 V2 S, E$ P
如果是3.2版本的,这个脚本自己要修改下,
! D- z( @ m0 L( u4 r1 l就用这3个部分,别的不需要的,绝对比什么智能动态限速好的多。 |
|