-
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. Note that R3.2 queueing support is only with kernel mode vrouter. Various configurations and facts under QOS Queueing are covered in this page. There is a dedicated page to explain Qos Queueing as well. Please refer to following link: https://github.com/Juniper/contrail-controller/wiki/QoS-Queueing-Configurations-and-Facts
#Release
- QOS config and forwarding class will be implemented as part of 3.1
- Queueing in kernel mode vrouter will be implemented as part of 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 and a default forwarding class identifier.
- 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.
- For unspecified values of DSCP, 802.1p or MPLS EXP, the default forwarding class will be applied.
- If QoS config is to be untrusted then only the default forwarding class can be specified so that the values of DSCP, 802.1p and EXP bits in incoming packet would be ignored, and the default forwarding class will be applied on all packets.
+--------------------------+ +---------------------+ +----------+
+ 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 queueing
+------------------+ +------------+ +-------------+
+ 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, there is no change in the packet headers while forwarding the same (the original packet is not changed).
###Traffic destined to Virtual machine interface If a tunneled packet is received, the tunnel headers are stripped off and sent to interface. No marking from the outer packet to inner packet is done.
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 specified 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.
The QoS queue configuration provided in the forwarding class is a logical queue. The logical queues used are mapped to the physical queues supported in the NIC, this mapping is done in the contrail-vrouter-agent.conf on each compute node. Fab setup supports updating this mapping in the corresponding contrail-vrouter-agent configuration files. In addition, the scheduling algorithm and bandwidth values that are used by respective priority groups (in IEEE mode, we have one traffic class per priority group) can also be updated in the same agent configuration for supported nic (niantic nic). The scheduling algorithm and bandwidth values can be read by a script that runs on the compute node to configure the priority groups.
Configuration for Logical to physical queue mapping for a new cluster . The logical to physical queue mapping can be added in testbed.py in the following format.
env.qos = {
host4: [
{'hardware_q_id': '1', 'logical_queue':['1', '6-10', '12-15']},
{'hardware_q_id': '2', 'logical_queue':['2-5']},
{'hardware_q_id': '3', 'logical_queue':['7'], 'default': 'True'}],
host5: [
{'hardware_q_id': '1', 'logical_queue':['1', '3-8', '10-15']},
{'hardware_q_id': '2', 'logical_queue':['9'], 'default': 'True'}]
}
hardware_q_id : Hardware queue identifier.
logical_queue : Defines the logical queues that map to the hardware queue.
default : When set to True, defines the default hardware queue for Qos. All unspecified logical queues map to this hardware queue. This is an optional configuration.
The above parameters are updated in /etc/contrail/contrail-vrouter-agent.conf on host4 as follows:
[QOS]
[QUEUE-1]
# Logical nic queues for qos config
logical_queue= ['1', '6-10', '12-15']
[QUEUE-2]
# Logical nic queues for qos config
logical_queue= [2-5]
[QUEUE-3]
# This is the default hardware queue
default_hw_queue= true
# Logical nic queues for qos config
logical_queue= [7]
As part of provisioning of a new cluster this queue mapping is enforced. Also, Xmit-Packet-Steering is disabled i.e. zeros are written to files /sys/class/net/queues/tx-X/xps_cpus. The above Qos queuing parameters are persistent across restarts.
Testbed.py file should be updated as shown above and this fab task needs to be run from /opt/contrail/utils path on config node:
fab setup_qos_queuing
This task will generate [QOS] section in contrail-vrouter-agent.conf, will write zeros to xps_cpu files and will make the configuration persistent across restarts. To change the configuration, update testbed.py and rerun the task.
Configuration for priority groups for a new cluster
Priority group with scheduling and bandwidth properties can be defined in testbed.py as follows:
env.qos_niantic = {
host4:[
{ 'priority_id': '1', 'scheduling': 'strict', 'bandwidth': '0'},
{ 'priority_id': '2', 'scheduling': 'rr', 'bandwidth': '20'},
{ 'priority_id': '3', 'scheduling': 'rr', 'bandwidth': '10'}],
host5:[
{ 'priority_id': '1', 'scheduling': 'strict', 'bandwidth': '0'},
{ 'priority_id': '2', 'scheduling': 'rr', 'bandwidth': '30'}]
}
priority_id: Priority group for qos.
scheduling: Defines the scheduling algorithm used for priority group, strict or roundrobin (rr).
bandwidth: Total hardware queue bandwidth used by priority group.
Bandwidth cannot be specified if strict scheduling is used for priority group set it as 0.
The above parameters for priority groups are updated in /etc/contrail/contrail-vrouter-agent.conf on host4 as follows:
[QOS-NIANTIC]
[PG-1]
# Scheduling algorithm for priority group (strict/rr)
scheduling=strict
# Total hardware queue bandwidth used by priority group
bandwidth=0
[PG-2]
# Scheduling algorithm for priority group (strict/rr)
scheduling=rr
# Total hardware queue bandwidth used by priority group
bandwidth=20
[PG-3]
# Scheduling algorithm for priority group (strict/rr)
scheduling=rr
# Total hardware queue bandwidth used by priority group
bandwidth=10
Above configuration is read by a qosmap.py script (path /opt/contrail/utils) that runs on the compute node to configure the priority groups using qosmap utility.
Testbed.py file should be updated as shown above and this fab task needs to be run from /opt/contrail/utils path on config node: fab setup_qos_scheduling
This task will generate [QOS-NIANTIC] section in contrail-vrouter-agent.conf, will write zeros to xps_cpu files and will make the qos scheduling configuration persistent across restarts. To change the configuration, update testbed.py and rerun the task. Note that this job is used only with setting up of priority group configuration on compute nodes running vRouter in kernel mode. For DPDK mode, the configuration is expected to be done separately.
-
DCB feature supports 2 modes. One is IEEE and other is CEE. We recommend and provide provision to configure Bandwidth and Scheduling values using IEEE mode. User can use CEE mode as well but some limitations are present in that mode which are documented in following bug: https://bugs.launchpad.net/juniperopenstack/+bug/1630865
-
On creating congestion within a single instance of VM and verifying scheduling, results will not be as per expectations. This is because of the fact that VM has its own queue and congestion within the VM will be handled by the queue of the VM(Not by the parent NIC interface queues). For more information, please refer to the following bug: https://bugs.launchpad.net/juniperopenstack/+bug/1634762
-
For "Intel based 10G NIC(Niantic)", you will observe 32 queues initially. As soon as you enable dcb on the interface, it shows all 64 queues. Using "qosmap" utility to configure Bandwidth and Scheduling, automatically enables DCB and creates 64 queues.
-
It is observed that even if the highest priority queue is carrying full rate(10G) data, some very minor leaks happen on lower priority queues as well.(Assuming highest priority queue is configured for strict priority)