FAUCET is an OpenFlow controller for multi table OpenFlow 1.3 switches, that implements layer 2 switching, VLANs, ACLs, and layer 3 IPv4 and IPv6 routing.
.. image:: https://github.com/faucetsdn/faucet/workflows/Unit%20tests/badge.svg?branch=master :target: https://github.com/faucetsdn/faucet/actions?query=workflow%3A%22Unit+tests%22
.. image:: https://github.com/faucetsdn/faucet/workflows/Integration%20tests/badge.svg?branch=master :target: https://github.com/faucetsdn/faucet/actions?query=workflow%3A%22Integration+tests%22
.. image:: https://codecov.io/gh/faucetsdn/faucet/branch/master/graph/badge.svg :target: https://codecov.io/gh/faucetsdn/faucet
FAUCET is an OpenFlow controller for multi table OpenFlow 1.3 switches, that implements layer 2 switching, VLANs, ACLs, and layer 3 IPv4 and IPv6 routing, static and via BGP. It is based on Waikato University's
Valve_ and the
Ryu OpenFlow Controller. FAUCET's design and background is described in
ACM Queue.
It supports:
Detailed guides for some switches are available on
readthedocs_.
Faucet's design principle is to be as hardware agnostic as possible and not require Table Type Patterns. This means that Faucet expects the hardware Open Flow Agent (OFA) to hide implementation details, including which tables are best for certain matches or whether there is special support for multicast - Faucet expects the OFA to leverage the right hardware transparently.
If you are a hardware vendor wanting to support FAUCET, you need to support all the matches in
faucet/faucet_pipeline.py_ and pass all tests.
Please see the
installation guide_.
Please see the
configuration guide_ for documentation regarding the general configuration of faucet and the
recipe book_ for configuration snippets for common use cases.
Please see the
developer guide_.
We run a number of mailing lists for communication between users and developers of Faucet, as well as a low traffic mailing list for announcements of new versions:
Faucet dev blog by Josh Bailey available at https://www.vandervecken.com/faucet.
To create a issue, use
GitHub Issues_.