Developing High Performance Networked Applications using P4-DPDK
- University of South Carolina (USC)
Venue
Friday Center
100 Friday Center Dr, Chapel Hill, NC 27517
University of North Carolina at Chapel Hill
Overview
Network packet processing faces significant performance challenges due to kernel overheads. These issues have become more pronounced with the rapid growth of network traffic. To address these challenges, the Data Plane Development Kit (DPDK) was developed. DPDK bypasses the kernel and operates directly in user space, offering significant improvements in performance and latency for packet processing tasks. However, DPDK's steep learning curve presents a barrier to entry for developers and network administrators. In recent years, P4 has emerged as a language specifically designed for expressing packet processing data paths. Building on this development, P4-DPDK has been introduced as a new technology that bridges P4 and DPDK. It allows developers to create P4 code which is then translated into a DPDK pipeline, combining the expressiveness of P4 with the performance benefits of DPDK. This workshop aims to provide researchers, students, developers, and practitioners with an introduction to P4-DPDK, followed by a hands-on lab. The workshop will cover the fundamentals of P4, including P4 building blocks, parser implementation, and match-action tables.
Audience
The target audience for this tutorial includes Information Technology (IT) professionals and practitioners, researchers, and application developers. The tutorial can also be useful for instructors interested in teaching P4 in the classrooms.
Tutorial Goals
The workshop aims to equip participants with both theoretical knowledge and practical skills related to packet processing in high-speed networks. By the end of this workshop, attendees will:
- Implement DPDK pipelines using the P4 language.
- Describe the elements of the Portable NIC Architecture (PNA), define and parse protocol headers and header fields in P4, define match-action tables and populate them at runtime.
- Develop DPDK-based defense solutions.
- Accelerate packet processing using the Receive Side Scaling (RSS), which distributes packets across multiple CPU cores.
Pre-requisites
Connectivity to the Internet and a browser to access the online virtual platform. Attendees will be provided with an account to access USC’s NETLAB system: https://netlab.cec.sc.edu/
Agenda
Tuesday, March 11
Time | Topic | Presenter |
---|---|---|
3:15-3:35 | Elie Kfoury, Jorge Crichigno | |
3:35-3:40 | P4-DPDK FABRIC demo [Demo] | Samia Choueiri |
3:40 - 40:00 | Hands-on Session [PDF, PPT] | Elie Kfoury, Jorge Crichigno |
[Survey] |
Access to Lab Platform
To access the lab platform, please use the following URL: https://netlab.cec.sc.edu/
Resources
Item | Note |
---|---|
swx pipeline: Link | The DPDK pipeline library source code |
Cybertraining Material: Link | List of virtual labs on P4, SDN, network tools and protocols, ... |
P4 Campus: Link | P4 applications for campus networks |
FABRIC: Link | A programmable research infrastructure |
Behavioral Model version 2 (BMv2): Link | Reference P4 software switch used as a tool for developing, testing and debugging P4 data planes |
Software-Defined Networks: A Systems Approach: Link | A book that explores the key principles of Software-Defined Networking (SDN) |
Mininet: Link | Virtual testbed enabling the development and testing of network tools and protocols |
Containernet: Link | Mininet fork that allows to use Docker containers as hosts in emulated networks |
Mininet Installation: Link | A guide that describes the steps to install Mininet on Linux |
Wireshark: Link | Packet analyzer used for network troubleshooting, analysis, protocol development, and education |