Tutorial on Openflow, Software Defined Networking (SDN) and Network Function Virtualization (NFV)
Total Page:16
File Type:pdf, Size:1020Kb
OpenFlow,OpenFlow, SoftwareSoftware DefinedDefined NetworkingNetworking (SDN)(SDN) andand NetworkNetwork . FunctionFunction VirtualizationVirtualization (NFV)(NFV) SDN=Standard Southbound API SDN = Centralization of control plane SDN=OpenFlow SDN = Separation of Control and Data Planes Raj Jain Washington University in Saint Louis Saint Louis, MO 63130, [email protected] Tutorial at IEEE International Conference on Communications (ICC) 2014, Sydney, Australia, June 14, 2014 These slides and audio/video recordings of this tutorial are at: http://www.cse.wustl.edu/~jain/tutorials/icc14.htm Washington University in St. Louis http://www.cse.wustl.edu/~jain/tutorials/icc14.htm ©2014 Raj Jain 1 OverviewOverview 1. OpenFlow and Tools 2. Software Defined Networking (SDN) 3. Network Function Virtualization (NFV) Washington University in St. Louis http://www.cse.wustl.edu/~jain/tutorials/icc14.htm ©2014 Raj Jain 2 PartPart I:I: OpenFlowOpenFlow andand ToolsTools Planes of Networking OpenFlow OpenFlow Switches including Open vSwitch OpenFlow Evolution OpenFlow Configuration Protocol (OF-Config) OpenFlow Notification Framework OpenFlow Controllers Washington University in St. Louis http://www.cse.wustl.edu/~jain/tutorials/icc14.htm ©2014 Raj Jain 3 PartPart II:II: SoftwareSoftware DefinedDefined NetworkingNetworking What is SDN? Alternative APIs: XMPP, PCE, ForCES, ALTO RESTful APIs and OSGi Framework OpenDaylight SDN Controller Platform and Tools Washington University in St. Louis http://www.cse.wustl.edu/~jain/tutorials/icc14.htm ©2014 Raj Jain 4 PartPart III:III: NetworkNetwork FunctionFunction VirtualizationVirtualization What is NFV? NFV and SDN Relationship ETSI NFV ISG Specifications Concepts, Architecture, Requirements, Use cases Proof-of-Concepts and Timeline Washington University in St. Louis http://www.cse.wustl.edu/~jain/tutorials/icc14.htm ©2014 Raj Jain 5 PartPart I:I: OpenFlowOpenFlow andand ToolsTools Planes of Networking OpenFlow OpenFlow Operation OpenFlow Evolution OpenFlow Configuration Protocol (OF-Config) OpenFlow Notification Framework OpenFlow Controllers Washington University in St. Louis http://www.cse.wustl.edu/~jain/tutorials/icc14.htm ©2014 Raj Jain 6 PlanesPlanes ofof NetworkingNetworking Data Plane: All activities involving as well as resulting from data packets sent by the end user, e.g., Forwarding Fragmentation and reassembly Replication for multicasting Control Plane: All activities that are necessary to perform data plane activities but do not involve end-user data packets Making routing tables Setting packet handling policies (e.g., security) Base station beacons announcing availability of services Ref: Open Data Center Alliance Usage Model: Software Defined Networking Rev 1.0,” http://www.opendatacenteralliance.org/docs/Software_Defined_Networking_Master_Usage_Model_Rev1.0.pdf Washington University in St. Louis http://www.cse.wustl.edu/~jain/tutorials/icc14.htm ©2014 Raj Jain 7 PlanesPlanes ofof NetworkingNetworking (Cont)(Cont) Management Plane: All activities related to provisioning and monitoring of the networks Fault, Configuration, Accounting, Performance and Security (FCAPS). Instantiate new devices and protocols (Turn devices on/off) Optiona l May be handled manually for small networks. Services Plane: Middlebox services to improve performance or security, e.g., Load Balancers, Proxy Service, Intrusion Detection, Firewalls, SSL Off-loaders Optional Not required for small networks Washington University in St. Louis http://www.cse.wustl.edu/~jain/tutorials/icc14.htm ©2014 Raj Jain 8 DataData vs.vs. ControlControl LogicLogic Data plane runs at line rate, e.g., 100 Gbps for 100 Gbps Ethernet Fast Path Typically implemented using special hardware, e.g., Ternary Content Addressable Memories (TCAMs) Some exceptional data plane activities are handled by the CPU in the switch Slow path e.g., Broadcast, Unknown, and Multicast (BUM) traffic All control activities are generally handled by CPU Control Logic Data Logic Washington University in St. Louis http://www.cse.wustl.edu/~jain/tutorials/icc14.htm ©2014 Raj Jain 9 OpenFlow:OpenFlow: KeyKey IdeasIdeas 1. Separation of control and data planes 2. Centralization of control 3. Flow based control Ref: N. McKeown, et al., ``OpenFlow: Enabling Innovation in Campus Networks," ACM SIGCOMM CCR, Vol. 38, No. 2, April 2008, pp. 69-74. Washington University in St. Louis http://www.cse.wustl.edu/~jain/tutorials/icc14.htm ©2014 Raj Jain 10 HistoryHistory ofof OpenFlowOpenFlow 2006: Martin Casado, a PhD student at Stanford and team propose a clean-slate security architecture (SANE) which defines a centralized control of security (in stead of at the edge as normally done). Ethane generalizes it to all access policies. April 2008: OpenFlow paper in ACM SIGCOMM CCR 2009: Stanford publishes OpenFlow V1.0.0 specs June 2009: Martin Casado co-founds Nicira March 2010: Guido Appenzeller, head of clean slate lab at Stanford, co- founds Big Switch Networks March 2011: Open Networking Foundation is formed Oct 2011: First Open Networking Summit. Juniper, Cisco announce plans to incorporate. July 2012: VMware buys Nicira for $1.26B Nov 6, 2013: Cisco buys Insieme for $838M Ref: ONF, “The OpenFlow Timeline,” http://openflownetworks.com/of_timeline.php Washington University in St. Louis http://www.cse.wustl.edu/~jain/tutorials/icc14.htm ©2014 Raj Jain 11 SeparationSeparation ofof ControlControl andand DataData PlanePlane Control Controller Switch OpenFlow Data Forwarding Forwarding Element Element Protocol OpenFlow Secure Forwarding Forwarding Channel Element Element Flow Table Control logic is moved to a controller Switches only have forwarding elements One expensive controller with a lot of cheap switches OpenFlow is the protocol to send/receive forwarding rules from controller to switches Washington University in St. Louis http://www.cse.wustl.edu/~jain/tutorials/icc14.htm ©2014 Raj Jain 12 OpenFlowOpenFlow V1.0V1.0 On packet arrival, match the header fields with flow entries in a table, if any entry matches, update the counters indicated in that entry and perform indicated actions Flow Table: Header Fields Counters Actions Header Fields Counters Actions … … … Header Fields Counters Actions Ingress Ether Ether VLAN VLAN IP IP IP IP Src L4 Dst L4 Port Source Dest ID Priority Src Dst Proto ToS Port Port Ref: http://archive.openflow.org/documents/openflow-spec-v1.0.0.pdf Washington University in St. Louis http://www.cse.wustl.edu/~jain/tutorials/icc14.htm ©2014 Raj Jain 13 FlowFlow TableTable ExampleExample VLAN ID ICMP Code Dst L4Port Dst IP Port Src MAC ICMP Type Src L4Port IP Proto Src IP Dst MAC EtherType Priority IP ToS Action Counter * * 0A:C8:* * * * * * * * * * Port 1 102 * * * * * * * 192.168.*.* * * * * Port 2 202 * * * * * * * * * * 21 21 Drop 420 * * * * * * * * 0x806 * * * Local 444 * * * * * * * * 0x1* * * * Controller 1 Idle timeout: Remove entry if no packets received for this time Hard timeout: Remove entry after this time If both are set, the entry is removed if either one expires. Ref: S. Azodolmolky, "Software Defined Networking with OpenFlow," Packt Publishing, October 2013, 152 pp., ISBN:978-1-84969-872-6 (Safari Book) Washington University in St. Louis http://www.cse.wustl.edu/~jain/tutorials/icc14.htm ©2014 Raj Jain 14 Set Input Port Ether Src Ether Dst MatchingMatching Ether Type Set all others to zero Match Y Apply Set VLAN ID Table 0? EtherType Y Set VLAN Priority Actions N =0x8100? Tagged Use EtherType in VLAN tag for next EtherType Check N Match Y Table n? Set IP Src, IP Dst EtherType Y IP Proto, IP ToS N =0x0806? Send to Controller ARP from within ARP N Set Src Port, Y Not IP Y IP Proto Y EtherType Set IP Src, IP Dst Dst Port for Fragment? =6 or 17 =0x0800? IP IP Proto, IP ToS TCP/ L4 fields UDP N N N Use ICMP Type IP Proto Y and code for =1? ICMP L4 Fields Packet lookup N using assigned header fields Washington University in St. Louis http://www.cse.wustl.edu/~jain/tutorials/icc14.htm ©2014 Raj Jain 15 CountersCounters Per Table Per Flow Per Port Per Queue Active Entries Received Packets Received Packets Transmit Packets Packet Lookups Received Bytes Transmitted Packets Transmit Bytes Packet Matches Duration (Secs) Received Bytes Transmit overrun errors Duration (nanosecs) Transmitted Bytes Receive Drops Transmit Drops Receive Errors Transmit Errors Receive Frame Alignment Errors Receive Overrun erorrs Receive CRC Errors Collisions Washington University in St. Louis http://www.cse.wustl.edu/~jain/tutorials/icc14.htm ©2014 Raj Jain 16 ActionsActions Forward to Physical Port i or to Virtual Port: All: to all interfaces except incoming interface Controller : encapsulate and send to controller Local : send to its local networking stack Table : Perform actions in the flow table In_port : Send back to input port Normal : Forward using traditional Ethernet Flood : Send along minimum spanning tree except the incoming interface Enqueue: To a particular queue in the port QoS Drop Modify Field: E.g., add/remove VLAN tags, ToS bits, Change TTL Washington University in St. Louis http://www.cse.wustl.edu/~jain/tutorials/icc14.htm ©2014 Raj Jain 17 ActionsActions (Cont)(Cont) Masking allows matching only selected fields, e.g., Dest. IP, Dest. MAC, etc. If header matches an entry, corresponding actions are performed and counters are updated If no header match, the packet is queued and the header is sent to the controller, which sends a new rule. Subsequent packets of the flow are handled