Re: [LARTC] Ethloop again and 4 level tree ???

Linux Advanced Routing and Traffic Control

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Dear Martin,

Hello again, Thank you for you help last time.
I think I understand the solution form you and Stef, but when come to
ethloop, the result is not like this. I repost the question, I am pleased
if you can give me a quick fix of the problem? Sorry to bother you.

I try to create final checkfor htb, and still found the same problem. 
 
 			1:1 (ceil 1500kbps)
 		      /     \
   (ceil 800kbps)   1:2	    1:8 (ceil 700kbps)
 		  /    \      \
 	        1:4   1:12    1:14
 	       /  \
    (prio 0) 1:10  1:11 (prio 1)
 
The tree under 1:2 is almost the same as you example and is working.
And I try to build a larger tree (4 levels) and I would like to do
following:
class 1:14 is completed isolated even no traffic, the BW will not borow.
class 1:12 is empty all the time.
class 1:10 is prio 0 and class 1:11 is prio 1
 
1. My understanding is 1:8 and 1:2 are isolated because of ceil and will
    not borrow?
2. Since 1:12 is always empty, it can borrow the excess to tree 1:4 and
   1:10 will get all the BW wiht prio 0.
 
But in my case, the prio parameter seems to be not working well. It will
give BW to both 1:10 and 1:11.The result I got using Ethloop is not like that.

I try to start 1:10 at 300k, 1:11 at 100k, since 1:4 parent ceil is 800bps
remind will be 400k.

At time 10s, I put 1:10 at 900k and 1:11 at 900k, and I think the 400kbs
excess will all go to 1:10 and make the flow 1:10 be 700kbs ( < 1:4 ceil ).

>From the ethloop result, 1:10 from 30 go to 50.  (equal sharing)
                         1:11 form 10 go to 30.  (eqaul sharing)

Do you think the problem is on HTB script or ethloop script or both????

My HTB:
 
echo "sim7 can do the priority BW"
 
echo Clean all the tc setup
./tc qdisc del dev lo root
 
./tc qdisc add dev lo root handle 1: htb default 12
 
./tc class add dev lo parent 1: classid 1:1 htb rate 1500kbps ceil
1500kbps
 
echo "AF and BE"
./tc class add dev lo parent 1:1 classid 1:2 htb rate 100kbps ceil 800kbps
./tc class add dev lo parent 1:2 classid 1:4 htb rate 100nbps ceil 800kbps
./tc class add dev lo parent 1:2 classid 1:10 htb rate 300kbps ceil 800kbps prio 0
./tc class add dev lo parent 1:2 classid 1:11 htb rate 100kbps ceil 800kbps prio 1
./tc class add dev lo parent 1:1 classid 1:12 htb rate 100kbps ceil 800kbps
 
echo "EF"
./tc class add dev lo parent 1:1 classid 1:8 htb rate 100kbps ceil 700kbps
./tc class add dev lo parent 1:8 classid 1:14 htb rate 100kbps ceil 700kbps
 
echo qdisc for AF and BE
./tc qdisc add dev lo parent 1:10 handle 20: pfifo limit 5
./tc qdisc add dev lo parent 1:11 handle 30: pfifo limit 5
./tc qdisc add dev lo parent 1:12 handle 40: sfq perturb 10
echo qdisc EF
./tc qdisc add dev lo parent 1:14 handle 50: sfq perturb 10
 
 
My testcase:
 
# set simulation packet size to 1k
0       S       0       1k
0       S       1       1k
0       S       2       1k
0       S       3       1k
# flow 0 AF, flow 1  BE, flow 2 excess, flow 3 EF
0       P       0       0x10010
0       P       1       0x10011
0       P       2       0x10012
0       P       3       0x10014
# start all flow at defined rate
0       R       0       300k
0       R       1       100k
0       R       2       0
0       R       3       700k
# AE/BE independent of EF
 
# AE and BE flow higher than normal excess <---Both will get BW ????
10000    R      0       900k
10000    R      1       900k
 
# AE and BE back to normal excess <-- Go back to original case and try again
15000    R      0       300k
15000    R      1       100k
 
# BE flow higher than normal excess <---no prio flow, allow lower prio to get BW
20000    R      1       900k
 
# AF flow higher than normal <---flow for low prio, both will get BW ????
25000    R      0       900k
 
# EF flow higher than normal
30000   R       3       900k
 
35000    X      0        0
 
 
Result:
 
0.5 231444 231444 0 0 77383 77383 0 0 0 0 0 0 540271 478572 40 0   
1.0 278479 278479 0 0 92882 92882 0 0 0 0 0 0 609124 583719 61 0   
1.5 298901 298901 0 0 100509 100509 0 0 0 0 0 0 615354 611911 62 0
2.0 302205 302205 0 0 101279 101279 0 0 0 0 0 0 617530 617379 63 0 
2.5 305878 305878 0 0 102361 102361 0 0 0 0 0 0 616506 616471 63 0 
3.0 304599 304599 0 0 102921 102921 0 0 0 0 0 0 618702 618073 63 0 
3.5 307264 307264 0 0 102751 102751 0 0 0 0 0 0 618239 617715 63 0 
4.0 309582 309582 0 0 103272 103272 0 0 0 0 0 0 620044 619920 63 0 
4.5 309559 309559 0 0 103205 103205 0 0 0 0 0 0 619327 619298 63 0 
5.0 304899 304899 0 0 102930 102930 0 0 0 0 0 0 621407 619538 63 0 
5.5 307757 307757 0 0 102893 102893 0 0 0 0 0 0 618269 617825 63 0 
6.0 307659 307659 0 0 102626 102626 0 0 0 0 0 0 615972 615867 63 0 
6.5 308994 308994 0 0 103015 103015 0 0 0 0 0 0 618143 618118 63 0 
7.0 304329 304329 0 0 102740 102740 0 0 0 0 0 0 620014 617526 61 0   
7.5 307540 307540 0 0 102821 102821 0 0 0 0 0 0 617775 617184 63 0 
8.0 308544 308544 0 0 102921 102921 0 0 0 0 0 0 617728 617588 63 0 
8.5 308877 308877 0 0 102976 102976 0 0 0 0 0 0 619844 619811 63 0 
9.0 302607 302607 0 0 100873 100873 0 0 0 0 0 0 620449 617339 61 0 
9.5 306437 306437 0 0 102147 102147 0 0 0 0 0 0 616490 615752 63 0 
10.0 300719 300719 0 0 100240 100240 0 0 0 0 0 0 604882 617636 63 0
10.5 777898 471982 0 0 729513 264159 0 0 0 0 0 0 609705 618402 43 0
11.0 863025 505560 0 0 851542 297668 0 0 0 0 0 0 619129 616713 41 0
11.5 909551 512577 0 0 906826 306202 0 0 0 0 0 0 618050 617476 43 0
12.0 921768 513819 0 0 921121 307972 0 0 0 0 0 0 618739 618603 43 0
12.5 907931 513704 0 0 905857 308147 0 0 0 0 0 0 619284 616925 43 0
13.0 886514 523490 0 0 883462 304891 0 0 0 0 0 0 624941 617690 40 0
13.5 915565 515999 0 0 886622 307416 0 0 0 0 0 0 620989 619268 42 0
14.0 923631 514873 0 0 879157 308406 0 0 0 0 0 0 618273 617864 43 0
14.5 927437 515656 0 0 878626 309271 0 0 0 0 0 0 618889 618792 43 0
15.0 895009 532329 0 0 859566 299013 0 0 0 0 0 0 621768 617479 40 0
15.5 448147 362082 0 0 282565 149543 0 0 0 0 0 0 631565 619126 63 0
16.0 341084 320660 0 0 145299 113733 0 0 0 0 0 0 619346 616394 63 0
16.5 315486 310640 0 0 112662 105171 0 0 0 0 0 0 616065 615364 63 0
17.0 297585 296435 0 0 102699 100921 0 0 0 0 0 0 611654 619246 51 0
17.5 306021 305749 0 0 84149 83727 0 0 0 0 0 0 618384 617756 63 0  
18.0 308460 308395 0 0 84714 84614 0 0 0 0 0 0 618424 618275 63 0  
18.5 307777 307761 0 0 97575 97552 0 0 0 0 0 0 618070 618035 63 0
19.0 301490 301487 0 0 96855 96849 0 0 0 0 0 0 620032 618278 63 0  
19.5 301154 301153 0 0 98066 98065 0 0 0 0 0 0 620900 616848 63 0  
20.0 286469 286469 0 0 93726 93726 0 0 0 0 0 0 622997 616716 60 0  
20.5 278343 278343 0 0 673385 450580 0 0 0 0 0 0 622126 619319 55 0
21.0 268888 268888 0 0 803848 524704 0 0 0 0 0 0 611372 617699 46 0
21.5 264163 264163 0 0 848137 550577 0 0 0 0 0 0 616748 618975 60 0
22.0 290767 290767 0 0 904416 530316 0 0 0 0 0 0 619749 620278 55 0
22.5 298363 298363 0 0 902981 524515 0 0 0 0 0 0 618094 618219 60 0
23.0 296164 296164 0 0 894027 520963 0 0 0 0 0 0 620139 619658 60 0
23.5 305930 305930 0 0 919102 516374 0 0 0 0 0 0 618459 618345 60 0
24.0 296653 296653 0 0 891907 527558 0 0 0 0 0 0 617325 619622 60 0
24.5 302214 302214 0 0 908726 507221 0 0 0 0 0 0 620659 587427 60 0
25.0 281425 281425 0 0 848616 514517 3 0 0 0 0 0 599578 619178 51 0
25.5 729582 470403 0 0 890676 359409 0 0 0 0 0 0 618846 618637 43 0
26.0 840603 504053 0 0 914453 320744 0 0 0 0 0 0 617764 617714 43 0
26.5 841996 517336 0 0 864975 310744 0 0 0 0 0 0 602270 618756 43 0
27.0 863804 492801 11 0 869257 296796 11 0 0 0 0 0 592927 618803 43 0
27.5 907681 517564 0 0 908975 309183 0 0 0 0 0 0 621719 618679 43 0
28.0 874073 516131 0 0 876445 310199 0 0 0 0 0 0 616986 620472 40 0
28.5 911304 513526 0 0 911866 308239 0 0 0 0 0 0 615668 616495 43 0
29.0 921202 513498 0 0 921336 308128 0 0 0 0 0 0 617519 617715 43 0
29.5 886795 518855 0 0 888691 309211 0 0 0 0 0 0 619105 622497 40 0
30.0 867967 521988 0 0 871155 306927 1 0 0 0 0 0 617935 619478 40 0
30.5 775693 516624 1 0 777624 304519 1 0 0 0 0 0 605359 625650 40 0
31.0 786527 529944 2 0 790509 300677 2 0 0 0 0 0 621088 622072 46 0
31.5 827695 533777 0 0 830094 298140 0 0 0 0 0 0 652808 612476 43 0
32.0 818300 532576 0 0 821039 295613 0 0 0 0 0 0 647647 607022 41 0
32.5 810709 520589 0 0 813866 289856 1 0 0 0 0 0 632117 599990 43 0
33.0 843462 524122 0 0 844211 299315 0 0 0 0 0 0 639384 609260 43 0
33.5 799789 525951 0 0 802866 303504 0 0 0 0 0 0 621335 618217 43 0
34.0 786034 523152 0 0 790214 302283 0 0 0 0 0 0 619806 621308 43 0
35.0 936074 514486 0 0 936923 301056 0 0 0 0 0 0 637879 603055 43 0
 
Thank you, I spend four hours on it and can not find the reasons. :(
 
 Pat
 
 
 
> 
> 
> On Fri, 7 Jun 2002, King Yung Tong wrote:
> 
> > Thank you, I put 100kbps to both 1:11 and 1:10. 1:10 (prio 0) get almost
> > 50kbps form 60kbps excess and 1:20 (prio 1) get 10kbps form excess.
> > Is it the expected result?
> > I gussess the all 60kbps (excess) should go to prio 0 or by proportional
> > to rate in each class.
> > 
> > 
> > Pat
> > 
> > On Fri, 7 Jun 2002, Martin Devera wrote:
> > 
> > > Ok. It seems you generate only 40kbps by ethloop script. Then you
> > > can't expect your lines to go higher !
> > > Generate 100kbps to 1:11 and 1:10 ...
> > > devik
> > > 
> > > On Fri, 7 Jun 2002, King Yung Tong wrote:
> > > 
> > > > Here is the version and info.
> > > >
> > > > Version htb3_2.4.17
> > > >
> > > > [root@samwise htb]# ./tc -s -d class show dev lo
> > > > class htb 1:11 parent 1:2 leaf 30: prio 1 quantum 1024 rate 80Kbit ceil
> > > > 800Kbit burst 1701b/8 mpu 0b cburst 2623b/8 mpu 0b level 0
> > > >  Sent 130048 bytes 127 pkts (dropped 0, overlimits 0)
> > > >  rate 254bps
> > > >  lended: 100 borrowed: 27 giants: 0
> > > >  tokens: -60449 ctokens: 12800
> > > >
> > > > class htb 1:1 root rate 800Kbit ceil 800Kbit burst 2623b/8 mpu 0b cburst
> > > > 2623b/8 mpu 0b level 7  Sent 730112 bytes 713 pkts (dropped 0, overlimits
> > > > 0)
> > > >  rate 1426bps 1pps
> > > >  lended: 81 borrowed: 0 giants: 0
> > > >  tokens: 12800 ctokens: 12800
> > > >
> > > > class htb 1:10 parent 1:2 leaf 20: prio 0 quantum 3072 rate 240Kbit ceil
> > > > 800Kbit burst 1906b/8 mpu 0b cburst 2623b/8 mpu 0b level 0
> > > >  Sent 360448 bytes 352 pkts (dropped 0, overlimits 0)
> > > >  rate 704bps
> > > >  lended: 298 borrowed: 54 giants: 0
> > > >  tokens: -36462 ctokens: 12800
> > > >
> > > > class htb 1:2 parent 1:1 rate 320Kbit ceil 800Kbit burst 2008b/8 mpu 0b
> > > > cburst 2623b/8 mpu 0b level 6
> > > >  Sent 490496 bytes 479 pkts (dropped 0, overlimits 0)
> > > >  rate 958bps
> > > >  lended: 0 borrowed: 81 giants: 0
> > > >  tokens: -62221 ctokens: 12800
> > > >
> > > > class htb 1:12 parent 1:1 leaf 40: prio 0 quantum 6144 rate 480Kbit ceil
> > > > 800Kbit burst 2213b/8 mpu 0b cburst 2623b/8 mpu 0b level 0
> > > >  Sent 239616 bytes 234 pkts (dropped 0, overlimits 0)
> > > >  rate 426bps
> > > >  lended: 234 borrowed: 0 giants: 0
> > > >  tokens: 15867 ctokens: 12800
> > > >
> > > >
> > > >
> > > > result for all line with 100kbps (pic5)
> > > >
> > > > 0.5 23947 23947 0 0 7982 7982 0 0 45228 45228 0 0
> > > > 1.0 29036 29036 0 0 9571 9571 0 0 57118 57118 0 0
> > > > 1.5 29318 29318 0 0 10107 10107 0 0 59489 59489 0 0
> > > > 2.0 30522 30522 0 0 10253 10253 0 0 59327 59327 0 0
> > > > 2.5 28197 28197 0 0 10280 10280 0 0 61159 61159 0 0
> > > > 3.0 30910 30910 0 0 7927 7927 0 0 59985 59985 0 0
> > > > 3.5 30991 30991 0 0 7935 7935 0 0 60665 60665 0 0
> > > > 4.0 28994 28994 0 0 9598 9598 0 0 59183 59183 0 0
> > > > 4.5 30150 30150 0 0 10034 10034 0 0 14044 14044 0 0
> > > > 5.0 28662 28662 0 0 10458 10458 0 0 3333 3333 0 0
> > > > 5.5 30876 30876 0 0 10506 10506 0 0 791 791 0 0
> > > > 6.0 28540 28540 0 0 10523 10523 0 0 188 188 0 0
> > > > 6.5 29107 29107 0 0 10154 10154 0 0 45 45 0 0
> > > > 7.0 30387 30387 0 0 8500 8500 0 0 11 11 0 0
> > > > 7.5 45085 45085 0 0 18230 18230 0 0 3 3 0 0
> > > > 8.0 49523 49523 0 0 19855 19855 0 0 1 1 0 0
> > > > 8.5 49546 49546 0 0 20405 20405 0 0 0 0 0 0
> > > > 9.0 50916 50916 0 0 18643 18643 0 0 0 0 0 0
> > > > 9.5 50410 50410 0 0 20082 20082 0 0 0 0 0 0
> > > > 10.0 48597 48597 0 0 20453 20453 0 0 0 0 0 0
> > > >
> > > >
> > > >
> > > >
> > > >
> > > >
> > > > On Fri, 7 Jun 2002, Martin Devera wrote:
> > > >
> > > > > What version of HTB do you use ? Send me
> > > > > tc -s -d class show dev xxx
> > > > > outoput after test pic5 generation.
> > > > > devik
> > > > >
> > > > > On Fri, 7 Jun 2002, King Yung Tong wrote:
> > > > >
> > > > > > Thank you again for you help!
> > > > > > Attach is the pic5 for the ceil equal to 100kbps for all line.
> > > > > > 	      pic10limit for the ceil equal to 100kbps except 1:20.
> > > > > >
> > > > > > My objective is to show if not prio is set the excess should allocate
> > > > > > according to rate. If the prio is set, the high prio should get more.
> > > > > >
> > > > > >
> > > > > >
> > > > > >
> > > > > >
> > > > > > On Fri, 7 Jun 2002, Martin Devera wrote:
> > > > > >
> > > > > > > > Thank you for you answer, 1:10 is incresed but 1:20 is also increased and
> > > > > > > > increase to the specific rate if I add 100kbps to every line.
> > > > > > >
> > > > > > > sounds weird. With higher prio 1:10 should get 90k and 1:11 10k.
> > > > > > >
> > > > > > > > In my case, I would like to put all the extra to 1:10 only, is that means
> > > > > > > > I have to give 1:11 ceil to 10kbps. If it is, is that means I don't need
> > > > > > > > prio paramter? How prio parameter works?
> > > > > > >
> > > > > > > your understanding is ok, tge ceil 10k is correct - the prio is
> > > > > > > meant for lowering delay and change in excess distribution is
> > > > > > > only "secondary" product.
> > > > > > >
> > > > > > > Port the resulting graph somewhere so I can look at it.
> > > > > > >
> > > > > > > devik
> > > > > > >
> > > > > > > _______________________________________________
> > > > > > > LARTC mailing list / LARTC@mailman.ds9a.nl
> > > > > > > http://mailman.ds9a.nl/mailman/listinfo/lartc HOWTO: http://lartc.org/
> > > > > > >
> > > > > >
> > > > >
> > > >
> > > >
> > > >
> > > 
> > > _______________________________________________
> > > LARTC mailing list / LARTC@mailman.ds9a.nl
> > > http://mailman.ds9a.nl/mailman/listinfo/lartc HOWTO: http://lartc.org/
> > > 
> > 
> > _______________________________________________
> > LARTC mailing list / LARTC@mailman.ds9a.nl
> > http://mailman.ds9a.nl/mailman/listinfo/lartc HOWTO: http://lartc.org/
> > 
> 
> _______________________________________________
> LARTC mailing list / LARTC@mailman.ds9a.nl
> http://mailman.ds9a.nl/mailman/listinfo/lartc HOWTO: http://lartc.org/
> 

_______________________________________________
LARTC mailing list / LARTC@mailman.ds9a.nl
http://mailman.ds9a.nl/mailman/listinfo/lartc HOWTO: http://lartc.org/

[Index of Archives]     [LARTC Home Page]     [Netfilter]     [Netfilter Development]     [Network Development]     [Bugtraq]     [GCC Help]     [Yosemite News]     [Linux Kernel]     [Fedora Users]
  Powered by Linux