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.

Github stars Tracking Chart

Faucet

.. image:: https://travis-ci.com/faucetsdn/faucet.svg?branch=master
:target: https://travis-ci.com/faucetsdn/faucet

.. 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 <https://github.com/wandsdn/valve>_ and the Ryu OpenFlow Controller <http://osrg.github.io/ryu/>. FAUCET's design and background is described in ACM Queue <https://queue.acm.org/detail.cfm?id=3015763>.

It supports:

  • OpenFlow v1.3 (multi table) switches (including optional table features), hardware and software
  • Multiple datapaths and distributed switching under a single controller
  • VLANs, mixed tagged/untagged ports
  • ACLs matching layer 2 and layer 3 fields
  • IPv4 and IPv6 routing, static and via BGP
  • Policy based forwarding to offload to external NFV applications (Eg 802.1x via hostapd, DHCP to isc DHCPD)
  • Port and flow statistics via InfluxDB/Grafana
  • Controller health and statistics via Prometheus
  • Unit and systems tests run under Travis based on mininet and OVS

Hardware and software switch support

Detailed guides for some switches are available on readthedocs <http://docs.faucet.nz/en/latest/vendors/index.html>_.

FAUCET has been tested against the following switches (see also SUPPORTED_HARDWARE in faucet/valve.py <faucet/valve.py>_):

  • Open vSwitch v2.1+ <http://www.openvswitch.org>_
  • Lagopus Openflow Switch <https://lagopus.github.io>_
  • Allied Telesis x510 <https://www.alliedtelesis.com/products/x510-series>_ and x930 <https://www.alliedtelesis.com/products/x930-series>_ series
  • NoviFlow 1248 <http://noviflow.com/products/noviswitch>_
  • Northbound Networks - Zodiac FX <http://northboundnetworks.com/collections/zodiac-fx>_ and Zodiac GX <http://northboundnetworks.com/products/zodiac-gx>_
  • Hewlett Packard Enterprise - Aruba 5400R, 3810 and 2930F <http://www.arubanetworks.com/products/networking/switches/>_
  • Netronome produces PCIe adaptors, via OVS - Agilio CX 2x10GbE card <https://www.netronome.com/products/agilio-cx/>_
  • Cisco Systems - Catalyst 9000 Family Switches <http://www.cisco.com/c/en/us/products/switches/catalyst-9000.html>_

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 <faucet/faucet_pipeline.py>_ and pass all tests.

Installation

Please see the installation guide <http://docs.faucet.nz/en/latest/installation.html>_.

Configuration

Please see the configuration guide <http://docs.faucet.nz/en/latest/configuration.html>_
for documentation regarding the general configuration of faucet and the
recipe book <http://docs.faucet.nz/en/latest/recipe_book/index.html>_
for configuration snippets for common use cases.

Development and testing

Please see the developer guide <http://docs.faucet.nz/en/latest/developer_guide.html>_.

Support

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 <https://github.com/faucetsdn/faucet/issues>_.

Main metrics

Overview
Name With Ownerfaucetsdn/faucet
Primary LanguagePython
Program languagePython (Language Count: 3)
Platform
License:Apache License 2.0
所有者活动
Created At2015-09-25 02:39:36
Pushed At2025-08-27 21:14:15
Last Commit At
Release Count166
Last Release Name1.10.11 (Posted on )
First Release Namev1_0 (Posted on 2016-05-16 11:14:44)
用户参与
Stargazers Count598
Watchers Count49
Fork Count197
Commits Count12.7k
Has Issues Enabled
Issues Count634
Issue Open Count41
Pull Requests Count3723
Pull Requests Open Count1
Pull Requests Close Count337
项目设置
Has Wiki Enabled
Is Archived
Is Fork
Is Locked
Is Mirror
Is Private