软件定义网络
Awesome SDN ¶
关于软件定义网络 (SDN) 的精彩列表
Introduction¶
软件定义网络 (SDN) 是一种计算机网络方法,它允许网络管理员通过抽象更高级别的功能来管理网络服务. 星期 : Software-Defined Networking
Network Operating System¶
- Beluganos - Beluganos是专为白盒交换机(OF-DPA)设计的新型网络操作系统,适用于大规模网络.
- Cumulus Linux - Cumulus Linux 是一个强大的开放式网络操作系统,允许您使用像世界上最大的数据中心这样的网络规模原则来实现自动化、定制和扩展.
- FlexSwitch - 第一个开源网络协议套件,提供完整的第 2 层/第 3 层功能,用于加速白盒网络设备的开发和部署
- Mion - 基于 ONLP API 和 Yocto 项目的交换机操作系统.
- OcNOS - 广泛的交换和路由协议支持,具有 MPLS 和 SDN 等高级功能
- Open Network Linux, ONL - 用于“裸机”交换机的 Linux 发行版,即由商品组件构建的网络转发设备.
- OpenSwitch - 来自 Dell EMC 的 linux 网络操作系统.
- OpenWrt - Is a Linux Operating System targeting embedded devices.
- PicOS - 用于白盒交换机第 ⅔ 层功能集的 SDN 操作系统,支持 OpenFlow、OVSDB 和其他协议.
- SONiC - 用于云 SONiC 中的开放网络的软件
- Stratum - 用于软件定义网络的开源、独立于硅的交换机操作系统
Install Environment¶
- ONIE - ONIE 支持裸机网络交换机生态系统,最终用户可以在不同的网络操作系统之间进行选择.
Software Switch¶
- BESS - Berkeley Extensible Software Switch,BESS 是软件交换机的模块化框架.
- bmv2- 一个P4软件开关,通常用作验证开发人员用P4语言描述的功能的工具.
- CPqD- OpenFlow 1.3 兼容的用户空间软件交换机实现
- FD.IO - 不懈地专注于数据 IO 速度和效率,以实现更灵活和可扩展的网络和存储
- Indigo - Indigo 是一个开源项目,旨在在物理和管理程序交换机上启用对 OpenFlow 的支持.
- Lagopus - 高性能软件 OpenFlow 1.3 交换机.
- LINC-Switch - 用 Erlang 编写的纯 OpenFlow 软件交换机
- Open vSwitch - Open vSwitch 是一种生产质量的多层虚拟交换机.
- PISCES - 一个可编程的、独立于协议的软件开关.
- snabbswitch - 开源虚拟化以太网网络堆栈.
- ZeroTier - ZeroTier 是一个基于软件的地球托管以太网交换机.
Network Virtualization¶
- FlowVisor - 一个 OpenFlow 控制器,充当交换机和多个控制器之间的管理程序/代理. 可以并行切片多个交换机,有效地切片网络.
- OpenVirtex - 可以在单个物理基础设施之上创建多个虚拟和可编程网络的网络管理程序.
Protocol¶
- OpenFlow - 一种通信协议,允许通过网络访问网络交换机或路由器的转发平面.
- OF-Config - OpenFlow 管理和配置协议
- OVSDB - 用于管理 OpenvSwitch 数据库的通信协议.
- NETCONF
- OpFlex
- Path Computation Element Protocol, PCEP
- Extensible Messaging and Presence Protocol, XMPP
- P4 Runtime
- gNMI - gRPC 网络管理接口
- gNOI - gRPC 网络操作接口
Controller¶
- Beehive Network Controller - 基于 Beehive 构建的分布式 SDN 控制器. 它支持 OpenFlow,但可以轻松扩展到其他南向协议.
- Floodlight - 基于 Java 的 OpenFlow 控制器.
- IRIS - 由 ETRI 的 SDN 研究部创建的 Resursive SDN Openflow 控制器.
- lighty.io core - lighty.io 核心组件 - 用于构建基于 Java 的 SDN 控制器的开源开发框架.
- Netrack - Go 中的 OpenFlow 控制器框架.
- NodeFlow - OpenFlow 控制器节点样式.
- NOX - 用于基于 C++ 的软件定义网络 (SDN) 控制应用程序的开源开发平台.
- OESS - 用于配置和控制支持 OpenFlow 的交换机的 Open Exchange 软件套件.
- ONOS - 开放式网络操作系统.
- Open MUL - 几乎完全用 C 从头开始编写的轻量级 SDN/Openflow 控制器.
- Open Security Controller - 软件定义的安全编排解决方案,可自动部署虚拟化网络安全功能,如下一代防火墙、入侵防御系统和应用程序数据控制器
- OpenContrail - 一个利用 SDN 和 NFV 并为网络虚拟化提供所有必要组件的 SDN 项目.
- OpenDaylight - OpenDaylight 平台
- OVN - OVN:Open vSwitch 的开放虚拟网络
- POX - An open source development platform for Python-based software-defined networking (SDN) control applications.
- Ravel - 软件定义网络 (SDN) 控制器,使用标准 SQL 数据库来表示网络.
- Ryu - 基于组件的软件定义网络框架.
- Trema - 用于在 Ruby 和 C 中开发 OpenFlow 控制器的全栈、易于使用的框架.
- Vyatta - 第一个直接从 OpenDaylight 构建的商业控制器.
Simulator/Emulator¶
- Containernet - 允许在模拟网络中使用 Docker 容器作为主机的 Mininet 分支
- EstiNet - 享誉全球的网络规划软件工具
- MaxiNet - MaxiNet 扩展了著名的 Mininet 仿真环境,将仿真跨越多个物理机器. 这允许模拟非常大的软件定义网络.
- Mininet - 笔记本电脑(或其他 PC)上的即时虚拟网络
- ns-3 - 支持 OpenFlow 环境的离散事件网络模拟器.
- OpenNet - 软件定义无线局域网模拟器
- Tinynet - 用于快速原型设计 SDN 的轻量级即时虚拟网络
Language¶
- Frenetic - 狂热的编程语言和运行时系统
- NEMO - 基于网络模型抽象和操作模式结论的领域特定语言(DSL).
- P4 - 一种声明性语言,用于表达网络转发元素(如交换机、NIC、路由器或网络功能设备)的管道如何处理数据包.
- POF - 协议无视转发
- Pyretic - Pyretic 是 SDN 编程语言 Frenetic 家族的一员.
Library¶
- loxigen - LoxiGen 是一种为多种语言生成 OpenFlow 协议库的工具.
- nettle - 用于使用 OpenFlow 协议的 Haskell 库.
- OCaml OpenFlow - OpenFlow 的序列化和协议库.
- oflib-node - Oflib-node 是 Node.js 的 OpenFlow 协议库. 它在 OpenFlow 有线协议消息和 Javascript 对象之间进行转换.
- openfaucet - openfaucet 是基于 Twisted 的 OpenFlow 1.0.0 协议的纯 Python 实现.
- OpenFlowJ - 低级 OpenFlow 数据包编组/解组和 IO 操作的 Java 实现.
- Scapy - Scapy 是一个强大的交互式数据包操作程序.
Test¶
- Cbenech - 控制器基准测试工具
- nice-of - 用于测试 NOX 控制器平台的 OpenFlow 控制器应用程序的工具.
- oftest - 开放流测试框架
- OpenSDNCore - NFV/SDN 环境的虚拟化测试台.
- ptf - 基于 unittest 的基于 python 的数据平面测试框架.
- STS - SDN 故障排除系统,模拟网络设备,允许以编程方式生成测试用例.
NFV¶
- OPNFV - 通过集成的开放平台加速 NFV 的发展.
Overlay Network¶
- GENEVE - 什么是日内瓦?
- NVGRE - NVGRE-Network-Virtualization-using-Generic-Routing-Encapsulation
- VXLAN - 虚拟可扩展局域网
Router¶
- bgp4r - BGP4R 是一个 ruby 库,可以创建和操作 BGP 消息. 在 BGP4R 中,所有众所周知的 BGP 构造都在类中定义.
- BGPFeeder
- Bird - BIRD 项目旨在开发功能齐全的动态 IP 路由守护程序,主要针对(但不限于)Linux、FreeBSD 和其他类 UNIX 系统,并在 GNU 通用公共许可证下分发.
- FreeRouter - 基于 Java 的 vRouter
- FRRouting - 用于 Linux 和 Unix 平台的 IP 路由协议套件,包括 BGP4、BGP4+、OSPFv2、OSPFv3、RIPv1、RIPv2、RIPng、PIM-SM/MSDP 和 LDP 的协议守护进程,以及对 IS-IS、EIGRP 和国家人权计划.
- gobgp - GoBGP 是一种开源 BGP 实现,从头开始为现代环境设计,并以现代编程语言 Go 编程语言实现.
- Quagga - Quagga 是一个路由软件套件,为 Unix 平台(尤其是 FreeBSD、Linux、Solaris 和 NetBSD)提供 OSPFv2、OSPFv3、RIP v1 和 v2、RIPng 和 BGP-4 的实现. Quagga 是由 Kunihiro Ishiguro 开发的 GNU Zebra 的一个分支.
- yabgp - YABGP 是 BGP 协议的另一个 Python 实现. 它可用于与各种路由器(包括真正的 Cisco/HuaWei/Juniper 路由器和一些路由器模拟器,如 GNS3)建立 BGP 连接,并接收/解析 BGP 消息以供将来分析.
Misc¶
- Aether Project - 第一个开源企业 5G/LTE 边缘云即服务平台 (ECaaS).
- Central Office Re-architected as a Datacenter, CORD - 提供云经济性和敏捷性的服务交付平台的参考实施.
- Mininet Spear Narmox - 在线网络服务提供 Mininet 拓扑的可视化
- Open Network Automation Platform, ONAP - 这两个项目的结合为虚拟网络功能的实时、策略驱动的软件自动化创建了一个协调和全面的框架,这将使软件、网络、IT 和云提供商和开发人员能够快速创建新服务.
- Open Source MANO Community, OSM
- OPEN-Orchestrator Project, Open-O
High Performance Network¶
- ASAP2 - ASAP2 加速器建立在 eSwitch NIC 硬件之上,允许将整个虚拟交换机或虚拟交换机或分布式虚拟路由器 (DVR) 操作的重要部分卸载到 Mellanox NIC
- DPDK - DPDK 是一组用于快速数据包处理的库和驱动程序.
- RDMA - 远程直接内存访问 (RDMA) 是从一台计算机的内存到另一台计算机的内存的直接内存访问,而不涉及任何一个操作系统. 这允许高吞吐量、低延迟的网络
- XDP - XDP 或 eXpress 数据路径在 Linux 内核中作为 IO Visor 项目的一部分提供高性能、可编程的网络数据路径. 它旨在在任何处理器上运行. 第一个支持的 CPU 是 Intel x86,现在扩展到 IBM POWER 和 ARM.
Userspace Network Stack¶
- drv-netif-dpdk - drv-netif-dpdk 是 rump 内核的 DPDK 网络接口. 组合结果是用户空间 TCP/IP 堆栈通过 DPDK 执行数据包 I/O.
- f-stack - F-Stack 是一个基于 DPDK、FreeBSD TCP/IP 堆栈和协程 API 的高性能用户空间网络开发套件.
- mTCP - mTCP 是用于多核系统的高度可扩展的用户级 TCP 堆栈. mTCP 源代码在修改后的 BSD 许可证下分发. 有关详细信息,请参阅许可证. io_engine 驱动程序和移植应用程序的许可条款可能与 mTCP 的不同.
- net-next-nuse - 用户空间中的网络堆栈 (NUSE) NUSE 允许我们将 Linux 网络堆栈用作一个库,任何应用程序都可以通过链接该库进行目录使用. 每个应用程序都有自己的网络堆栈,因此它提供了一个与主机操作系统不同的即时虚拟化环境.
- nff-go - NFF-Go 成为 Linux 基金会下 DPDK 项目保护伞的一部分! 可以在此处找到镜像仓库:http://dpdk.org/browse/apps/nff-go/. 我们也将通过 DPDK 邮件列表和标准 DPDK 贡献流程接受补丁.
Analytics¶
- Apache Spot - 社区驱动的网络安全项目,从头开始构建,在开放、可扩展的平台上对所有 IT 遥测数据进行高级分析
- PNDA - 用于网络和服务的可扩展、开源大数据分析平台.
- SNAS - 流式网络分析系统(项目 SNAS)是一个实时收集、跟踪和访问数千万路由对象(路由器、对等点、前缀)的框架.
Resources¶
Books¶
- DevOps for Networking
- Network Algorithmics:An Interdisciplinary Approach to Designing Fast Networked Devices
- Network Programmability and Automation Skills for the Next-Generation Network Engineer
- SDN: Software Defined Networks: An Authoritative Review of Network Programmability Technologies
- SDN网络指南(倪鹏飞的中文开源书籍)
- SDN核心技术剖析和实战指南
- Software Defined Networking with OpenFlow
- 圖解OpenFlow
- 重构网络-SDN架构与实现
- 深度解析SDN: 利益、战略、技术、实践
- 软件定义网络:SDN与OpenFlow解析
Paper¶
- A Guided Tour of Data-Center Networking
- A Survey on the Security of Stateful SDN Data Planes
- High Performance Datacenter Networks: Architectures, Algorithms, and Opportunities
- Re-architecting datacenter networks and stacks for low latency and high performance
- SDN A Comprehensive Survey