Technical Overview of Intel Application Device Queues
  • lr-link(用来填充位置)
  • amazon
  • newegg
  • aliexpress
  • alibaba
  • Linkreal Co., Ltd.
  • Linkreal Co., Ltd.
  • Linkreal Co., Ltd.
  • Linkreal Co., Ltd.
  • Linkreal Co., Ltd.
  • Linkreal Co., Ltd.

Technical Overview of Intel Application Device Queues (ADQ)

Date:2021-01-18View:1465Tags:ADQ Technical,Application Device Queues

Intel introduced application device queues (ADQ) technology to 800 series 100G Ethernet products, so as to realize NVMe support for TCP transmission protocol over Fabric.

ADQ function released by Intel can be used for some NVMe access acceleration based on TCP. And this new feature has been supported in the operating system of Linux kernel. Intel's 800 series 100G Ethernet network card can give full play to the advantages of NVMe access based on TCP protocol, and its delay can be comparable to that of Fabric NVMe based on RDMA function.

Application Device Queue (ADQ) is an advanced traffic-oriented technology, which can improve the predictability and scalability of application response time. LRES1014PF-2QSFP28 adopts Intel Ethernet 800 series network controller, that is, adopts application equipment queue (ADQ) technology, and establishes data transmission channels for key applications. ADQ can significantly improve the performance of key applications and provide higher consistency in meeting customer SLAs.

When we measure the performance of the data center, most people first consider indicators such as throughput and delay-that is, how much data can be processed per second and how long does an operation take?

We compare ADQ to providing a fast dedicated channel for the most core applications on the highways that go hand in hand. In this way, the core business can be executed at a higher speed.


(Image from Intel website)

Data center adopts parallel computing, so a job may be split into multiple instructions and distributed to dozens or hundreds of servers for completion. Then, among all the instructions, the job is finished when the instruction with the slowest response is completed and the result is returned. That is to say, the more servers there are, the more likely it is that the results will return slowly, thus reducing the completion speed of the whole job. At this time, the network between servers and the network software play an important role in influencing the time of data transmission.

ADQ is a development technology aimed at solving network traffic problems by improving throughput and delay, and at the same time, it can improve the predictability of application response time. According to the test, compared with no ADQ technology, the performance of ADQ application has been significantly improved. After enabling ADQ, the predictability of the system is improved by more than 50%, the application delay is reduced by more than 45%, and the throughput is improved by more than 30%. This is due to the fact that ADQ is directly reaching the target channel or queue for the core business queue, which makes it unnecessary for other applications to share or preempt the transmission channel.


Intel 800 series adapters are equipped with 2048 dedicated hardware queues, which can be configured as dedicated ADQs or used as standard traffic channels. Allocate queues for applications through system administrator customization, so as to allocate more queues for higher priority applications to ensure their high performance predictability.

At present, Intel has updated the key patch to the Linux kernel to enable ADQ, and this patch has been included in Linux 4.19 and later. ADQ can be configured by standard Linux operating system tools, such as iproute2, flow control (TC), network port setting (ethtool) and control group (cgroup).

ADQ opens up the expressway, which is a key application for enterprises and keeps them away from traffic jams. You can get more predictability in application performance, reduce latency and improve overall performance.



1Application Device Queues (ADQ) Resource Center

2、《英特尔助力数据中心发展 为企业铺设ADQ高速公路》