Manual:HTB: Difference between revisions
No edit summary |
No edit summary |
||
Line 58: | Line 58: | ||
=== Priorities, limits and amounts of incoming traffic === | === Priorities, limits and amounts of incoming traffic === | ||
We will use 50Mbps as basic rate | We will use 50Mbps as basic rate for this particular HTB tree. Limitations and priorities are set according the rules mentioned earlier in this page. | ||
Amounts of incoming traffic are assigned to ensure meaningfulness of the example. | Amounts of incoming traffic are assigned to ensure meaningfulness of the example. | ||
Line 64: | Line 64: | ||
[[Image:Stage1_1.jpg]] | [[Image:Stage1_1.jpg]] | ||
As we know that in this particular setup sum of children '''limit-at'''s are less or equal to traffic that is available to parent, we can assume, that this HTB will have no problems to give limit-at amount of traffic to each and every child queue if required | |||
*'''Queue07''' has the highest priority - it will get its 10Mbps first | |||
: By doing so it will decrees available traffic of parents ('''Queue02''','''Queue01''') by 10Mbps | |||
: '''Queue07''' still has 28Mbps to send out | |||
*'''Queue10''' has the second highest priority - it will get its 5Mbps first | |||
: By doing so it will decrees available traffic of parents ('''Queue09''','''Queue08''') by 10Mbps | |||
: '''Queue10''' still has 5Mbps to send out | |||
*'''Queue11''' has the second highest priority - it will get its 5Mbps first | |||
: By doing so it will decrees available traffic of parents ('''Queue09''','''Queue08''') by 10Mbps | |||
: '''Queue11''' still has 17Mbps to send out | |||
*'''Queue11''' has the second highest priority - it will get its 5Mbps first | |||
: By doing so it will decrees available traffic of parents ('''Queue09''','''Queue08''') by 10Mbps | |||
: '''Queue11''' still has 17Mbps to send out | |||
=== Stage 1 - Satisfying the Limit-at=== | === Stage 1 - Satisfying the Limit-at=== |
Revision as of 13:57, 2 October 2008
Theory
Structure
Hierarchical Token Bucket (HTB) allows to create hierarchical queue structure and determine relations between parent and child queues and relation between child queues. As soon as queue have at least one child it become a parent queue. All child queues (don't matter how many levels of parents they have) are treated as they were on the same (bottom) level of HTB. Child queues make actual traffic consumption, parent queues are responsible only for traffic distribution. Child queues are not able to get more traffic than parent has.
In RouterOS it is necessary to specify parent option to assign queue as a child to other queue
Dual Limitation
Each queue in HTB have two rate limits:
- CIR (Committed Information Rate) – (limit-at in RouterOS) worst case scenario, flow will get this amount of traffic no matter what (assuming we can actually send so much data)
- MIR (Maximal Information Rate) – (max-limit in RouterOS) best case scenario, rate that flow can get up to, if there is spare bandwidth
In another words, at first HTB will try to satisfy every child queue's limit-at (CIR) only then it will try to reach max-limit (MIR)
To ensure optimal (as designed) usage of dual limitation feature we suggest to stick to these rules:
- Sum of committed rates of all children must be less or equal to amount of traffic that is available to parent.
- CIR(parent)* ≥ CIR(child1) +...+ CIR(childN)
- *in case if parent is main parent CIR(parent)=MIR(parent)
- CIR(parent)* ≥ CIR(child1) +...+ CIR(childN)
- Maximal rate of any child must be less or equal to maximal rate of the parent
- MIR (parent) ≥ MIR(child1) & MIR (parent) ≥ MIR(child2) & MIR (parent) ≥ MIR(childN)
Priority
Priority is used for creation of the strict order - who will get traffic first. Queue with higher priority will reach its limit-at before the queue with lower priority and after all limit-ats are satisfied queue with higher priority will reach its MIR before the queue with lower priority. 8 is the lowest priority, 1 is the highest.
Make a note that priority only works:
- for child queues - as soon as you assign at least one child to the queue, priority option will have no meaning in this queue
- if limit-at and/or max-limit is specified (not 0)
Example
In this section we will analyze HTB in action. To do so we will take one specific example of HTB in one specific moment in time, when HTB have to recycle specific amount of incoming traffic.
Structure
Our HTB structure will consist of 14 queues:
- Queue01 has two childs - Queue02 and Queue08
- Queue02 has two childs - Queue03 and Queue07
- Queue03 has three childs - Queue04, Queue05 and Queue06
- Queue04 child
- Queue05 child
- Queue06 child
- Queue07 child
- Queue08 has two childs - Queue09 and Queue12
- Queue09 has two childs - Queue10 and Queue11
- Queue10 child
- Queue11 child
- Queue12 has two childs - Queue13 and Queue14
- Queue13 child
- Queue14 child
Priorities, limits and amounts of incoming traffic
We will use 50Mbps as basic rate for this particular HTB tree. Limitations and priorities are set according the rules mentioned earlier in this page. Amounts of incoming traffic are assigned to ensure meaningfulness of the example.
All data can be seen in the table below:
As we know that in this particular setup sum of children limit-ats are less or equal to traffic that is available to parent, we can assume, that this HTB will have no problems to give limit-at amount of traffic to each and every child queue if required
- Queue07 has the highest priority - it will get its 10Mbps first
- By doing so it will decrees available traffic of parents (Queue02,Queue01) by 10Mbps
- Queue07 still has 28Mbps to send out
- Queue10 has the second highest priority - it will get its 5Mbps first
- By doing so it will decrees available traffic of parents (Queue09,Queue08) by 10Mbps
- Queue10 still has 5Mbps to send out
- Queue11 has the second highest priority - it will get its 5Mbps first
- By doing so it will decrees available traffic of parents (Queue09,Queue08) by 10Mbps
- Queue11 still has 17Mbps to send out
- Queue11 has the second highest priority - it will get its 5Mbps first
- By doing so it will decrees available traffic of parents (Queue09,Queue08) by 10Mbps
- Queue11 still has 17Mbps to send out
Stage 1 - Satisfying the Limit-at