Skip to content

Latest commit

 

History

History
61 lines (41 loc) · 1.93 KB

README.md

File metadata and controls

61 lines (41 loc) · 1.93 KB

PFQ

Introduction

PFQ is a capturing engine designed for the Linux kernel that allows efficient packet capturing, in-kernel aggregation, functional processing and packet steering across sockets.

PFQ is highly optimized for multi-core architecture, as well as for network devices supporting multiple hardware queues. It works with any device driver (the ones shipped with the Linux Kernel) and provides a script (pfq-omatic) that patches and compiles source codes on-the-fly to obtain accelerated drivers.

The package provides the source code of the PFQ kernel module, user-space libraries for C, C++11 and Haskell languages and a set of diagnostic tools.

Features

  • 10-Gbit Line-rate (14,8Mpps) with Intel ixgbe vanilla driver.
  • Socket groups allow for concurrent monitoring of multi-threaded applications.
  • Per-group packet steering through randomized hashing algorithms or deterministic packet classifications.
  • Per-group Berkeley filters and per-group VLAN filters.
  • Extensible framework for in-kernel functional monitoring (continuation passing style).
  • User-space native bindings for C, C++11 and Haskell languages.
  • PFQ-omatic, a script that allows to compile drivers and get the accelerated versions.
  • Accelerated pcap library.

Publication

We received the Best-Paper-Award at PAM2012 in Vienna for the paper "PFQ: a Novel Engine for Multi-Gigabit Packet Capturing With Multi-Core Commodity Hardware"": http://tma2012.ftw.at/papers/PAM2012paper12.pdf

Author

Nicola Bonelli [email protected]

Contributors

Andrea Di Pietro [email protected]

Loris Gazzarrini [email protected]

Gregorio Procissi [email protected]

Luca Abeni [email protected]

HomePages

PFQ home-page is pfq.github.io/PFQ. Additional information are available here.