SDN软件定义网络学习资料
计算机网络软件定义网络基础
计算机网络软件定义网络基础计算机网络软件定义网络(Software-Defined Networking,简称SDN)是一种新兴的网络架构,它通过将网络控制平面与数据传输平面进行分离,以实现网络管理的集中化和智能化。
在传统网络中,网络设备的控制和数据转发功能通常由同一设备完成,而SDN通过将网络控制逻辑集中到一个或多个控制器中,与数据转发设备进行解耦,从而使得网络更加灵活、可编程和可管理。
一、SDN的基本概念SDN的核心概念是将网络控制从传统的根据底层网络设备厂商提供的命令进行操作的方式中解脱出来,将网络控制逻辑放置在一个或多个分离的控制器中。
控制器通过与网络设备之间的南向接口,向网络设备下发控制命令,并从网络设备收集数据统计信息,从而调节网络设备的行为。
这种分离控制平面和数据平面的方式,使得网络可以根据上层应用的需求进行快速调整和优化。
二、SDN的工作原理SDN架构包括控制器、南向接口和数据平面,其中控制器负责网络管理与控制,南向接口用于控制器与数据平面之间的通信,数据平面则是实际的网络设备。
SDN的工作原理如下:1. 控制器:在SDN架构中,控制器是整个网络的大脑,负责网络的全局视图以及整体管理与控制。
控制器通过南向接口与网络设备进行通信,接收数据平面的信息,并根据上层应用的需求制定网络策略,下发控制命令给数据平面。
2. 南向接口:南向接口是控制器与数据平面之间的接口,用于传递控制命令和收集网络统计信息。
南向接口可以是标准化的接口,如OpenFlow协议,也可以是厂商自定义的接口。
3. 数据平面:数据平面是实际进行数据传输的网络设备,如交换机、路由器等。
数据平面接收来自控制器的控制命令,根据命令进行数据转发和流量控制。
三、SDN的优势和应用1. 灵活性和可编程性:SDN架构的分离控制平面和数据平面,使得网络可以根据应用需求进行灵活调整和优化。
网络管理员可以通过控制器下发灵活的控制命令,实现网络策略的快速变更和部署。
SDN软件定义网络学习资料
便用户进行网络管理和配置。
标准化接口
02
推动SDN接口的标准化工作,实现不同设备之间的互操作性和
兼容性,降低网络建设和运营成本。
设备兼容性
03
加强SDN设备的兼容性测试和验证,确保不同厂商的设备能够
相互协作,提高网络的可靠性和稳定性。
性能优化问题
流量调度
通过SDN控制器对网络流量进行智能调度和管理, 优化网络性能,提高网络带宽利用率。
edX上的"Introduction to SoftwareDefined Networking"课程:该课程 介绍了SDN的基本原理、OpenFlow 协议、控制器和应用场景,适合初学 者入门。
SDN开源项目推荐Fra bibliotekOpenDaylight
一个开源的SDN控制器项目,支持多种南 向协议和北向API,提供了丰富的网络功能 和可扩展性。
网络功能虚拟化(NFV)
定义
NFV是一种将网络功能软件化的技术,通过虚拟化技 术将传统的网络设备转化为虚拟化形态。
特点
降低网络成本,提高网络灵活性,加快业务部署速度。
应用场景
广泛应用于运营商网络、数据中心、企业网等领域。
03
SDN的应用场景
数据中心网络
数据中心网络是SDN应用的重要领域之一,通过SDN技术 可以实现数据中心网络的集中控制和自动化管理,提高网 络资源的利用率和灵活性。
SDN软件定义网络 学习资料
目录
• SDN概述 • SDN核心技术 • SDN的应用场景 • SDN的挑战与解决方案 • SDN未来发展趋势 • SDN学习资料推荐
01
SDN概述
定义与特点
定义
SDN(Software-Defined Networking,软件定义网络)是一种新型网络架 构,通过分离网络控制与转发功能,实现网络资源的灵活管理和高效利用。
SDN(软件定义网络)技术解析
SDN(软件定义网络)技术解析随着信息技术的飞速发展,软件定义网络(Software-Defined Networking,SDN)作为一种新兴的网络架构,正在受到越来越多企业和组织的关注和应用。
本文将对SDN技术进行详细解析,包括其基本概念、架构原理、应用场景以及未来发展方向等。
一、基本概念SDN是一种基于软件控制的网络架构,与传统的网络架构相比,它的核心思想是将网络控制平面与数据转发平面进行分离。
传统网络中,网络设备(如交换机、路由器)同时具备控制和数据转发功能,网络管理员通过配置这些设备的命令来控制网络。
而在SDN中,控制器负责决策网络数据的转发路径,将这些决策下发到数据平面设备执行。
这种分离使得网络的管理与控制变得集中化,便于对网络进行统一的管理与维护。
二、架构原理SDN架构主要由三个组件组成:应用层、控制层和基础设施层。
应用层包括各种网络应用,如负载均衡、安全防护等;控制层由控制器组成,负责管理和控制网络中的各种设备;基础设施层则是实际的网络设备,包括交换机、路由器等。
在SDN中,应用层通过与控制层进行交互来获得网络管理的能力。
应用程序可以通过SDN控制器的API接口与其进行通信,通过发送和接收消息来实现网络上的各种功能。
控制层是SDN的核心,它负责对网络进行管理与控制。
控制器通过与基础设施层的网络设备进行通信,提供网络的可编程性和可配置性。
控制器可根据网络策略和管理员的需求,动态地调整网络的配置,并将这些配置下发至网络设备,从而实现对网络的控制。
基础设施层是实际的网络设备,包括交换机、路由器等。
这些设备根据控制器下发的指令来转发数据。
三、应用场景SDN技术在各个领域有着广泛的应用场景。
以下列举几个典型的应用场景:1. 数据中心网络:SDN技术可以对复杂的数据中心网络进行灵活统一的管理。
通过集中化的控制,管理员可以根据实际需求对数据中心网络进行动态配置,提高网络的资源利用率和性能。
2. 广域网(WAN)优化:SDN可以通过对网络流量进行实时监测与调整,提高广域网的带宽利用率和传输效率。
软件定义网络(SDN)中的网络编程与控制
软件定义网络(SDN)中的网络编程与控制软件定义网络(Software Defined Networking,SDN)是一种新兴的网络架构,它通过将网络控制平面(Control Plane)与数据转发平面(Data Plane)分离,实现了网络的灵活性和可编程性。
在SDN中,网络编程与控制起着至关重要的作用,它不仅决定了网络的性能和功能,还能够为网络提供更高效的管理和维护。
一、SDN网络编程的基本概念和原理SDN网络编程即通过编写程序来控制网络的行为和流量转发。
相比传统网络中依靠硬件设备固定配置的方式,SDN网络编程使网络能够根据具体需求进行自动化管理和优化。
在SDN中,网络编程的基本概念包括控制器、交换机和应用程序。
控制器是网络的大脑,它负责接收和处理来自应用程序的指令,并向交换机发送相应的控制信息。
交换机负责实际的数据转发工作,根据控制器的指令进行数据包的处理和路由。
应用程序可以通过与控制器交互来实现对网络的编程控制。
SDN网络编程的原理是通过控制器和交换机之间的OpenFlow协议来实现的。
OpenFlow是一种用于交换机和控制器之间通信的协议,它定义了多种消息类型和相应的操作指令,使控制器能够对交换机进行灵活的配置和控制。
二、SDN网络编程的主要功能和优势1. 灵活性和可编程性:SDN网络编程使网络管理员能够根据具体业务需求进行网络配置和控制,实现网络的自定义和个性化服务。
同时,网络编程还提供了更高层次的抽象,简化了网络管理和维护的复杂性。
2. 实时性和响应性:SDN网络编程可以快速地对网络状态进行监测并做出相应的调整,实现对网络的实时响应。
网络管理员可以通过编写程序来自动化地进行网络故障的检测和修复,提高了网络的可靠性和稳定性。
3. 安全性和可靠性:SDN网络编程能够对网络中的流量进行精确的检测和过滤,提供更高级别的网络安全保护。
通过编写程序和算法,网络管理员可以实现对网络中的恶意行为和攻击的及时发现和应对。
SDN软件定义网络关键技术研究
SDN软件定义网络关键技术研究第一章:SDN软件定义网络的概念SDN软件定义网络(Software Defined Networking)是一种网络架构的设计思路,它的目的是解决传统网络架构中存在的问题,并且提高网络的可控性、可靠性和安全性。
SDN软件定义网络是一种基于控制平面和数据平面分离的网络架构,它使用了一种叫做控制器的软件来管理和控制数据包的传输。
SDN软件定义网络的控制器被用来集中控制网络中的转发设备,它提供了一个抽象的控制界面,使得网络管理员可以通过应用程序编程接口(API)来控制网络中的设备,实现网络中的自动化管理和流控制功能。
第二章:SDN软件定义网络的架构SDN软件定义网络的架构通常被分为三层:应用层、控制层和数据层。
1、应用层:应用层即提供各种各样网络应用的层次,包括基于网络的各种业务和网络安全管理。
2、控制层:控制层即网络的控制层,主要负责网络的流量控制和管理。
控制层包括一个或多个SDN控制器,这些控制器可以是集中式的或分布式的。
控制层实现对网络拓扑和流量的全局掌控,通过抽象化的方式来管理网络。
3、数据层:数据层即网络的数据转发层,它由各种网络设备组成,包括交换机、路由器、防火墙等。
数据层根据控制层的指令来控制数据包的转发和处理,实现消息的交换。
第三章:SDN软件定义网络的关键技术1、控制器架构技术:控制器是SDN软件定义网络的核心,在SDN中,控制器实现了掌控网络的关键功能,如全局拓扑的探测、数据流的下发、网络流量的管理和安全策略的实现等。
因此,SDN的控制器架构设计直接影响SDN的性能和可靠性。
目前,控制器架构主要分为单控制器和多控制器两种架构,其中,多控制器架构由于具有高可用性和分布式特性,已经成为了SDN控制器的主流架构。
2、流表映射技术:流表映射技术是实现SDN流量控制的核心技术,它是将数据包的转发规则划分为多张流表,根据流表映射表将不同的流表映射到不同的交换机上,并将数据包转发到对应的交换机。
sdn软件定义网络学习文件材料文件材料
05 SDN的未来发展
SDN技术的发展趋势
自动化与智能化
随着人工智能和机器学习技术的不断发展,SDN技术将进 一步实现网络配置、流量调度、安全防护等功能的自动化 和智能化。
云网融合
云计算和网络技术的融合是未来发展的重要趋势,SDN技 术将更好地支持云网融合,实现云资源的灵活调度和网络 的智能管控。
适用场景
OpenFlow协议广泛应用于数据 中心、云计算、校园网等场景, 以提升网络的性能、可靠性和安 全性。
OpenFlow协议工作原理
01
控制与转发分离
OpenFlow协议将网络设备的控制平面与转发平面分离,网络设备的转
发行为由SDN控制器进行集中控制。
02
流表匹配与动作
OpenFlow设备维护一个或多个流表,用于匹配和处理数据包。当数据
随着SDN技术的广泛应用,网络安全和隐私保护问题将更加突出,需要加强安全机制的 设计和实施,确保SDN技术的安全可靠。
商业模式创新
SDN技术的发展将推动网络产业的商业模式创新,形成更加灵活、高效的网络服务模式 ,为各行业提供更好的网络支持和服务。
SDN的未来发展方向
边缘计算
随着云计算向边缘的延伸,SDN技术将更好地支持边缘计算的发展,实现边缘设备的 灵活管理和智能控制。
SDN控制器是软件定义网络(SDN)的核心组件, 负责管理和控制网络流量。
功能
SDN控制器提供了一个集中式的管理界面,允许 网络管理员通过编程方式配置和控制网络设备。
重要性
SDN控制器是实现SDN架构的关键,它简化了网 络管理和配置,提高了网络的灵活性和可扩展性。
SDN控制器的工作原理
控制与转发分离
高效性
SDN资料整理
1 SDN1.1 什么是SDN软件定义网络(Software Defined Network, SDN),是由美国斯坦福大学clean slate 研究组提出的一种新型网络创新架构,SDN 技术就相当于把每人家里路由器的的管理设置系统和路由器剥离开。
以前我们每台路由器都有自己的管理系统,而有了SDN之后,一个管理系统可用在所有品牌的路由器上。
如果说现在的网络系统是功能机,系统和硬件出厂时就被捆绑在一起,那么SDN 就是Android系统,可以在很多智能手机上安装、升级、使用,同时还能安装更多更强大的手机App(SDN 应用层部署)。
SDN的设计理念是将网络的控制面与数据转发面进行分离,并实现可编程化控制。
SDN的典型架构共分三层,最上层为应用层,包括各种不同的业务和应用;中间的控制层主要负责处理数据平面资源的编排,维护网络拓扑、状态信息等;最底层的基础设施层负责基于流表的数据处理、转发和状态收集。
图3SDN网络结构从传统的网络设备(路由器,交换机)的设计上看,它由软件控制和硬件数据通道组成。
软件控制包括管理(CLI,SNMP)以及路由协议(OSPF,ISIS,BGP)等。
数据通道包括针对每个包的查询、交换和缓存。
此时如果将网络中所有的网络设备视为被管理的资源,那么参考操作系统的原理,可以抽象出一个网络操作系统(Network OS)的概念,这个网络操作系统一方面抽象了底层网络设备的具体细节,同时还为上层应用提供了统一的管理视图和编程接口。
这样,基于网络操作系统这个平台,用户可以开发各种应用程序,通过软件来定义逻辑上的网络拓扑,以满足对网络资源的不同需求,而无需关心底层网络的物理拓扑结构。
SDN的好处:SDN本质上具有“控制和转发分离”、“设备资源虚拟化”和“通用硬件及软件可编程”三大特性,这带来了一系列的好处。
第一,设备硬件归一化,硬件只关注转发和存储能力,与业务特性解耦,可以采用相对廉价的商用的架构来实现。
软件定义网络(SDN)的原理和应用
软件定义网络(SDN)的原理和应用软件定义网络(Software Defined Networking,简称SDN)是一种新兴的网络架构,它通过将网络控制与数据转发相分离,实现了网络的集中管理与灵活性。
本文将介绍SDN的原理和应用。
一、SDN的原理SDN的核心原理是将网络控制层与数据转发层分离,并通过集中的控制器对网络进行管理。
传统网络中,交换机和路由器不仅承担数据转发的功能,还负责路由计算等控制任务,这使得网络的维护和管理变得复杂。
而SDN将数据转发交给可编程的交换机,通过集中的控制器对交换机进行编程和管理,从而实现了网络的可编程性和灵活性。
二、SDN的架构SDN架构包括三个主要组件:控制器、网络应用和交换机。
控制器是SDN网络的大脑,负责网络资源的管理和控制,以及为网络应用提供编程接口。
网络应用是基于SDN架构开发的应用程序,可以利用控制器提供的编程接口实现网络的控制和管理。
交换机是数据转发的设备,它与控制器进行通信,根据控制器的指令进行数据包的转发。
三、SDN的优势1. 灵活性:SDN的控制器可以对整个网络进行集中管理,通过编程接口可以快速、灵活地改变网络的策略和配置,满足不同应用的需求。
2. 可编程性:SDN交换机具有可编程性,可以根据控制器的指令进行灵活的数据转发处理,从而支持不同的网络功能和服务。
3. 自动化:SDN的集中管理和编程接口可以实现网络的自动化操作和管理,减少了手动配置的工作量和出错的可能性。
4. 适应性:SDN可以根据网络流量和业务需求,动态进行网络资源的配置和优化,提高网络的性能和可靠性。
四、SDN的应用1. 数据中心网络:SDN可以对数据中心的网络进行集中管理和优化,实现虚拟化、多租户隔离等功能,提高网络的灵活性和资源利用率。
2. 企业网络:SDN可以实现企业内部网络的统一管理和安全策略的集中控制,简化网络配置和管理,提高网络的稳定性和安全性。
3. 无线网络:SDN可以应用于无线网络中,实现对无线基站的集中控制和资源分配,提高无线网络的性能和覆盖范围。
云计算中的软件定义网络(SDN)
云计算中的软件定义网络(SDN)云计算已经成为现代信息技术领域的重要组成部分,而软件定义网络(SDN)作为云计算架构的核心技术之一,正逐渐引起人们的广泛关注和应用。
本文将从SDN的概念、原理和应用方面,详细介绍云计算中的软件定义网络。
一、SDN的概念与特点软件定义网络(Software Defined Networking,简称SDN)是一种新兴的网络架构和管理范式,其核心思想是将网络控制平面与数据平面分离,通过集中式的控制器对网络进行配置和管理。
与传统网络相比,SDN具有以下几个显著特点:1. 灵活性:SDN架构可以根据需求动态配置网络流量和路由,提供更灵活、可定制的网络服务。
这种灵活性为云计算环境下的资源调度和虚拟机迁移等提供了强大支持。
2. 可编程性:SDN将网络的控制逻辑从传统的网络设备中抽象出来,使得网络控制器可以通过编程方式操控网络流量。
这种可编程性使得SDN可以根据应用需求提供定制化的网络服务。
3. 集中管理:SDN通过集中式的控制器实现对整个网络的统一管理和控制,可以实时监控网络状态并根据需求进行网络调整。
这种集中管理的优势使得网络运维更加高效和便捷。
二、SDN的工作原理SDN的工作原理可以简要分为三个步骤:控制平面与数据平面的分离、网络流量的转发和集中化的控制器。
1. 控制平面与数据平面的分离:传统网络中,控制平面和数据平面通常呈现紧密集成的结构,而SDN将二者进行了有效的解耦。
控制平面负责网络的管理和配置,数据平面则负责实际的数据传输和处理。
2. 网络流量的转发:在SDN中,网络设备(如交换机)将网络流量的转发决策交给集中式的控制器。
当数据包到达交换机时,交换机会将数据包的相关信息发送给控制器,由控制器根据预先定义的策略进行转发决策,并将决策结果返回给交换机。
3. 集中化的控制器:SDN的核心是集中化的控制器,它与交换机之间通过控制通道进行通信。
控制器负责整个网络中的拓扑发现、流量控制、虚拟网络管理等功能,通过与交换机之间的交互,实现对整个网络的控制和管理。
了解服务器虚拟化中的软件定义网络(SDN)技术
了解服务器虚拟化中的软件定义网络(SDN)技术随着信息技术的快速发展,服务器虚拟化技术在企业和组织中得到了广泛的应用。
而软件定义网络(SDN)作为一种新兴的网络架构技术,在服务器虚拟化中也扮演着重要的角色。
本文将对服务器虚拟化中的软件定义网络技术进行详细的介绍和解析。
一、什么是软件定义网络(SDN)技术软件定义网络(SDN)是一种通过将网络控制平面与数据平面进行分离,使网络的控制集中化、智能化的网络技术。
传统的网络架构中,网络控制功能被集中在网络设备内部,无法进行灵活的调整和管理。
而SDN技术通过引入统一的控制器,将网络的控制功能从硬件设备中解耦出来,实现了对网络的集中控制。
二、软件定义网络技术的优势1. 灵活性和可编程性:SDN技术将网络控制平面与数据平面分离,使网络管理员可以通过集中的控制器对整个网络进行灵活的编程和管理。
这样的设计使得网络的配置和管理变得更加简单和高效。
2. 高度可扩展和可定制化:SDN架构采用了分层的网络结构,使得网络可以根据实际需求进行灵活的扩展和定制。
同时,通过网络控制器的集中管理,网络管理员能够更容易地对网络进行监控和故障排除。
3. 提高网络安全性:SDN架构中的集中控制器可以实时监控网络流量和网络设备状态,并对网络流量进行精确控制。
这可以提高网络的安全性,并能够及时发现和应对网络攻击和安全威胁。
三、软件定义网络技术在服务器虚拟化中的应用1. 灵活的网络配置:SDN技术可以实现对虚拟网络的动态配置和管理。
服务器虚拟化环境中,虚拟机之间的通信需要通过虚拟交换机进行,传统的网络配置比较繁琐且不灵活。
而SDN技术可以通过集中的控制器对虚拟交换机进行管理,实现对虚拟机网络的快速配置和调整。
2. 虚拟机迁移支持:在服务器虚拟化环境中,经常需要对虚拟机进行迁移。
而SDN技术可以提供对虚拟机迁移的支持,保证迁移过程中的网络连接和通信的稳定性。
通过SDN技术的应用,虚拟机的网络配置可以实现无缝迁移,有效降低迁移过程中可能出现的网络中断和延迟。
云计算中的软件定义网络(SDN)技术
云计算中的软件定义网络(SDN)技术软件定义网络(SDN)技术在云计算中的应用云计算是当今信息技术领域的热门话题,它为用户提供了便捷的存储和计算资源,并且以其高效灵活的特点受到了广泛的关注和应用。
然而,随着云计算规模的不断扩大和网络需求的快速增长,传统的网络架构已经逐渐无法满足对网络性能和灵活性的要求。
因此,软件定义网络(SDN)技术被引入到云计算中,以提供更加灵活可控的网络管理和服务。
一、SDN技术概述1.1 SDN的定义和原理软件定义网络(SDN)是一种新兴的网络架构,其核心思想是将网络控制平面和数据转发平面进行分离。
传统的网络架构中,网络的控制和数据转发都由网络设备(如交换机和路由器)自主完成,而SDN 通过将网络逻辑集中在一个控制器中,使得网络的控制更加灵活和可编程。
1.2 SDN的特点和优势相比传统的网络架构,SDN具有以下几个显著的特点和优势:- 灵活可编程:SDN通过将网络逻辑集中在控制器中,可以通过编程方式灵活控制网络的行为,实现灵活的网络管理和配置。
- 高效可扩展:SDN的控制平面和数据平面分离,使得网络的扩展更加容易和高效,可以根据需求动态地调整网络的规模和容量。
- 集中控制:SDN通过集中的控制器对整个网络进行管理和控制,可以提供更加全面和细粒度的网络服务和策略。
二、SDN技术在云计算中的应用2.1 网络虚拟化云计算环境中通常需要支持多租户的网络隔离和虚拟化,以满足不同用户对网络资源的需求。
SDN技术可以通过创建逻辑上的虚拟网络来实现多租户的网络隔离,并且在物理网络上进行动态映射。
这样可以提供灵活的网络资源分配和管理,同时提高网络的利用率。
2.2 动态网络配置和优化在云计算中,不同的应用和服务对网络的要求并不相同。
SDN技术允许管理员根据具体的需求来动态配置网络策略和路由,以优化网络的性能和质量。
例如,可以基于应用的要求来调整网络的带宽和延迟,提高网络的吞吐量和响应速度。
2.3 弹性网络弹性网络是云计算中一个重要的特点和要求,即网络能够根据负载情况快速调整和适应变化。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
数据中心 数据中心
易扩展,易增加网络设备 24
SDN 应用 —— 转发平面型 ,Google
6
1、控制转发分离
控制平面(CP) 转发平面(DP)
传统网络设备的CP与DP 不分离; 设备之间通过控制协议交互转发信息;
SDN 的思路是将网络设备的控制平面集中上收到Controller; 网络设备上指保留转发平面(转发表项); 通过Controller实现网络统一部署和网络自动化;
总体来看,由于SDN技术主要带来的好处是可编程带来的网络自动化,而目前 SDN的编程接口并不统一标准,这就要求用户有较强的技术自主开发能力。 所以,各种类型的SDN技术,在企业网应用都很较少。 由于私有云计算平台要求网络资源被抽象,以提供自动编排能力,所以目前看 Overlay型SDN发展速度较快。很多企业客户开始测试、评估Overlay 型SDN。
Software Defined Networking SDN 学习总结
目录
关于SDN 与可编程网络
各种SDN技术思路、应用场景、标准化情况介绍 各厂商SDN方案介绍 展望SDN的发展
SDN 技术从哪里起源 —— Openflow
06 年斯坦福的学生Martin Casado 领导了一个关于网络安全与管理的项目Ethane,该项目试图通过一个 集中式的控制器,让网络管理员可以方便地定义基于网络流的安全控制策略,并将这些安全策略应用到各 种网络设备中,从而实现对整个网络通讯的安全控制。 通过集中式的控制器(Controller)以标准化的接口对各种网络设备进行管理和配置,那么这将为网络资源的 设计、管理和使用提供更多的可能性,从而更容易推动网络的革新与发展。 于是他们便提出了OpenFlow 的概念, 并于08 年在ACMSIGCOMM 发表了题为OpenFlow: Enabling Innovation in Campus Networks的论文,阐述Openflow 的原理。 论文还列举了OpenFlow 几大应用场景,包括:
Service的角度:
抽象物理网络 定制转发路径抽象
Operation的角度:
网元开放接口,应 用可对网元编程, 采用现代的接口, 应用与网元的紧密 配合
架构角度:控制平面与数据平面分离,逻辑集中管理(集中到控制器上); 业务角度:通过对控制器,使低层网络被抽象出来网络资源被抽象成服务,实现了应用程序与网络设备 的操作系统进行解耦和。应用看到的是网络服务。 运营角度:网络可以通过编程的方式来访问,从而实现应用程序对网络的直接影响,一些新型的接口, 可以实现传统网络管理不能做到的网络优化。
数据中心
Openflow
数据中心
资源利用率:为保证故障情况发生切换时不出现拥塞, 链路利用率小于50%,业务人抱怨带宽不足,但网络 却有50%用不上; 管理性:大量的设备需要管理,大量的差异化配置;
目前是通过MPLS-TE实现上述需求; 未来将通过SDN技术(Openflow),将整个网络 看做一个路由器,统一配置管理,将不同的流量分 别走到不同的路径上,可以快速提供网络路径,并 且保证有北向接口给业务。 Openflow 的好处:
CP
DP
CP
DP
Controller
CP
DP
CP
DP
CP
DP
CP
DP
CP
DP
CP
DP
CP
DP
CP
DP
CP
DP
CP
DP
CP
DP
CP
DP
CP
DP
CP
DP
7
2、网络的抽象
通过Controller实现了对基础网络设施的抽象; 应用程序看到的是Controller提供的网络服务
被抽象出的网络
应用程序的视角
OF 1.1 多表 MPLS、VLAN group ECMP
OF 1.2 IPv6
功能:
单表 IPv4
OF 1.3 重构了能力协商 PBB IPv6扩展头 多Controller Per flow meter
OF 1.3.1
增强版本协商能力
Open Network Foundation,即开放式网络基金会。ONF是非盈利的组织机构,致力于创新和发展新 型网络架构,即软件定义网络(SDN)。 -ONF成立一年,有超过80家国内外公司加入到ONF的商业化推广和使用SDN技术的推广。 -国内企业包括:华为、中兴、腾讯、盛科、华三等。
18
Openflow 方案模型
安全信道:Controller通过安全信道向OpenFlow Switch下发命令和接收信息 组表 Group Table:用一个Group使OpenFlow可以支持额外的转发行为(如select)
流表 Flow Table:OpenFlow交换机的基本表项
网 络 抽 象 层 级
Overlay 型 SDN 转发平面型 SDN 控制平面型 SDN
分布式控制平面被保留的量
14
SDN技术在业界的应用部署情况
只有少数用户部署了SDN技术的网络 而且这些用户集中在互联网、云计算运营商 转发平面型SDN,有少量用户使用,主要在广域网 Overlay 型SDN,应用比较多,主要是在数据中心应用@腾讯 控制平面型SDN,主要受技术成熟度影响,目前应用很少
园区网络中对实验性通讯协议的支持;
网络管理和访问控制; 网络隔离和VLAN; 基于WiFi 的移动网络;
非IP 网络;
基于网络包的处理;
基于OpenFlow 为网络带来的可编程的特性,进一步提 出了SDN(Software Defined Network,软件定义网 络)的概念
Flow Table Flow Table
OF-Controller
A
Flow Table
Of-config D
E
C
Flow Flow Table Table
B
23
Openflow 应用场景-骨干网流量工程
业务管理中心
WAN的主要需求:
灵活性:业务部门经常有临时性的大容量传输,要求 VPN,QOS,但网络很难快速满足,业务人抱怨网络 基础架构相应慢,缺乏灵活性
9
@关键是 “可编程性”及“可编程的平台”
架构的控制转发分离 物理网络的抽象的协议 可编程接口
从单一点的技术点上看,思路SDN 的三个视角都是没有逃离传统网络的技术思路。 但SDN 区别于传统网络技术的关键是“通过可编程性,将应用与网络设备之间的交互更紧密结合”。二这 种紧密结合性,需要上述三种思路:“控制转发分离”、“物理网络抽象”、“可编程接口”。 可编程性是SDN的核心。将控制和管理平面从交换机、路由器中移到设备外的软件中,并通过SDN协议来 连接网络设备。这些设备外的软件平台有自己的API、处理逻辑,以及向网络提要求、接受事件、处理SDN 通信协议的能力,这些软件平台就是“控制器/Controller”。 应用开发人员只使用控制器提供的API来实现网络自动化、网络编排和操作网络。 控制器被认为代表了支持SDN的应用程序的基础架构,体现了SDN的可编程性。传统网络部具备这个。
10
小结:SDN的定义与结构
SDN 源于Openflow,但SDN 不等于 Openflow. SDN是一种架构,一种思想。让应用参与到网络控制中。 SDN 的三个特点: 转发、控制分离(并不是所有的控制都要被分离出来);
控制集中,网络被抽象
编程接口
11
OpenFlow is one Fish in the Sea of SDN
架构角度:控制平面全部上收到Openflow Controller,数据平面依靠流表规定的匹 配字段和动作进行转发。目前来看,Hybrid 模式是主流。 业务角度:通过在不同的网元上下发流表,通过流表实现了对网络的抽象(路径)。 运营角度:
Openflow Controller与网元之间采 用Of-Config 协议实现信息交互。即 通过Of-Config实现对网络的编程。 应用可以自定义流表,通过OfConfig 下发设备,并获取设备的反 馈信息(紧密联系的模式); 协议目前支持三种报文类型: controller-to-switch ; asynchronous;symmetric, 每种 报文类型都有很多子类型。 控制平面集中度高,但网络抽象度低!
Controller
物理网络/Fabric Underlay网络
8
3、可编程接口
传统的网元都具备管理接口,可以 通过网关协议(SNMP、NETCONF) 或CLI实现简单的编程; 但传统接口常导致应用程序需要与 网元设备之间通过某种代理或翻译 器来通信。副作用是在应用设备与 网元设备之间的反馈回路的时间长。 一些新型接口协议如XMPP、Thrift、 JSON等可以更灵活的以异步的方式 操作网络设备; 一些新的协议如I2RS可以直接对网络 路由系统进行直接的、快速的应用 优化的修改/编程。 SDN可编程接口不是传统的网络管理, 而是一种在应用与网元之间双向的、 紧密联系的通信通道,可以实现传 统网络不具备的网络快速优化能力。
各厂商SDN方案介绍 展望SDN的发展
16
(一)关于转发平面型 SDN
“转发平面型SDN”是完全不同与 传统网络实现的一种设计; 设备中已经没有分布式控制平面的 痕迹了; 转发平面SDN 的抽象层是逐跳转发 表项; 通过逐跳表建立一个流的转发路径。 对比于“overlay型SDN”,后者 只在网络的边缘对隧道的首和尾进 行编程。 最典型的就是 openflow 模型
19
从Controller 下发的流表(OF v1.0)