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]

 



Thank you for your attention, my web page is on www.cs.dal.ca/~tong
3 experiments were attached.

Best Regards,

Patrick Tong

On Sun, 9 Jun 2002, King Yung Tong wrote:

> 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/
> 

_______________________________________________
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