-
Notifications
You must be signed in to change notification settings - Fork 388
QoS
QoS feature in networking provides the ability to control reliability, bandwidth and latency among other traffic management features. Network traffic can be marked with QoS bits (DSCP, 802.1p etc), which intermediate network switches and routers can use to provide service guarantees.
#High level QOS model in Contrail
- All packet forwarding devices (for e.g.: vRouter and Gateway) together form a system.
- Interfaces to the system are ports from where system sends and receives packets, such as tap interfaces and physical ports.
- Fabric interfaces are interfaces where the overlay traffic is tunneled
- QOS is applied at ingress to the system, i.e traffic from interfaces to fabric.
- At egress, packets will be stripped off their tunnel headers and sent to interface queues based on forwarding class. No marking from the outer packet to innerpacket is considered at this time.
Unlike other interfaces that may not be shared, fabric interfaces are always shared, and thus, a common property. Hence, the traffic classes and the QOS marking on the fabric has to be controlled by the System Administrator. Administrator may provision different classes of service on the fabric.
This is achieved by two constructs:
- Queueing on the fabric interface, which involves queues, scheduling of queues and drop policy AND
- Forwarding class, which involves marking and identifying which queue to use and thus controls how packets are sent to fabric.
Tenants have the ability to define which forwarding class their traffic can use. So, in QOS config, they can decide which packets can use what forwarding class.
QOS config object has a mapping table from incoming DSCP or .1p to forwarding class mapping.
Additionally QOS config can be applied to a virtual-network, interface or network-policy.
#Queueing
From 3.2 release onwards, vRouter will provide the infrastructure to make use of the queues supplied by the network interface, also called hardware queueing. NICs that implement hardware queueing also come with their own set of scheduling algorithms associated with the queues. While the implementation will work with most of the NICs, Intel based 10G NIC (also called 'Niantic') is what was used for internal testing.
#Release
- QOS config and forwarding class will be implemented as part of 3.1
- Queueing will be implemented as part 3.2
- Egress marking and queueing is currently not planned.
-
Forwarding-class: specifies knobs for marking and queuing.
- Specifies DSCP value, 802.1p and MPLS EXP values to be written on packet
- Specifies queue index to be used for packet.
-
QoS config object: specifies a mapping from DSCP, 802.1p and MPLS EXP values to corresponding forwarding class. It also has a trusted mode to specify if QoS bits in packet should be honored or not.
- If packet is IP packet then DSCP map would be used to lookup and corresponding forwarding class will be applied.
- If packet is layer2 packet then 802.1p map would be used to lookup and corresponding forwarding class will be applied.
- If its a MPLS tunneled packet and its has MPLS EXP values specified, then EXP bit value would be used to lookup into MPLS EXP map and corresponding forwarding class will be applied.
- If QoS config is untrusted then DSCP, 802.1p and EXP bits in packet would be ignored, all packets would be marked with same forwarding-class properties.
+--------------------------+ +---------------------+ +----------+
+ QOS config object + ----> + Forwarding class + ----> + Queue +
+--------------------------+ +---------------------+ + ---------+
+------------------------------------------------------------+
+ +--------------+ +--------------+ +--------------+ +
+ + DSCP1 - FC-X + + .1p 1 -- FC1 + + EXP1 -- FC-Y + +
+ + DSCP2 - FC-Y + + .1p 2 -- FC2 + + EXP2 -- FC-Z + +
+ + .... + + ..... + + ..... + +
+ +--------------+ +--------------+ +--------------+ +
+ QOS config +
+------------------------------------------------------------+
Virtual-machine-interface, virtual-network, network policy and security-group can refer to QoS config object. QOS config object can be specified on vhost and fabric interface so that underlay traffic can also be subjected to marking and queing
+------------------+ +------------+ +-------------+
+ Virtual machine + + Virtual + + Policy/SG +
+ interface + + network + + +
+------------------+ +------------+ +-------------+
| | |
| V |
| +--------------------+ <------| +---------------+
----------> + QoS config + <------------+ global qos +
+--------------------+ vhost/ + config +
fabric +---------------+
Name | ID | DSCP | 802.1p | MPLS EXP | Queue |
---|---|---|---|---|---|
FC1 | 1 | 10 | 7 | 7 | 0 |
FC2 | 2 | 38 | 0 | 0 | 1 |
In the above table there are two forwarding class objects defined. FC1 marks the traffic with high priority values and queues to Queue 0. FC2 marks the traffic a best effort and queues the traffic to Queue 1.
DSCP | Forwarding-class ID | 802.1p | Forwarding-class ID | MPLS EXP | Forwarding-class ID |
---|---|---|---|---|---|
10 | 1 | 6 | 1 | 5 | 1 |
18 | 1 | 7 | 1 | 7 | 1 |
26 | 1 | * | 2 | * | 1 |
- | 2 | | | | |
In the above example QOS config object DSCP values 10, 18 and 26 are mapped to forwarding class with ID 1 which is FC1, all the other IP packets are mapped to forwarding class with ID 2 which is FC2. Similarly all traffic with 802.1p value of 6 and 7 are mapped to forwarding class FC1, rest to FC2.
##QoS config object marking on packet
- If interface sends a IP packet to another VM in remote compute node, then this DSCP value in IP header value would be used to look up in cos-config table, and the tunnel header would be marked with DSCP, 802.1p and MPLS EXP bit as specified by forwarding-class.
- If VM sends a layer 2 non IP packet with 802.1p value, then corresponding 802.1p value would be used to look into qos-config table and corresponding forwarding-class DSCP, 802.1p and MPLS EXP value would be written to tunnel header.
- If VM sends an IP packet to VM in same compute node, then DSCP value in IP header would be matched in qos-config and corresponding forwarding class would be used to overwrite IP header with new DSCP value and 802.1p value.
###Traffic destined to Virtual machine interface
- If a tunneled packet is received DSCP value in the tunnel IP header would be used to look in qos-config table and corresponding DSCP value would be written to inner payload IP header.
- If VM receives an IP packet from VM in same compute node, then DSCP value in IP header would be matched in qos-config and corresponding forwarding class would be used to overwrite IP header with new DSCP value and 802.1p value.
QoS config can be applied on IP traffic coming from vhost interface. DSCP value in packet would be used to lookup into cos-config object specified on vhost, and corresponding forwarding-class specified DSCP and 802.1p value would be rewritten on packet.
QoS config can be applied while receiving packet on ethernet interface of compute node. Based on DSCP or 802.1p value in packet corresponding forwarding-class DSCP, 802.1p values would be rewritten in packet header.
- IP packet would use DSCP value to lookup in DSCP table of qos-config.
- Non IP layer 2 traffic would use 802.1p value and lookup in 802.1p table of cos-config.
QoS config can be specified at multiple levels, following is the order of priority
- QoS config in policy
- QoS config specified on virtual-network
- QoS config specified on virtual-machine-interface
The queue to send a packet to is specified by the forwarding class. While in almost every component of contrail where queue number is specified it is a logical number, in vRouter (i.e in the data path) that number specifies the actual hardware queue to which the packet needs to be send to. To facilitate this logical to physical transition, there needs to be a mapping and this mapping is specified in the vRouter-agent's configuration file. vRouter-agent, when it programs the vRouter, will program this translated queue number from the logical queue number that it has in its configuration.
If XPS or Xmit-Packet-Steering is enabled, which is the common case in Ubuntu based kernels, kernel will choose the queue to send a packet to based on the affinity each cpu has i.e each cpu has a list of queues it can send a packet to and the kernel will select one from the available set. If kernel selects the queue, then packets will not be sent to the vRouter specified queue. Hence, this mapping needs to be disabled. One can disable this mapping either by having a kernel without CONFIG_XPS option or by writing zeros to the mapping file in /sys/class/net//queues/tx-X/xps_cpus. Once this mapping is disabled, kernel will start sending the packets to the specific hardware queue. One can verify that packets indeed make it to the specified hardware queue by looking at individual queue statistics in the output of 'ethtool -S ' command.
In the case of Intel 10G NIC, the QOS features come as part of a feature called DataCenterBridging (DCB). DCB is now an IEEE standards based feature that provides end to end QOS. In Linux, DCB feature is provided by the tools associated with a package called lldpad. If one wishes to use DCB, DCB has to be enabled at both ends of the wire i.e both on the compute as well as on the switch to which the compute is connected to. The 'lldpad' package also provides tools to configure the bandwidth and the scheduling algorithms to be used under a feature called ExtendedTransmissionSelection or ETS. Please refer to lldptool-ets(8) for the various configuration options.
If one doesn't want to enable DCB on both ends of the wire, one has the option to program the NIC with available functionality/interfaces provided by the Linux kernel under the DCB feature. In vRouter-utils package, there is a utility called 'qosmap' that allows configuration of bandwidth groups and bandwidths allotted to each of the group. It also allows one to specify whether this is a strict allocation or not. Bandwidth that is left after allotment to strict priority groups is divided in a round-robin manner.
Queuing and scheduling will not be supported in 3.1