Dynamic bandwidth allocation systems and methods using content identification in a software-defined networking controlled multi-layer network
A method, a Software-Defined Networking (SDN) controller, and a network include operation of a multi-layer SDN network and uniquely identifying streaming content on higher layers relative to the multi-layer SDN network through deep packet inspection; associating the streaming content to a multi-layer service on the SDN network; and monitoring the streaming content on the SDN network over the multi-layer service. This can include dynamically adjusting bandwidth of the multi-layer service utilizing OpenFlow on the SDN network based on the monitoring. The deep packet inspection can utilize a Bloom filter embedded in a resource identifier of the streaming content by the content provider, wherein the embedded Bloom filter is transparent to content players and does not require changes to storage on associated web servers for the streaming content.
Latest Ciena Corporation Patents:
- IN-PHASE (I) / QUADRATURE (Q) CORRELATION DITHER FOR MODULATOR QUADRATURE CONTROL
- Graceful transition in a connectivity test when a discriminator is changed in a Seamless Bidirectional Forwarding Detection (S-BFD) reflector node
- Automatic optical link calibration of amplified optical links
- Apparatus and method for driving an optical modulator with independent modulator arm bias
- METHODS, SYSTEMS, AND DEVICES TO IMPROVE WITHRDRAWING BORDER GATEWAY PROTOCOL (BGP) ROUTES WHEN A BGP GATEWAY BECOMES UNREACHABLE
The present disclosure relates generally to networking systems and methods. More particularly, the present disclosure relates to Dynamic Bandwidth Allocation Systems and Methods using Content Identification in a Software-Defined Networking (SDN) Controlled Multi-Layer Network.
BACKGROUND OF THE DISCLOSUREConventional networks have little interaction between various layers. For example, Layers 0-2 (e.g., optical (DWDM) at Layer 0, Optical Transport Network (OTN) or SONET/SDH at Layer 1, Ethernet at Layer 2) have little interaction with higher layer traffic (e.g., Layers 4-7). In the context of content delivery in conventional networks at Layers 0-2, the present state-of-the art solutions aim at providing a best quality stream based on available bandwidth knowing nothing about the content and having no ability to create a different, higher bandwidth, service to carry the content if it determines the current service to be sub-optimal. Today's mechanisms to accomplish guaranteed bandwidth are subscription-based (with the content providers) and are accomplished with statically provisioned core networks (at Layers 0-1 and possibly 2) that lead to underutilization since these maximum bandwidth scenarios are not in use 100% of the time. Here, Over-The-Top (OTT) content providers maintain their transparency through an Internet Service Provider's (ISP) network using this approach. In a session based approach, a particular session is identified by Layer 4-7 information. In this scenario, an initial session handshake between OTT server and a subscriber device through the portal path is required. This handshake identifies the unique flow identifier (e.g., Internet Protocol (IP) source address +IP destination address +Transmission Control Protocol (TCP) port number). The shortcoming of this approach is the manual step involvement of the portal. Note, both DWDM and OTN/SONET/SDH (TDM) are Layer 1 physical layer protocols in the OSI stack. However, those of ordinary skill in the art refer to DWDM as a separate Layer, i.e., Layer 0, to distinguish between DWDM and TDM protocols.
Today's mechanism to accomplish the “best” user experience in content viewing is to use adaptive bit rate streaming. This technique is used in streaming multimedia over one or more networks to user devices (e.g., computers, smart phones, tablets, etc.) with the aim at providing the best user experience (i.e., best video resolution for movies, etc.) which is based entirely on the availability of bandwidth and independent of the content. While in the past most video streaming technologies utilized streaming protocols such as Real Time Transport Protocol (RTP) with Real Time Streaming Protocol (RTSP), today's adaptive streaming technologies are almost exclusively based on Hypertext Transfer Protocol (HTTP) and are designed to work efficiently over large distributed HTTP networks such as the Internet.
In the subscriber (identified by destination IP address) based approach, customers who pay the highest monthly fee have their streams carried on pre-established high performance end-to-end tunnels. The shortcoming of this approach is the over-provisioning of the network (e.g., at Layers 0-1 and possibly 2). Furthermore, there is no ability to distinguish multiple streams from different OTT providers for this subscriber. In the session based approach, a particular session is identified by Layer 4-7 information. In this scenario, an initial session handshake between OTT server and subscriber device through the portal path is required. This handshake identifies the unique flow identifier (e.g. IP source address+IP destination address+TCP port number). The shortcoming of this approach is the manual step involvement of the portal. Further, the present state of art solution does not involve a multi-layer network and coordination therebetween. Lastly, another shortcoming is the inability of the network provider (e.g., ISP) to know what content is being passed through their network.
BRIEF SUMMARY OF THE DISCLOSUREIn various exemplary embodiments, dynamic bandwidth allocation systems and methods can use an SDN controller and associated applications to determine the streaming content by performing deep packet inspection (DPI) and further associating the content to a multi-layer service. The dynamic bandwidth allocation systems and methods can use a Bloom filter to allow the Deep Packet Inspection component to identify the packets that belong to the media stream and its segments in a completely transparent manner to the HTTP streaming content players without requiring any changes to storage structure on the web servers. Finally, the dynamic bandwidth allocation systems and methods can dynamically adjust bandwidth by provisioning/deprovisioning services spanning multi-layer (L0, L1 and L2) using the OpenFlow protocol based on the original content identified.
In an exemplary embodiment, a method includes operating a multi-layer Software-Defined Networking (SDN) network; uniquely identifying streaming content on higher layers relative to the multi-layer SDN network through deep packet inspection; associating the streaming content to a multi-layer service on the SDN network; and monitoring the streaming content on the SDN network over the multi-layer service. The method can further include dynamically adjusting bandwidth of the multi-layer service utilizing OpenFlow on the SDN network based on the monitoring. The multi-layer SDN network can operate at any of Layers 0, 1, and 2, Layer 0 being wavelengths, Layer 1 being Time Division Multiplexing, and Layer 2 being packets. The streaming content can include Hypertext Transfer Protocol (HTTP) adaptive streaming. The uniquely identifying, the associating, and the monitoring can be performed by an SDN controller. The method can further include performing the deep packet inspection utilizing a Bloom filter embedded in a resource identifier of the streaming content, wherein the embedded Bloom filter is transparent to content players and does not require changes to storage on associated web servers for the streaming content. The method can further include receiving the streaming content from a content provider with an embedded Bloom Filter in a resource identifier; and tracking the streaming content associated with the content provider over the SDN network.
The method can further include prior to the uniquely identifying and at a content provider, initializing a master N-bit Bloom filter with k different hash function associated with the Bloom filter; and repeating each of the following steps for each media segment comprising segment data produced by the content provider: initializing an M-bit empty Bloom Filter with L different hash functions associated with the filter; as each segment is produced, taking a first set of bytes of the segment data and performing an M-bit Bloom filter addition by feeding the segment data through each of the L hash function and setting the corresponding Bloom filter bits; performing master N-bit Bloom filter addition by feeding the data through each of the K hash function and setting the corresponding Bloom filter bits; and creating a Uniform Resource Indicator (URI) for every media segment that enables its clients to obtain the segment data. The method can further include embedding the Bloom Filter in the URI of every media segment file for the uniquely identifying.
In another exemplary embodiment, a Software-Defined Networking (SDN) controller includes a network interface communicatively coupled to one or more network devices in a multi-layer Software-Defined Networking (SDN) network; a processor communicatively coupled to the network interface; memory storing instructions that, when executed, cause the processor to: uniquely identify streaming content on higher layers relative to the multi-layer SDN network through deep packet inspection; associate the streaming content to a multi-layer service on the SDN network; and monitor the streaming content on the SDN network over the multi-layer service. The instructions, when executed, can further cause the processor to: dynamically adjust bandwidth of the multi-layer service utilizing OpenFlow on the SDN network based on the monitoring. The multi-layer SDN network can operate at any of Layers 0, 1, and 2, Layer 0 being wavelengths, Layer 1 being Time Division Multiplexing, and Layer 2 being packets. The streaming content can include Hypertext Transfer Protocol (HTTP) adaptive streaming. The instructions, when executed, can further cause the processor to: perform the deep packet inspection utilizing a Bloom filter embedded in a resource identifier of the streaming content, wherein the embedded Bloom filter is transparent to content players and does not require changes to storage on associated web servers for the streaming content. The instructions, when executed, can further cause the processor to: receive the streaming content from a content provider with an embedded Bloom Filter in a resource identifier; and track the streaming content associated with the content provider over the SDN network.
In yet another exemplary embodiment, a network includes a multi-layer Software-Defined Networking (SDN) network; a content provider comprising at least one web server communicatively coupled to the SDN network; an SDN controller communicatively coupled to the SDN network and configured to: uniquely identify streaming content from the content provider on higher layers relative to the multi-layer SDN network through deep packet inspection; associate the streaming content to a multi-layer service on the SDN network; monitor the streaming content on the SDN network over the multi-layer service; and dynamically adjust bandwidth of the multi-layer service utilizing OpenFlow on the SDN network based on the monitoring. The multi-layer SDN network can operate at any of Layers 0, 1, and 2, Layer 0 being wavelengths, Layer 1 being Time Division Multiplexing, and Layer 2 being packets, and wherein the streaming content can include Hypertext Transfer Protocol (HTTP) adaptive streaming.
The SDN controller can be configured to: perform the deep packet inspection utilizing a Bloom filter embedded in a resource identifier of the streaming content by the content provider, wherein the embedded Bloom filter is transparent to content players and does not require changes to storage on associated web servers for the streaming content. The content provider can include a server configured to: prior to the uniquely identifying, initialize a master N-bit Bloom filter with k different hash function associated with the Bloom filter; and repeat each of the following steps for each media segment comprising segment data produced by the content provider: initialize an M-bit empty Bloom Filter with L different hash functions associated with the filter; as each segment is produced, take a first set of bytes of the segment data and performing an M-bit Bloom filter addition by feeding the segment data through each of the L hash function and setting the corresponding Bloom filter bits; perform master N-bit Bloom filter addition by feeding the data through each of the K hash function and setting the corresponding Bloom filter bits; and create a Uniform Resource Indicator (URI) for every media segment that enables its clients to obtain the segment data.
The present disclosure is illustrated and described herein with reference to the various drawings, in which like reference numbers are used to denote like system components/method steps, as appropriate, and in which:
In various exemplary embodiments, dynamic bandwidth allocation systems and methods using content identification in a Software-Defined Networking (SDN) controlled multi-layer network are described. The dynamic bandwidth allocation systems and methods relate to an SDN network, a controller adaption layer, controller, an adaptive streaming server and methods to determine a provider, and furthermore, specific content, and a method to dynamically control the bandwidth across a multi-layer network for the delivery of the said original content to one or more user devices. Fundamentally, the dynamic bandwidth allocation systems and methods provide a multi-layer SDN solution. The SDN Controller, with the corresponding adaption layer and applications, can provision services spanning multi-layer (Layers 0-2 (L0/L1/L2)) such as, for example, using the OpenFlow protocol. To accomplish the multi-layer SDN control, the dynamic bandwidth allocation systems and methods describe techniques of identifying content flowing through the network for the purpose of dynamically controlling the service bandwidth.
Referring to
It is an objective of the dynamic bandwidth allocation systems and methods to enable direct interaction between the ISP network 16 and the OTT content provider 12. With the dynamic bandwidth allocation systems and methods, the ISP network 16 is no longer in the dark as to the content which is being transported and having a history of what content was transported over time provides the ISP with many new business opportunities. A significant benefit of the dynamic bandwidth allocation systems and methods is an ability to identify content at the highest granularity possible; every piece of content is unique, and utilizing this information to dynamically manage the path this content takes so that sufficient bandwidth is available for the end user to view it in its maximum resolution. Being able to dynamically allocate bandwidth based on original content opens many business opportunities for network operators of the ISP network 16. For example, network operators can allow its customers to purchase packages where they are guaranteed full high-quality video streaming from a list of OTT content providers (e.g., Netflix, Hulu, Amazon, Apple, etc.), specific sporting events such as World Cup soccer, real-time gaming, and hard to find television channels from around the world.
The network operators can also dynamically adjust the subscriber's contracted subscription rate if they are streaming any of the above content. In addition to these benefits, network operators can utilize the dynamic bandwidth allocation systems and methods to create a history of the content streamed across the ISP network 16. With this information, more informed and targeted marketing and pricing contracts with the content providers can be negotiated. In context with the above, it is anticipated that service delivery of multimedia content will continue to move away from coaxial cable (for MSO providers) and satellite towards packet-based delivery and the dynamic bandwidth allocation systems and methods anticipate providing powerful tools for network operators to differentiate such service offerings.
Referring to
The HTTP Live Streaming 22 sends audio and video as a series of small files, typically of about 10 seconds duration, called media segment files. Specifically, the HTTP Live Streaming 22 includes audio/video 36 provided to a server 40 including a media encoder 42 providing an MPEG-2 transport stream to a stream segmenter 44. Distribution 46 is performed by a web server 50 which uses an index file 52, or playlist, that gives clients 54 the Uniform Resource Locators (URLs) of the media segment files over HTTP 56. The playlist can be periodically refreshed to accommodate live broadcasts, where media segment files are constantly being produced. The HTTP Live Streaming 22 steams can be identified by the master playlist (manifest) URL format extension of .M3U8. For example, Apple has submitted its solution to IETF (tools.ietf.org/html/draft-pantos-http-live-streaming-11), the contents of which are incorporated by reference herein. An .M3U8 file is an extensible playlist file format. It is an M3U playlist containing UTF-8 encoded text. The m3u file format is a de facto standard playlist format suitable for carrying lists of media file URLs. This is the format used as the index file for the HTTP Live Streaming 22.
A master index file may reference alternate streams of content. References can be used to support delivery of multiple streams of the same content with varying quality levels for different bandwidths or devices. The HTTP Live Streaming 22 supports switching between streams dynamically if the available bandwidth changes. The client software uses heuristics to determine appropriate times to switch between the alternates. Currently, these heuristics are based on recent trends in measured network throughput. The master index file points to alternate streams of media by including a specially tagged list of other index files. A .ts file contains an MPEG-2 Transport Stream. This is a file format that encapsulates a series of encoded media samples—typically audio and video. The file format supports a variety of compression formats, including MP3 audio, AAC audio, H.264 video, and so on.
Thus, in both the HTTP adaptive streaming 20 and the HTTP live streaming (HLS) 22, the OTT content provider 12 has the adaptive streaming encoder/transcoder (i.e., the encoder 26 and the encoder 42) and an adaptive streaming server (i.e., the web server 30, 50). The web server 30, 50 is communicatively coupled to the end users 14 and the ISP network 12 (and possibly via other networks such as access and/or wireless networks). The media encoder 26, 42 receives the source video/audio and generates multiple files of the same video/audio content but which are encoded at different bit rates. For example, the adaptive streaming encoder 26, 42 can output a 128K bit rate file, a 256K bit rate file, a 768K bit rate file and a 65K bit rate audio only file. The segmentation unit then segments each of the different bit rate file into multiple segment files. That is the 128K bit rate file is segmented into multiple files, each contains video/audio packets for predetermined time duration (typically 10 seconds). These files are stored in the database. The adaptive streaming server interfaces with the database and creates a master manifest file which includes child manifest files. Each child manifest file includes references to each of the segment files.
For example, an exemplary manifest file could include:
For example, an exemplary child manifest could include:
Referring to
Again, for illustration purposes, the ISP network 16A includes an OpenFlow packet switch 70, various packet/optical switches 72, and packet switches 74 with the switches 70, 72 each communicatively coupled to the SDN controller 60 via the OpenFlow interface 62 and the mediation software 64 at any of Layers 0-2 (L0 being DWDM, L1 being OTN, and L2 being Ethernet). The switches 70, 72, 74, again for illustration purposes only, are located at various sites including an Ethernet Wide Area Network (WAN) 80, a carrier cloud Central Office (CO) and data center 82, an enterprise data center 84, a Reconfigurable Optical Add/Drop Multiplexer (ROADM) ring 86, a switched OTN site 88, another enterprise data center 90, a central office 92, and another carrier cloud Central Office (CO) and data center 94. Again, the network 16A is shown just to provide context and typical configurations at Layers 0-2 in an SDN network for illustration purposes.
The switches 70, 72, 74 can operate, via SDN, at Layers 0-2. The OpenFlow packet switch 70, for example, can be a large-scale Layer 2 Ethernet switch that operates, via the SDN controller 60, at Layer 2 (L2). The packet/optical switches 72 can operate at any of Layers 0-2 in combination. At Layer 0, the packet/optical switches 72 can provide wavelength connectivity such as via DWDM, ROADMs, etc., at Layer 1, the packet/optical switches 72 can provide time division multiplexing (TDM) layer connectivity such as via Optical Transport Network (OTN), Synchronous Optical Network (SONET), Synchronous Digital Hierarchy (SDH), etc., and at Layer 2, the packet/optical switches 72 can provide Ethernet packet switching. An exemplary configuration of the packet/optical switches 72 and the OpenFlow packet switch 70 is illustrated in
Referring to
In the dynamic bandwidth allocation systems and methods, the OTT content provider 12 has HTTP streaming traffic over the ISP network 16A, i.e. via the switches 70, 72, 74. In conjunction with the SDN controller 60 and the web server 30, 50, the dynamic bandwidth allocation systems and methods include techniques for the web server 30, 50 to uniquely identify HTTP streaming traffic such that the SDN controller 60 and the switches 70, 72, 74 can, via deep packet inspection, determine content flows and adjust SDN bandwidth accordingly if needed. That is, the dynamic bandwidth allocation systems and methods contemplate operation with any type of adaptive HTTP streaming technology such as HTTP Live Streaming and the like to enable the SDN controller 60 to have knowledge of content at higher layers (e.g., Layers 4-7) for a variety of applications. The dynamic bandwidth allocation systems and methods contemplate the web server 30, 50 dynamically identifying the HTTP streams and the SDN controller 60 and the switches 70, 72 identifying the HTTP streams based thereon.
Referring to
When a packet matches the flow entry, the OpenFlow Packet Switch 70 forwards a copy to the SDN Controller 60, which then passes it to the application layer 104 described below. The application layer 104 can include the business applications 118 including a deep packet inspection (DPI) application, a multi-layer service provisioning application, a multi-layer service inventory application, a multi-layer service insight application, a dynamic bandwidth allocation application, and the like. The DPI application is utilized to identify HTTP streams. The multi-layer service provisioning application is utilized to provision services at Layers 0-2 in the network 16A. The multi-layer service inventory application is utilized to monitor an HTTP stream, and the multi-layer service insight application with conjunction with the dynamic bandwidth allocation application can be utilized to move an HTTP stream for various reasons in the network 16A.
Referring to
Referring to
Referring to
Referring to
The method 200 includes initializing a master N-bit Bloom filter with k different hash function associated with the Bloom filter (step 202). For example, the N-bit Bloom filter could be 160 bits. The method 200 repeats each of the following steps for each media segment produced (step 204). The method 200 includes initializing an M-bit empty Bloom Filter with L different hash functions associated with the Bloom filter (step 206). For example, the M-bit Bloom filter could be 80 bits. The method 200 includes, as each segment is produced, taking a first set of bytes of the segment data and performing an M-bit Bloom filter addition by feeding the segment data through each of the L hash function and setting the corresponding Bloom filter bits (step 208). For example, the first set of bytes could be 512 bytes.
The method 200 includes performing master N-bit Bloom filter addition by feeding the data through each of the K hash function and setting the corresponding Bloom filter bits (step 210). The method includes creating a Uniform Resource Indicator (URI) for every media segment that enables its clients to obtain the segment data (step 212) and embedding the Bloom Filter in the URI of every media segment file (step 214). For example, this could be as follows:
- example.com/c35d6c0804b1fc1b742e/segment0.ts
- where example.com is the domain, segment0.ts is a media segment file, and c35d6c0804b1fc1b742e is the Bloom Filter.
The method 200 includes creating a Media Playlist file and creating the URI for the Media Playlist file (step 216). The Playlist file contains each media segment URI with its embedded Bloom Filter. For example, the Playlist file could include:
The method 200 also creates the URI for the Media Playlist file, embedding the master N-bit Bloom Filter and this could include:
- example.com/f1d515ea8a76a81f6f458cc05ea799d59f45bbb4/low.m3u8
Advantageously, this novel use of a Bloom Filter in URI is completely transparent to HTTP streaming client players, thereby working over existing infrastructure. Another novel use is that there are no changes to storage structure on the web servers 30, 50. On the web servers 30, 50 hosting the media segments, URL rewriting can be used to hide the Bloom Filter from the URL. Here is an example for Tomcat using mod_headers:
The Bloom Filter information provided by the method 200 allows the deep packet inspection (DPI) application 150 to identify the packets that belong to the media stream and its segments, at Layer 7. The multi-layer service insight application 180 can track the media streams flowing through services. Referring to
Advantageously, the dynamic bandwidth allocation systems and methods can use the SDN controller 60 and associated applications to determine the streaming content by performing deep packet inspection (DPI) and further associating the content to a multi-layer service. The dynamic bandwidth allocation systems and methods can use the Bloom filter to allow the Deep Packet Inspection component to identify the packets that belong to the media stream and its segments in a completely transparent manner to the HTTP streaming content players without requiring any changes to storage structure on the web servers. Finally, the dynamic bandwidth allocation systems and methods can dynamically adjust bandwidth by provisioning/deprovisioning services spanning multi-layer (L0, L1 and L2) using the OpenFlow protocol based on the original content identified.
Referring to
The processor 302 is a hardware device for executing software instructions. The processor 302 may be any custom made or commercially available processor, a central processing unit (CPU), an auxiliary processor among several processors associated with the server 300, a semiconductor-based microprocessor (in the form of a microchip or chip set), or generally any device for executing software instructions. When the server 300 is in operation, the processor 302 is configured to execute software stored within the memory 310, to communicate data to and from the memory 310, and to generally control operations of the server 300 pursuant to the software instructions. The I/O interfaces 304 may be used to receive user input from and/or for providing system output to one or more devices or components. User input may be provided via, for example, a keyboard, touch pad, and/or a mouse. System output may be provided via a display device and a printer (not shown). I/O interfaces 304 may include, for example, a serial port, a parallel port, a small computer system interface (SCSI), a serial ATA (SATA), a fibre channel, Infiniband, iSCSI, a PCI Express interface (PCI-x), an infrared (IR) interface, a radio frequency (RF) interface, and/or a universal serial bus (USB) interface.
The network interface 306 may be used to enable the server 300 to communicate on a network, such as the Internet, a wide area network (WAN), a local area network (LAN), and the like, etc. The network interface 306 may include, for example, an Ethernet card or adapter (e.g., 10BaseT, Fast Ethernet, Gigabit Ethernet, 10GbE) or a wireless local area network (WLAN) card or adapter (e.g., 802.11a/b/g/n). The network interface 306 may include address, control, and/or data connections to enable appropriate communications on the network. A data store 308 may be used to store data. The data store 308 may include any of volatile memory elements (e.g., random access memory (RAM, such as DRAM, SRAM, SDRAM, and the like)), nonvolatile memory elements (e.g., ROM, hard drive, tape, CDROM, and the like), and combinations thereof. Moreover, the data store 308 may incorporate electronic, magnetic, optical, and/or other types of storage media. In one example, the data store 308 may be located internal to the server 300 such as, for example, an internal hard drive connected to the local interface 312 in the server 300. Additionally in another embodiment, the data store 308 may be located external to the server 300 such as, for example, an external hard drive connected to the I/O interfaces 304 (e.g., SCSI or USB connection). In a further embodiment, the data store 308 may be connected to the server 300 through a network, such as, for example, a network attached file server.
The memory 310 may include any of volatile memory elements (e.g., random access memory (RAM, such as DRAM, SRAM, SDRAM, etc.)), nonvolatile memory elements (e.g., ROM, hard drive, tape, CDROM, etc.), and combinations thereof. Moreover, the memory 310 may incorporate electronic, magnetic, optical, and/or other types of storage media. Note that the memory 310 may have a distributed architecture, where various components are situated remotely from one another, but can be accessed by the processor 302. The software in memory 310 may include one or more software programs, each of which includes an ordered listing of executable instructions for implementing logical functions. The software in the memory 310 includes a suitable operating system (O/S) 314 and one or more programs 316. The operating system 314 essentially controls the execution of other computer programs, such as the one or more programs 316, and provides scheduling, input-output control, file and data management, memory management, and communication control and related services. The one or more programs 316 may be configured to implement the various processes, algorithms, methods, techniques, etc. described herein.
Referring to
In an exemplary embodiment, the network element 400 includes common equipment 410, one or more line modules 420, and one or more switch modules 430. The common equipment 410 can include power; a control module; operations, administration, maintenance, and provisioning (OAM&P) access; user interface ports; and the like. The common equipment 410 can connect to a management system 450 through a data communication network 460. The management system 450 can include a network management system (NMS), element management system (EMS), or the like. Additionally, the common equipment 410 can include a control plane processor configured to operate a control plane as described herein. The common equipment 410 can also provide communication to the SDN controller 60. The network element 400 can include an interface 470 for communicatively coupling the common equipment 410, the line modules 420, and the switch modules 430 therebetween. For example, the interface 470 can be a backplane, mid-plane, a bus, optical or electrical connectors, or the like. The line modules 420 are configured to provide ingress and egress to the switch modules 430 and external to the network element 400. In an exemplary embodiment, the line modules 420 can form ingress and egress switches with the switch modules 430 as center stage switches for a three-stage switch, e.g. a three stage Clos switch. Other configurations and/or architectures are also contemplated. The line modules 420 can include optical transceivers, such as, for example, 1 Gb/s (GbE PHY), 2.5 Gb/s (OC-48/STM-1, OTU1, ODU1), 10 Gb/s (OC-192/STM-64, OTU2, ODU2, 10 GbE PHY), 40 Gb/s (OC-768/STM-256, OTU3, ODU3, 40 GbE PHY), 100 Gb/s (OTU4, ODU4, 100 GbE PHY), etc.
Further, the line modules 420 can include a plurality of optical connections per module and each module may include a flexible rate support for any type of connection, such as, for example, 155 Mb/s, 622 Mb/s, 1 Gb/s, 2.5 Gb/s, 10 Gb/s, 40 Gb/s, and 100 Gb/s, and any rate in between. The line modules 420 can include wavelength division multiplexing interfaces, short reach interfaces, and the like, and can connect to other line modules 420 on remote network elements, end clients, edge routers, and the like. From a logical perspective, the line modules 420 provide ingress and egress ports to the network element 400, and each line module 420 can include one or more physical ports. The switch modules 430 are configured to switch channels, timeslots, tributary units, etc. between the line modules 420. For example, the switch modules 430 can provide wavelength granularity (Layer 0 switching), SONET/SDH granularity such as Synchronous Transport Signal-1 (STS-1) and variants/concatenations thereof (STS-n/STS-nc), Synchronous Transport Module level 1 (STM-1) and variants/concatenations thereof, Virtual Container 3 (VC3), etc.; OTN granularity such as Optical Channel Data Unit-1 (ODU1), Optical Channel Data Unit-2 (ODU2), Optical Channel Data Unit-3 (ODU3), Optical Channel Data Unit-4 (ODU4), Optical Channel Data Unit-flex (ODUflex), Optical channel Payload Virtual Containers (OPVCs), ODTUGs, etc.; Ethernet packet granularity; Digital Signal n (DSn) granularity such as DS0, DS1, DS3, etc.; and the like. Specifically, the switch modules 630 can include both Time Division Multiplexed (TDM) (i.e., circuit switching) and packet switching engines. The switch modules 430 can include redundancy as well, such as 1:1, 1:N, etc. In an exemplary embodiment, the switch modules 430 provide OTN, SONET, or SDH switching.
Those of ordinary skill in the art will recognize the network element 400 can include other components which are omitted for illustration purposes, and that the systems and methods described herein are contemplated for use with a plurality of different network elements with the network element 400 presented as an exemplary type of network element. For example, in another exemplary embodiment, the network element 400 may not include the switch modules 430, but rather have the corresponding functionality in the line modules 420 (or some equivalent) in a distributed fashion. For the network element 400, other architectures providing ingress, egress, and switching therebetween are also contemplated for the systems and methods described herein. In general, the systems and methods described herein contemplate use with any network element providing switching of OTN, SONET, SDH, etc. channels, timeslots, tributary units, wavelengths, packets, etc. Furthermore, the network element 400 is merely presented as one exemplary implementation for the systems and methods described herein. Those of ordinary skill in the art will recognize the systems and methods can be used for practically any type of network element operating at any of Layers 0-2.
Referring to
The network interface 504 can be used to enable the controller 500 to communicate on a network, such as to communicate control plane information to other controllers, to the management system 460, to the SDN controller 60, and the like. The network interface 504 can include, for example, an Ethernet card (e.g., 10BaseT, Fast Ethernet, Gigabit Ethernet) or a wireless local area network (WLAN) card (e.g., 802.11a/b/g). The network interface 504 can include address, control, and/or data connections to enable appropriate communications on the network. The data store 506 can be used to store data, such as control plane information, provisioning data, OAM&P data, etc. The data store 506 can include any of volatile memory elements (e.g., random access memory (RAM, such as DRAM, SRAM, SDRAM, and the like)), nonvolatile memory elements (e.g., ROM, hard drive, flash drive, CDROM, and the like), and combinations thereof. Moreover, the data store 506 can incorporate electronic, magnetic, optical, and/or other types of storage media. The memory 508 can include any of volatile memory elements (e.g., random access memory (RAM, such as DRAM, SRAM, SDRAM, etc.)), nonvolatile memory elements (e.g., ROM, hard drive, flash drive, CDROM, etc.), and combinations thereof. Moreover, the memory 508 may incorporate electronic, magnetic, optical, and/or other types of storage media. Note that the memory 508 can have a distributed architecture, where various components are situated remotely from one another, but may be accessed by the processor 502.
The I/O interface 510 includes components for the controller 500 to communicate to other devices in a node, such as through the local interface 514. The components (502, 504, 506, 508, 510) are communicatively coupled via a local interface 514. The local interface 514 and the I/O interface 510 can be, for example but not limited to, one or more buses or other wired or wireless connections, as is known in the art. The local interface 514 and the I/O interface 510 can have additional elements, which are omitted for simplicity, such as controllers, buffers (caches), drivers, repeaters, and receivers, among many others, to enable communications. Further, the local interface 514 and the I/O interface 510 can include address, control, and/or data connections to enable appropriate communications among the aforementioned components.
It will be appreciated that some exemplary embodiments described herein may include one or more generic or specialized processors (“one or more processors”) such as microprocessors, digital signal processors, customized processors, and field programmable gate arrays (FPGAs) and unique stored program instructions (including both software and firmware) that control the one or more processors to implement, in conjunction with certain non-processor circuits, some, most, or all of the functions of the methods and/or systems described herein. Alternatively, some or all functions may be implemented by a state machine that has no stored program instructions, or in one or more application specific integrated circuits (ASICs), in which each function or some combinations of certain of the functions are implemented as custom logic. Of course, a combination of the aforementioned approaches may be used. Moreover, some exemplary embodiments may be implemented as a non-transitory computer-readable storage medium having computer readable code stored thereon for programming a computer, server, appliance, device, etc. each of which may include a processor to perform methods as described and claimed herein. Examples of such computer-readable storage mediums include, but are not limited to, a hard disk, an optical storage device, a magnetic storage device, a ROM (Read Only Memory), a PROM (Programmable Read Only Memory), an EPROM (Erasable Programmable Read Only Memory), an EEPROM (Electrically Erasable Programmable Read Only Memory), Flash memory, and the like. When stored in the non-transitory computer readable medium, software can include instructions executable by a processor that, in response to such execution, cause a processor or any other circuitry to perform a set of operations, steps, methods, processes, algorithms, etc.
Although the present disclosure has been illustrated and described herein with reference to preferred embodiments and specific examples thereof, it will be readily apparent to those of ordinary skill in the art that other embodiments and examples may perform similar functions and/or achieve like results. All such equivalent embodiments and examples are within the spirit and scope of the present disclosure, are contemplated thereby, and are intended to be covered by the following claims.
Claims
1. A method, comprising:
- operating a multi-layer Software-Defined Networking (SDN) network, wherein the multi-layer SDN network operates at any of Layers 0, 1, and 2, Layer 0 being wavelengths, Layer 1 being Time Division Multiplexing, and Layer 2 being packets;
- uniquely identifying streaming content at Layer 7 over the multi-layer SDN network through deep packet inspection by an SDN application that utilizes a Bloom filter embedded in a resource identifier in the streaming content that is transparent to streaming content clients and that is hidden while the streaming content is hosted on a server via resource identifier rewriting;
- associating the streaming content at Layer 7 to a multi-layer service on the SDN network at any of Layers 0, 1, and 2 based on the uniquely identifying and the Bloom filter embedded in the resource identifier;
- monitoring the streaming content on the SDN network over the multi-layer service using the Bloom filter embedded in the resource identifier; and
- dynamically adjusting bandwidth of the multi-layer service that is currently provisioned on the SDN network at any of Layers 0, 1, and 2 based on the monitoring, wherein the bandwidth comprises one or more of wavelength connectivity and Time Division Multiplexing connectivity, wherein the one or more of the wavelength connectivity and the Time Division Multiplexing connectivity are adjusted based on the monitoring at the higher layers.
2. The method of claim 1, further comprising:
- dynamically adjusting the bandwidth of the multi-layer service utilizing Open Flow on the SDN network.
3. The method of claim 1, wherein the streaming content comprises Hypertext Transfer Protocol (HTTP) adaptive streaming.
4. The method of claim 1, wherein the uniquely identifying, the associating, and the monitoring is performed by an SDN controller.
5. The method of claim 1, further comprising:
- receiving the streaming content from a content provider with the embedded Bloom filter in the resource identifier; and
- tracking the streaming content associated with the content provider over the SDN network.
6. The method of claim 1, further comprising:
- prior to the uniquely identifying and at a content provider, initializing a master N-bit Bloom filter with k different hash functions associated with the Bloom filter; and
- repeating each of the following steps for each media segment comprising segment data produced by the content provider: initializing an M-bit Bloom filter with L different hash functions associated with the filter; as each segment is produced, taking a first set of bytes of the segment data and performing an M-bit Bloom filter addition by feeding the segment data through each of the L hash function and setting the corresponding M-bit Bloom filter bits; performing a master N-bit Bloom filter addition by feeding the data through each of the K hash function and setting the corresponding Bloom filter bits; and creating a Uniform Resource Indicator (URI) for every media segment that enables its clients to obtain the segment data.
7. The method of claim 6, further comprising:
- embedding the Bloom filter in the URI of every media segment file for the uniquely identifying.
8. A Software-Defined Networking (SDN) controller, comprising:
- a network interface communicatively coupled to one or more network devices in a multi-layer Software-Defined Networking (SDN) network, wherein the multi-layer SDN network operates at any of Layers 0, 1, and 2, Layer 0 being wavelengths, Layer 1 being Time Division Multiplexing, and Layer 2 being packets;
- a processor communicatively coupled to the network interface; and
- memory storing instructions that, when executed, cause the processor to: uniquely identify streaming content on higher layers relative to the multi-layer SDN network through deep packet inspection by an SDN application that utilizes a Bloom filter embedded in a resource identifier in the streaming content that is transparent to streaming content clients and that is hidden while the streaming content is hosted on a server via resource identifier rewriting; associate the streaming content at Layer 7 to a multi-layer service on the SDN network at any of Layers 0, 1, and 2 based on the uniquely identifying and the Bloom filter embedded in the resource identifier; monitor the streaming content on the SDN network over the multi-layer service using the Bloom filter embedded in the resource identifier; and dynamically adjust bandwidth of the multi-layer service that is currently provisioned on the SDN network at any of Layers 0, 1, and 2 based on the monitoring, wherein the bandwidth comprises one or more of wavelength connectivity and Time Division Multiplexing connectivity, wherein the one or more of the wavelength connectivity and the Time Division Multiplexing connectivity are adjusted based on the monitoring at the higher layers.
9. The SDN controller of claim 8, wherein the instructions, when executed, further cause the processor to:
- dynamically adjust the bandwidth of the multi-layer service utilizing OpenFlow on the SDN network.
10. The SDN controller of claim 8, wherein the streaming content comprises Hypertext Transfer Protocol (HTTP) adaptive streaming.
11. The SDN controller of claim 8, wherein the instructions, when executed, further cause the processor to:
- perform the deep packet inspection utilizing the Bloom filter embedded in the resource identifier of the streaming content, wherein the embedded Bloom filter is transparent to content players and does not require changes to storage on associated web servers for the streaming content.
12. The SDN controller of claim 8, wherein the instructions, when executed, further cause the processor to:
- receive the streaming content from a content provider with the embedded Bloom filter in the resource identifier; and
- track the streaming content associated with the content provider over the SDN network.
13. A network, comprising:
- a multi-layer Software-Defined Networking (SDN) network, wherein the multi-layer SDN network operates at any of Layers 0, 1, and 2, Layer 0 being wavelengths, Layer 1 being Time Division Multiplexing, and Layer 2 being packets;
- a content provider comprising at least one web server communicatively coupled to the SDN network; and
- an SDN controller communicatively coupled to the SDN network comprising a processor and memory storing instructions that, when executed, cause the processor to: uniquely identify streaming content at Layer 7 from the content provider over the multi-layer SDN network through deep packet inspection by an SDN application that utilizes a Bloom filter embedded in a resource identifier in the streaming content that is transparent to streaming content clients and that is hidden while the streaming content is hosted on a server via resource identifier rewriting; associate the streaming content at Layer 7 to a multi-layer service on the SDN network at any of Layers 0, 1, and 2 based on the uniquely identifying and the Bloom filter embedded in the resource identifier; monitor the streaming content on the SDN network over the multi-layer service using the Bloom filter embedded in the resource identifier; and dynamically adjust bandwidth at any of Layers 0, 1, and 2 of the multi-layer service that is currently provisioned on the SDN network utilizing OpenFlow based on the monitoring, wherein the bandwidth comprises one or more of wavelength connectivity and Time Division Multiplexing connectivity, wherein the one or more of the wavelength connectivity and the Time Division Multiplexing connectivity are adjusted based on the monitoring at the higher layers.
14. The network of claim 13, wherein the streaming content comprises Hypertext Transfer Protocol (HTTP) adaptive streaming.
15. The network of claim 13, wherein the SDN controller is configured to:
- perform the deep packet inspection utilizing the Bloom filter embedded in the resource identifier of the streaming content by the content provider, wherein the embedded Bloom filter is transparent to content players and does not require changes to storage on associated web servers for the streaming content.
16. The network of claim 13, wherein the content provider comprises a server configured to:
- prior to the uniquely identifying, initialize a master N-bit Bloom filter with k different hash functions associated with the Bloom filter; and
- repeat each of the following steps for each media segment comprising segment data produced by the content provider: initialize an M-bit Bloom filter with L different hash functions associated with the filter; as each segment is produced, take a first set of bytes of the segment data and performing an M-bit Bloom filter addition by feeding the segment data through each of the L hash function and setting the corresponding M-bit Bloom filter bits; perform a master N-bit Bloom filter addition by feeding the data through each of the K hash function and setting the corresponding Bloom filter bits; and create a Uniform Resource Indicator (URI) for every media segment that enables its clients to obtain the segment data.
8456984 | June 4, 2013 | Ranganathan et al. |
8499355 | July 30, 2013 | Goncharov |
8504488 | August 6, 2013 | Dutta |
8751511 | June 10, 2014 | Dong |
9038151 | May 19, 2015 | Chua |
20040181588 | September 16, 2004 | Wang |
20080144177 | June 19, 2008 | Miller |
20080271103 | October 30, 2008 | Praden |
20080295140 | November 27, 2008 | Praden |
20110102157 | May 5, 2011 | Tarkoma |
20120158756 | June 21, 2012 | Jimenez |
20130071116 | March 21, 2013 | Ong |
20130163426 | June 27, 2013 | Beliveau et al. |
20130170344 | July 4, 2013 | Crowe |
20130188957 | July 25, 2013 | Deng |
20130223226 | August 29, 2013 | Narayanan et al. |
20130223442 | August 29, 2013 | Narayanan et al. |
20130250770 | September 26, 2013 | Zou |
20130259465 | October 3, 2013 | Blair |
20130272305 | October 17, 2013 | Lefebvre et al. |
20130276092 | October 17, 2013 | Sun et al. |
20140052836 | February 20, 2014 | Nguyen |
20140092905 | April 3, 2014 | Hui |
20140344468 | November 20, 2014 | Saremi |
20140344575 | November 20, 2014 | Saremi |
20150012551 | January 8, 2015 | Dong |
20150016255 | January 15, 2015 | Bisht |
20150026794 | January 22, 2015 | Zuk |
20150039629 | February 5, 2015 | Theeten |
20150127805 | May 7, 2015 | Htay |
2013108121 | July 2013 | WO |
- Nov. 21, 2014 International Search Report issued in International Application No. PCT/US2014/054248.
- Georgopoulos et al., “Towards Network-wide QoE Fairness Using OpenFlow-assisted Adaptive Video Streaming,” Future Human-Centric Multimedia Networking, ACM, Aug. 2013, pp. 15-20.
- Jarschel et al., “SDN-Based Application-Aware Networking on the Example of YouTube Video Streaming,” 2013 Second European Workshop on Software Defined Networks, IEEE, Oct. 2013, pp. 87-92.
- Dharmapurikar S et al: “Deep packet inspection using parallel bloom filters”, IEEE Micro, IEEE Service Center, Los Alamitos, CA, US, val. 24, No. 1, Jan. 1, 2004 (Jan. 1, 2004 ), pp. 52-61, XP0111 08460, ISSN: 0272-1732, DOI: 10.11 09/MM.2004.1268997.
- EPO Communication pursuant to Article 94(3) EPC, Jun. 13, 2017.
Type: Grant
Filed: Nov 4, 2013
Date of Patent: Dec 19, 2017
Patent Publication Number: 20150127805
Assignee: Ciena Corporation (Hanover, MD)
Inventors: Aung Htay (Alpharetta, GA), Paul Hudgins (Roswell, GA), Mallikarjunappa Kore (Alpharetta, GA)
Primary Examiner: Mahran Abu Roumi
Application Number: 14/071,224
International Classification: G06F 15/173 (20060101); H04L 12/28 (20060101); H04L 12/911 (20130101); H04L 12/26 (20060101); H04L 29/06 (20060101); H04L 12/801 (20130101);