Facebook Open Switching System Software for controlling network switches.
C++ Python Thrift CMake Shell C
Switch branches/tags
Nothing to show
Clone or download
Jasmeet Bagga and facebook-github-bot 7X faster bcm_tests
Mostly bring back pieces of code retired in D7996069,D7888008.
The idea is to not do full unit initialization for each bcm_test.
This saves time for each test setting up the unit, attaching to it etc.
We still do cold boot on each bcm_test, but the time savings on
not reattaching to the unit are substantial. Concretely
99 tests take 540secs with the earlier approach and 76secs with
the new P59795462. So we could scale to ~700 tests with the similar
time incurred as done by bcm_tets today.
TODO: We need to explicitly free flex counters if we are not recreating
unit on each test. Figure out how to do this.

Reviewed By: capveg

Differential Revision: D8763960

fbshipit-source-id: 7f002b934a91ebb40dbf47914d8459bdb9c1425d
Latest commit 1ca7fcd Jul 16, 2018


Facebook Open Switching System (FBOSS)

FBOSS is Facebook's software stack for controlling and managing network switches.


FBOSS consists of a number of user-space applications, libraries, and utilities.

The initial open source release of FBOSS consists primarily of the agent daemon, but we are working on releasing additional pieces and functionality as well.

Agent Daemon

One of the central pieces of FBOSS is the agent daemon, which runs on each switch, and controls the hardware forwarding ASIC. The agent daemon sends forwarding information to the hardware, and implements some control plane protocols such as ARP and NDP. The agent provides thrift APIs for managing routes, to allow external routing control processes to get their routing information programmed into the hardware forwarding tables.

The code for the agent can be found in fboss/agent

The agent requires a JSON configuration file to specify its port and VLAN configuration. Some sample configuration files can be found under fboss/agent/configs. These files are not really intended for human consumption--at Facebook we have tooling that generates these files for us.

Routing Daemon

The FBOSS agent manages the forwarding tables in the hardware ASIC, but it needs to be informed of the current routes via thrift APIs.

Our initial open source release does not yet contain a routing protocol daemon capable of talking to the agent (UPDATE: checkout Netlink Manager). The routing protocol daemon we use at Facebook is rather specific to our environment, and likely won't be as useful to the open source community. For more general use outside of Facebook, it should be possible to modify existing open source routing tools to talk to the FBOSS agent, but we have not implemented this yet. In the meantime, we have included a small sample python script in fboss/agent/tools that can manually add and remove routes.

Management Tools

Obviously additional tools and utilities are required for interacting with the FBOSS agent, reporting its status, generating configuration files, and debugging issues.

At the moment we do not have many of our tools ready for open source release, but we hope to make more of these available in the future weeks. In the meantime, the thrift compiler can automatically generate a python-remote script to allow manual invocation of the agent's various thrift interfaces.

Testing Infrastructure

Scripts for system-level testing is included in $base/system_tests/ and documented in the same directory.


See the BUILD.md document for instructions on how to build FBOSS.

Future Development

FBOSS has been designed specifically to handle the needs of Facebook's data center networks, but we hope it can be useful for the wider community as well. However, note that this initial release of FBOSS will likely require modification and additional development to support other network configurations beyond the features used by Facebook. Until it matures more, FBOSS will likely be primarily of interest to network software developers, rather than to network administrators who are hoping to use it as an turnkey solution.

We look forward to getting feedback from the community, and we hope FBOSS can serve as a jumping-off point for other users wishing to program network switches.

FBOSS development is ongoing at Facebook, and we plan to continue releasing more components, additional features, and improvements to the existing tooling.