1、SDN技术介绍,What is SDN and why SDN,SDN成为业界热点话题,Gartner:未来五年影响IT的十大关键性趋势,IDC:SDN市场规模2016年预计将达37亿美元,什么是SDN,SDN是Software Defined Network的缩写,软件定义网络,SDN并不是一个具体的技术,它 是一种网络设计理念,规划了网络的各个组成部分(软件、硬件、转发面和控制面)及相互之间 的互动关系,其特征属性包括下面几点:控制面与转发平面分离开放的可编程接口集中化的网络控制网络业务的自动化应用程序控制,控制功能,网络协议,网络设备,网络硬件,集中控制器,OpenFlow,网络硬件,I
2、2RS,应 用,标准接口,传统网络设备,网络硬件,网络协议,控制功能,标准接口,Google SDN案例,将分布于全球的11个数据中心用SDN技术互联 2010年试点,2012年完成全网部署,广域网带宽利用率提升至接近100% 故障收敛时间从9s减低到1s,SDN的发展驱动力,SDN的发展驱动力计算虚拟化驱动由静态到动态的网络变化,虚拟机迁移改变了原有静态的网络部署模式,需要网络开放出来,能与虚拟化业务互通起来随需而动,动态调整网络的策略的扩展性云计算对资源的垂直整合驱动网络技术从独立演进到协同,网络作为一种资源被云计算整合到基础架构中,提供快速连接的服务云计算时代IT业务变化驱动由固定到可编
3、程网络越来越快的变化数据中心资源需要随业务跨地域整合,并使数据中心间广域流量增大,而现状是数据中心资源分散,广域成本高且利用率低,SDN在网络运维中的优势,统一便捷的管理 解决网络中设备越来越多样化问题无缝的版本升级 解决设备版本升级对业务的影响网络数据可视化整体的流量调度,SDN的相关组织与应用方向,SDN的相关组织一,ONF(open network faundation ):openflow 该组织的发起者为google、facebook 、微软等由客户驱动的组织,负责推动SDN网络的部署IETF I2RS interface to route system I2RS实现路由系统的开放访
4、问接口标准化,通过外部控制平面对设备控制平面进行扩展,也不是完全取代现有控制平面,可以实现基于控制层面的hybrid SDN,SDN的相关组织二,国际主流运营商发起成立的ETSI: 网络功能虚拟化工作组(Network Function Virtualizetion,NFV) NFV的目标是利用当前的一些IT虚拟化技术,讲多种网络设备虚拟到大量符合行业标准的物理服务器、交换机或者存储设备上,然后在这些标准的硬件上运行各种执行这些网络功能(路由、安全功能、负载均衡、SBC等)Opendaylight 由各软硬件厂商成立目标打造一个开源的基于SDN的平台框架,SDN技术的应用方向,SDN基本架构,
5、管理和编排,Controller,OpenFlow,设备直接编程 (VAN SDK),RESTful、SOAP、C、Java、XML,转发层,控制层,业务编排层,应用层,SDN体系架构,SDN体系架构,一个简单的类比,硬件,系统,应用/市场,Openflow协议介绍,OpenFlow简介和架构,OpenFlow 1.0,OpenFlow 1.1,OpenFlow是SDN架构中定义的一个控制器与转发层之间的通信接口标准,OpenFlow允许直接访问和操作网络设备的转发平面 OpenFlow的思想是分离控制平面和数据平面,二者之间使用标准的协议通信;数据平面采用基于流的方式进行转发。 OpenFl
6、ow网络由OpenFlow网络设备(OpenFlow Switch)和控制器(OpenFlow Controller)通过OpenFlow通道(OpenFlow Channel)组成,OpenFlow的几个基本概念,流水线(Pipeline):OpenFlow交换机当中一系列连接起来的流表,提供了匹配、转发和包修改的功能。 流表(Flow Table):流水线的一个阶段,包含了流表项 流表项(Flow Entry):流表的一个元素,用于匹配和处理包。包括了一系列用于匹配包的匹配域,一系列跟踪包的计数器,以及一系列可应用的指令 指令(Instruction):一个操作。或者包含了一系列的动作以添
7、加到动作集,或者包含了一个要立即应用在包上的动作列表,或者修改了流水线处理 动作(Action):将包转发到一个端口或修改包(例如减小TTL)的操作。动作可以作为流表项指令集的一部分,或者作为组表项动作桶的一部分,OpenFlow的几个基本概念(续一),Match Fields,Actions/Instructions,Counters,基于Table/Flow/Port/Queue的各种报文计数器,Actions: forward/enqueue/drop/modify-field Instructions: modify action-set or pipeline proc.,流表由流表
8、项组成。 流表项由其匹配域来标识。每个流表项中包括: 匹配域match fields:与包进行匹配。由输入端口和包头组成,也可以包括由前一个表确定的元数据。 计数器counters:发生包匹配时更新 指令集instructions:修改动作集,或修改流水线处理,OpenFlow的几个基本概念(续二),流表项举例 Flow entry 3 information: cookie: 0x2328, priority: 29999, hard time: 0, idle time: 3000, flags: flow_send_rem, byte count: -, packet count: 29
9、304939 Match information: Input interface: XGE1/0/17 Ethernet destination MAC address: 7425-8a02-68e3 Ethernet destination MAC address mask: ffff-ffff-ffff Ethernet source MAC address: 7425-8a08-76f0 Ethernet source MAC address mask: ffff-ffff-ffff Instruction information: Write actions: Output inte
10、rface: XGE1/0/11,单表 IPv4,多表 MPLS、VLAN group ECMP,功能:,IPv6,重构了能力协商 PBB IPv6扩展头 多Controller Per flow meter,OF 1.4,Oct, 2013,增强协议扩展性 Flow Monitoring Eviction Bundles,核心思想: OpenFlow 交换机基于流进行转发。同时,传统的控制层面从转发设备中剥离出来,“迁移”到集中控制器上,OF 1.3,June, 2012,OF 1.2,Dec, 2011,OF 1.1,Feb, 2011,OF 1.0,Dec, 2009,OpenFlow版
11、本演进,H3C SDN产品,SDN战略合作,H3C SDN解决方案,华三SDN体系架构,VCC CLI TCL Python NETCONF ,OpenFlow,SNMP NETCONF OpenFlow ,RESTful、SOAP、C、Java、XML、,更高层Controller,管理监控,上层应用,某厂商Controller,OF-only Switch,OpenFlow,云计算接口,某厂商Switch,Agent,某厂商Switch,Agent,OpenFlow网络: 基于业界规范OpenFlow 1.3 兼容业界标准实现的虚拟交换机、物理交换机 提供丰富的API调用,兼容云计算接口,
12、第三方Controller,OF vSwitch,OpenFlow,转发设备,网络设备,网络设备,OpenFlow,Business Applications,Business Applications,业务应用,SDN 控制器,Java/Rest API,转发层,H3C SDN构架,控制层,应用层,OpenFlow交换机,Hybrid交换机,H3C OpenFlow交换机工作在Hybrid模式 交换机可同时工作在OpenFlow和传统转发模式。部分VLAN为OpenFlow模式,部分VLAN为传统模式,互不干涉。 交换机支持OpenFlow多实例。配置多实例后,controller将视为多台
13、物理设备管理。,SDN控制器,网络设备,网络设备,OpenFlow,Business Applications,Business Applications,业务应用,SDN 控制器,Java/Rest API,转发层,H3C SDN构架,控制层,应用层,SDN Controller 对外开发接口,JAVA API,Rest API,GUI,REST API简介,REST 是英文 Representational State Transfer(表述性状态转移) 的缩写,是近年来迅速兴起的,一种基于 HTTP,URI,以及 JSON 这些现有协议与标准的,针对网络应用的设计和开发方式。在 REST 中,开发人员显式地使用 HTTP 方法,对系统资源进行创建、读取、更新和删除的操作: 使用 POST 方法在服务器上创建资源 使用 GET 方法从服务器检索某个资源或者资源集合 使用 PUT 方法对服务器的现有资源进行更新 使用 DELETE 方法删除服务器的某个资源,REST API和Java API比较,