One or more example embodiments relate to communication systems, for example, Software Defined Networking (SDN) and/or Network Function Virtualization.
Related art multi-homed devices may be connected to multiple network interfaces. For instance, a smartphone may be attached to mobile network (e.g., third generation (3G) and fourth generation (4G) mobile technologies) and a wireless local area network (WLAN), such as, Wi-Fi network, for Internet access. A router in a Wide Area Network (WAN) may also be connected to multiple Internet Service Providers (ISPs).
An advantage of using multi-homed devices is that when an interface is down, Internet connectivity may still be possible through other interfaces. However, with regular Transmission Control Protocol (TCP), the multi-homed devices cannot use multiple interfaces simultaneously for a single TCP connection. As a result, when an interface currently in use goes down, the application must re-establish a new TCP session via another interface for continuity of service and bandwidth aggregation.
Multi-Path TCP (MPTCP) is a TCP extension that allows end-hosts (e.g., multi-homed devices) to use multiple paths together to maximize network utilization and increase redundancy. MPTCP may be implemented in modern operating systems and existing applications without using excessive memory or processing.
As is generally known, MPTCP uses multiple paths concurrently and/or simultaneously for a single TCP connection. This use of multiple paths may cause a relatively large number of out-of-order TCP packets, especially when the paths have different bandwidths and delays. For instance, if a packet arrives at the receiver's buffer over a WLAN while other packets with lower sequence numbers are delayed and still arriving through a mobile network due to congestion, then MPTCP holds the packet received via the WLAN in the reordering queue until its data sequence number is in order. In this case, performance using MPTCP may be degraded.
At least one example embodiment provides a radio access network element comprising: at least one transceiver and at least one processor. The at least one transceiver is configured to transmit and receive content associated with at least one packet communication protocol connection traversing at least a first wireless network and a second wireless network. The at least one processor is coupled to the at least one transceiver, and is configured to execute computer readable instructions to: determine a first available throughput for a first path traversing the first wireless network; determine a second available throughput for a second path traversing the second wireless network; establish, for the at least one packet communication protocol connection, at least one of a first multipath packet flow via the first path and a second multipath packet flow via the second path based on (i) a throughput gap threshold value and (ii) a throughput gap parameter for the first and second paths, the throughput gap parameter indicative of a difference between the first available throughput and the second available throughput.
At least one other example embodiment provides a radio access network element comprising: at least one transceiver and at least one processor. The at least one transceiver is configured to receive content associated with at least one packet communication protocol connection via at least a first connectivity path through a first wireless edge node and a second connectivity path through a second wireless edge node. The at least one processor is coupled to the at least one transceiver, and is configured to execute computer readable instructions to: compute at least one throughput gap parameter for the first and second connectivity paths based on a maximum throughput supported by each of the first and second wireless edge nodes and a maximum throughput across the first and second connectivity paths; and selectively enable and disable at least one of the first and second connectivity paths for receiving the content associated with the at least one packet communication protocol connection based on the computed at least one throughput gap parameter and a throughput gap threshold value for the at least one packet communication protocol connection.
At least one other example embodiment provides a radio access network element comprising: at least one transceiver and at least one processor. The at least one transceiver is configured to receive content associated with at least one packet communication protocol connection via at least a first connectivity path through a first wireless edge node and a second connectivity path through a second wireless edge node. The at least one processor is coupled to the at least one transceiver, and is configured to execute computer readable instructions to: compute a first throughput gap parameter for the first connectivity path based on a first expected throughput and a first maximum throughput supported by the first wireless edge node; compute a second throughput gap parameter for the second connectivity path based on a second expected throughput and a second maximum throughput supported by the second wireless edge node; and selectively enable and disable at least one of the first and second connectivity paths for receiving the content associated with the at least one packet communication protocol connection based on the computed first and second throughput gap parameters and a throughput gap threshold value for the at least one packet communication protocol connection.
The present invention will become more fully understood from the detailed description given herein below and the accompanying drawings, wherein like elements are represented by like reference numerals, which are given by way of illustration only and thus are not limiting of the present invention.
It should be noted that these figures are intended to illustrate the general characteristics of methods, structure and/or materials utilized in certain example embodiments and to supplement the written description provided below. These drawings are not, however, to scale and may not precisely reflect the precise structural or performance characteristics of any given embodiment, and should not be interpreted as defining or limiting the range of values or properties encompassed by example embodiments. The use of similar or identical reference numbers in the various drawings is intended to indicate the presence of a similar or identical element or feature.
Various example embodiments will now be described more fully with reference to the accompanying drawings in which some example embodiments are shown.
Detailed illustrative embodiments are disclosed herein. However, specific structural and functional details disclosed herein are merely representative for purposes of describing example embodiments. This invention may, however, be embodied in many alternate forms and should not be construed as limited to only the embodiments set forth herein.
Accordingly, while example embodiments are capable of various modifications and alternative forms, the embodiments are shown by way of example in the drawings and will be described herein in detail. It should be understood, however, that there is no intent to limit example embodiments to the particular forms disclosed. On the contrary, example embodiments are to cover all modifications, equivalents, and alternatives falling within the scope of this disclosure. Like numbers refer to like elements throughout the description of the figures.
Although the terms first, second, etc. may be used herein to describe various elements, these elements should not be limited by these terms. These terms are only used to distinguish one element from another. For example, a first element could be termed a second element, and similarly, a second element could be termed a first element, without departing from the scope of this disclosure. As used herein, the term “and/or,” includes any and all combinations of one or more of the associated listed items.
When an element is referred to as being “connected,” or “coupled,” to another element, it can be directly connected or coupled to the other element or intervening elements may be present. By contrast, when an element is referred to as being “directly connected,” or “directly coupled,” to another element, there are no intervening elements present. Other words used to describe the relationship between elements should be interpreted in a like fashion (e.g., “between,” versus “directly between,” “adjacent,” versus “directly adjacent,” etc.).
The terminology used herein is for the purpose of describing particular embodiments only and is not intended to be limiting. As used herein, the singular forms “a,” “an,” and “the,” are intended to include the plural forms as well, unless the context clearly indicates otherwise. It will be further understood that the terms “comprises,” “comprising,” “includes,” and/or “including,” when used herein, specify the presence of stated features, integers, steps, operations, elements, and/or components, but do not preclude the presence or addition of one or more other features, integers, steps, operations, elements, components, and/or groups thereof.
It should also be noted that in some alternative implementations, the functions/acts noted may occur out of the order noted in the figures. For example, two figures shown in succession may in fact be executed substantially concurrently or may sometimes be executed in the reverse order, depending upon the functionality/acts involved.
Specific details are provided in the following description to provide a thorough understanding of example embodiments. However, it will be understood by one of ordinary skill in the art that example embodiments may be practiced without these specific details. For example, systems may be shown in block diagrams so as not to obscure the example embodiments in unnecessary detail. In other instances, well-known processes, structures and techniques may be shown without unnecessary detail in order to avoid obscuring example embodiments.
In the following description, illustrative embodiments will be described with reference to acts and symbolic representations of operations (e.g., in the form of flow charts, flow diagrams, data flow diagrams, structure diagrams, block diagrams, etc.) that may be implemented as program modules or functional processes include routines, programs, objects, components, data structures, etc., that perform particular tasks or implement particular abstract data types and may be implemented using existing hardware at, for example, existing base stations, NodeBs, eNodeBs, gateways, servers, etc. Such existing hardware may include one or more Central Processing Units (CPUs), system-on-chip (SOC) devices, digital signal processors (DSPs), application-specific-integrated-circuits, field programmable gate arrays (FPGAs) computers or the like.
Although a flow chart may describe the operations as a sequential process, many of the operations may be performed in parallel, concurrently or simultaneously. In addition, the order of the operations may be re-arranged. A process may be terminated when its operations are completed, but may also have additional steps not included in the figure. A process may correspond to a method, function, procedure, subroutine, subprogram, etc. When a process corresponds to a function, its termination may correspond to a return of the function to the calling function or the main function.
As disclosed herein, the term “storage medium”, “computer readable storage medium” or “non-transitory computer readable storage medium” may represent one or more devices for storing data, including read only memory (ROM), random access memory (RAM), magnetic RAM, core memory, magnetic disk storage mediums, optical storage mediums, flash memory devices and/or other tangible machine readable mediums for storing information. The term “computer-readable medium” may include, but is not limited to, portable or fixed storage devices, optical storage devices, and various other mediums capable of storing, containing or carrying instruction(s) and/or data.
Furthermore, example embodiments may be implemented by hardware, software, firmware, middleware, microcode, hardware description languages, or any combination thereof. When implemented in software, firmware, middleware or microcode, the program code or code segments to perform the necessary tasks may be stored in a machine or computer readable medium such as a computer readable storage medium. When implemented in software, a processor or processors will perform the necessary tasks.
A code segment may represent a procedure, function, subprogram, program, routine, subroutine, module, software package, class, or any combination of instructions, data structures or program statements. A code segment may be coupled to another code segment or a hardware circuit by passing and/or receiving information, data, arguments, parameters or memory contents. Information, arguments, parameters, data, etc. may be passed, forwarded, or transmitted via any suitable means including memory sharing, message passing, token passing, network transmission, etc.
The terms “including” and/or “having”, as used herein, are defined as comprising (i.e., open language). The term “coupled”, as used herein, is defined as connected, although not necessarily directly, and not necessarily mechanically. Terminology derived from the word “indicating” (e.g., “indicates” and “indication”) is intended to encompass all the various techniques available for communicating or referencing the object/information being indicated. Some, but not all, examples of techniques available for communicating or referencing the object/information being indicated include the conveyance of the object/information being indicated, the conveyance of an identifier of the object/information being indicated, the conveyance of information used to generate the object/information being indicated, the conveyance of some part or portion of the object/information being indicated, the conveyance of some derivation of the object/information being indicated, and the conveyance of some symbol representing the object/information being indicated.
As used herein, the term “eNodeB” or “eNB” may be considered synonymous to, and may hereafter be occasionally referred to as a NodeB, base station, transceiver station, base transceiver station (BTS), etc., and describes a transceiver in communication with and providing wireless resources to users in a geographical coverage area. As discussed herein, eNBs may have all functionally associated with conventional, well-known base stations in addition to the capability and functionality to perform the methods discussed herein.
The term “client device” as discussed herein, may be considered synonymous to, and may hereafter be occasionally referred to, as user equipment (UE), user, user device, client, mobile unit, mobile station, mobile user, mobile, subscriber, remote station, access terminal, receiver, etc., and describes a remote user of wireless resources in one or more wireless communication networks (e.g., 3G mobile networks, 4G mobile networks, 5G mobile networks, WLANs, etc.).
As discussed herein, application servers may be web servers that host multimedia content (e.g., voice, video, etc.), Voice over Internet Protocol (VoIP) servers providing VoIP services to users in a network, a web server, an instant messaging server, an email server, a software and/or cloud server, or any other Internet Protocol (IP)-based service deliverable to a mobile or other device using 3GPP access and/or non-3GPP access (e.g., WLAN, Wi-Fi, etc.). In this regard, downlink bearer traffic may include, for example, webpages, videos, emails, instant messages, a direction of a VoIP call, a direction of a video call, or the like, which originates at an application server. Uplink bearer traffic may include requests for webpages, requests for video, emails, instant messages, a direction of a VoIP call, a direction of a video call, upload of a video, or the like.
Benefits, other advantages, and solutions to problems have been described above with regard to specific embodiments of the invention. However, the benefits, advantages, solutions to problems, and any element(s) that may cause or result in such benefits, advantages, or solutions, or cause such benefits, advantages, or solutions to become more pronounced are not to be construed as a critical, required, or essential feature or element of any or all the claims.
According to example embodiments, routers, client devices, UEs, eNBs, WLAN APs, application servers, etc. may be (or include) hardware, firmware, hardware executing software or any combination thereof. Such hardware may include one or more Central Processing Units (CPUs), system-on-chip (SOC) devices, digital signal processors (DSPs), application-specific-integrated-circuits (ASICs), field programmable gate arrays (FPGAs) computers or the like configured as special purpose machines to perform the functions described herein as well as any other well-known functions of these elements. In at least some cases, CPUs, SOCs, DSPs, ASICs and FPGAs may generally be referred to as processing circuits, processors and/or microprocessors.
The client devices, eNBs, WLAN APs, application servers, etc., discussed herein, may also include various interfaces including one or more transmitters/receivers connected to one or more antennas, a computer readable medium, and (optionally) a display device. The one or more interfaces may be configured to transmit/receive (wireline and/or wirelessly) data or control signals via respective data and control planes or interfaces to/from one or more switches, gateways, MMEs, controllers, other eNBs, client devices, etc. As discussed herein, a client device and/or eNB may be referred to as a radio access network (RAN) device, element or entity.
For simplicity and consistency, in some cases, the technological terms used herein refer to the 3d Generation Partnership Project Long Term Evolution (3GPP LTE or LTE) and Multi-Path Transmission Control Protocol (MPTCP) technology, but can be generalized for any wireless technology. Although discussed herein with regard to these technologies, it should be understood that example embodiments may be applicable to any multi-connectivity transport protocol providing connectivity to wireless devices over multiple interfaces (e.g., User Datagram Protocol (UDP)).
As is generally well-known, Multi-Path TCP (MPTCP) is implemented at the transport layer (Internet layer 4), and supports both IPv4 and IPv6. A subflow is a TCP flow on an individual connectivity path that may be defined by a 4-tuple (source and destination IP addresses and TCP port pairs). MPTCP establishes and terminates a subflow similar to regular TCP, but does not attach multiple subflows at the same time.
Referring to
If the server 12 supports MPTCP, then the server 12 replies to the SYN segment by sending a SYN ACK message, including the MP CAPABLE option, to the client device 10 at step S12. The MP CAPABLE option in the SYN ACK message indicates that the server 12 supports MPTCP. The server 12 may indicate the MP CAPABLE option using a flag bit.
At step S14, the client device 10 confirms the MPTCP connection by sending an ACK with the MP CAPABLE option back to the server 12.
During the handshake, both the client device 10 and the server 12 exchange random keys (KEY in
To attach a second subflow to the MPTCP connection, the client device 10 and the server 12 use the MP JOIN option during a subsequent handshake. The client device 10 and the server 12 also exchange random nonces RAND that are used to compute hash-based message authentication codes (HMACs).
In more detail with regard to
In response to receiving the SYN message segment, the server 12 responds to the SYN message segment by sending a SYN ACK message including the MP JOIN option to the client device 10 at step S18. The server 12 may indicate the MP JOIN option using a flag bit. The SYN ACK message from the server 12 also includes the above-discussed random nonces RAND and HMACs.
At step S20, the client device 10 confirms the new subflow by sending an ACK with the MP JOIN option back to the server 12. The ACK message also includes the above-discussed HMACs.
In response to the ACK message from the client device 10, the server 12 sends a final ACK message to the client device 10 at step S22. The final ACK at step S22 is a confirmation message received by the client device 10 from the server 12, containing the HMAC and ACK messages.
Once the two subflows are established, the client device 10 and the server 12 may use the subflows to exchange data concurrently and/or simultaneously. The default scheduler for the MPTCP connection pushes data through the subflow with the lowest Round Trip Time (RTT) as long as there is space in the congestion window for the subflow. If the congestion window is full, then the scheduler moves onto the next subflow with the next highest RTT. Each subflow uses its own TCP sequence numbers, and the MPTCP uses the sequence numbers to ensure that the packets received via the two subflows are delivered to the application layer in order. When packet loss occurs on a subflow, the packet can be retransmitted over another subflow. When one subflow fails, MPTCP may use the other subflow to convey the failure to the other host.
Conventional MPTCP solutions, such as that discussed above with regard to
According to at least some example embodiments, a MPTCP client device monitors current downloading rates on connectivity paths for a given subflow to identify and/or detect relatively poor links that may cause an increase of the reordering queue size at the MPTCP layer at the client device. Upon detecting the relatively poor links, the client device may remove (e.g., temporarily remove) the connectivity path that performs relatively poorly, and re-attach the connectivity path when sufficiently large throughput becomes available. According to at least some example embodiments, the client device may obtain the estimated capacity over the path through an SDN controller.
The number of connectivity paths and/or traffic flows between an application server and a client device may be dynamically adjusted (e.g., added or removed) through the use of a Software-Defined Networking (SDN) framework applicable to client devices. In at least one example embodiment, SDN applications installed on a client device (e.g., a user equipment (UE) or other multi-homed device) and wireless edge nodes (e.g., eNBs, WLAN APs, etc.) track available capacity of various connectivity paths (e.g., all or a subset) between the application server and client devices in real-time, and enable selection of the most appropriate connectivity paths, depending on varying network conditions, which may be triggered either by network events, or simply by mobility of a client device.
According to at least one example embodiment, number of parallel paths in a multi-connectivity protocol (e.g., connectivity paths in MPTCP, UDP, etc.) may be dynamically adjusted with the support of an SDN framework. According to at least one example embodiment, an SDN framework may be configured to: (1) recognize heavily unbalanced traffic load conditions; and/or (2) determine when and how to adjust the number of connectivity paths during traffic downloads.
According to at least one example embodiment, a threshold is used to identify unbalanced traffic load conditions, which may trigger multi-connectivity protocols to behave relatively poorly. An SDN application at multi-connectivity client device monitors the current throughput on connectivity paths to identify relatively poor links that increase the reordering queue size at the multi-connectivity protocol (e.g., MPTCP, UDP, etc.) layer at the client device. The SDN application at the client device obtains the estimated capacity over a connectivity path between the application server and the client device through an SDN controller, and removes the connectivity path(s) with lower capacity relative to other available connectivity paths. The SDN application attaches those connectivity path(s) again when a sufficiently large capacity becomes available.
Referring to
The eNB 204 is connected to an Evolved Packet Core (EPC), which facilitates connection between the EUTRAN (including the eNB 204) and an Internet Protocol Packet Data Network (IP-PDN) 1001. In the example shown in
Still referring to
In the example embodiment shown in
As it is generally known, SDN technology was originally designed to be deployed among switches in data centers, but its availability has been extended to routers in WANs. Using well-known communication protocols such as OpenFlow, an SDN controller may collect various networking feedback (e.g., current link capacity and/or packet loss rate on a link) from WAN routers in real-time. With such information, an SDN controller may dynamically adapt/reconfigure routing paths through the WAN in response to changes in network conditions and/or Quality of Service (QoS) rules that may be updated by service providers (e.g., Internet Service Providers (ISPs)) using SDN Northbound Application Programming Interfaces (APIs).
The SDN application (sometimes referred to herein as the eNB SDN application) 2040 at the eNB 204 and the WLAN AP SDN application 2080 at the WLAN AP 208 (sometimes referred to herein as the WLAN AP SDN application) are in communication with one or more corresponding SDN controllers. As discussed herein, the eNB 204 and the WLAN AP 208 may collectively be referred to more generically as edge nodes or wireless edge nodes. For example, the eNB SDN application 2040 and the WLAN AP SDN application 2080 are in communication with the SDN controller 2060 in the EPC 206. The SDN applications 2020 at the client devices 202 (sometimes referred to herein as the client SDN applications) are also in communication with one or more SDN controllers through the eNB 204 and/or the WLAN AP 208. The WLAN AP SDN application 2080 may also be in communication with the WAN SDN controller within the WAN 218.
In the example embodiment shown in
The SDN applications provide QoS policy and routing table updates at the respective client devices and/or edge nodes based on information provided by the respective SDN controllers.
According to at least some example embodiments, the client SDN application 2020 running on a client device 202 receives various networking information from at least one of the SDN controllers, and selects the most suitable connectivity path or paths for a given user application in real-time. In at least one example embodiment, to avoid scalability issues, the client device 202 may receive the information from the SDN-enabled local edge nodes, such as the WLAN AP 208 and/or eNB 204. Additional functionality of the client SDN applications 2020, as well as the SDN applications 2040 and 2080 at edge nodes 204 and 208 will be discussed in more detail later.
As it is generally known, there are different QoS requirements, depending on the characteristics of user applications. For instance, file downloading using FTP and web browsing are not latency sensitive; on the other hand, network delay is more important to real-time traffic applications, such as Voice over Internet Protocol (VoIP) and online gaming. For over-the-top (OTT) video streaming services, throughput is considered important to provide the increasingly on-demand high resolution video.
The throughput-based path control according to one or more example embodiments may improve and/or maximize downloading rates while using multi-connectivity over multiple paths. For purposes of explanation, in some instances, example embodiments will be discussed with regard to a client device 202 that is requesting content from an application server (e.g., one of servers 212, 216, 220 and 222 in
Referring to
In the example embodiment shown in
According to at least some example embodiments, the intelligence described in the algorithmic flow charts shown in
Referring to
In one example, as is generally known, a theoretical maximum OTA throughput Tputpath
In another example, as is also generally known, the theoretical maximum over-the-air (OTA) throughput Tputpath
At step S403, the client SDN application 2020 at the client device 202 checks whether there is a new flow FlowID that has originated from the client device 202, and which is able to communicate through a set or a subset of M wireless edge nodes, where M≦N. In at least one example, the “check” may be triggered by the client SDN application 2020. According to at least one other example embodiment, if an SDN controller (e.g., SDN controller 2060 within the EPC 206) is aware of the new flow, then the “check” at the client SDN application 2020 may be triggered by the SDN controller using any well-known signaling.
If the client SDN application 2020 determines that a new flow FlowID does not exist at step S403, then the client SDN application 2020 loops back and awaits arrival of a new flow.
Still referring to step S403, if the client SDN application 2020 determines that a new flow FlowID exists, then at step S404 the client SDN application 2020 enters the newly originated flow FlowID into a flow database FlowDB maintained by the client SDN application 2020 at the client device 202. The client SDN application 2020 also communicates with the SDN controller(s) and the SDN applications at the edge nodes to update the flow databases at each of these network elements. By maintaining flow databases FlowDB at respective edge nodes, the SDN application of an edge node has full visibility of the network conditions and has knowledge of the current throughput for each flow for client devices attached to the respective edge node; this allows the SDN application at the edge node to swiftly calculate expected throughputs on an as-needed basis.
Also at step S404, the client SDN application 2020 initializes the current time t_cur, the reference time t_ref and a measurement sample parameter ΔT. The current time t_cur tracks the current time in the system, and the reference time t_ref is initialized to the initial value of the t_cur value (i.e., t_ref=t_cur). The measurement sample parameter ΔT is a measurement sampling interval for measuring throughput metrics at different entities in the network. According to at least one example embodiment, the current time t_cur, the reference time t_ref and the measurement sample parameter ΔT are system time variables maintained by the network elements involved in performing the functionality discussed with regard to example embodiments.
Still referring to step S404, the client SDN application 2020 also initializes integer variable j to 1. The integer variable j tracks the connectivity path identity within the multi-connectivity context for the client device 202. In this regard, j may be an index indicative of a connectivity path between the client device 202 and an application server.
At step S405, the client SDN application 2020 determines whether the difference between an updated current time t_cur and the reference time t_ref is less than the measurement sampling interval ΔT.
If the client SDN application 2020 determines that the difference between the updated current time t_cur and the reference time t_ref is less than the measurement sampling interval ΔT at step S405, then the client SDN application 2020 checks whether the counter value j is less than the number of currently available edge nodes Mat step S406.
If the client SDN application 2020 determines that the counter value j is less than the number of currently available edge nodes M at step S406, then at step S407 the client SDN application 2020 determines whether there is active and/or measurable traffic on the j-th connectivity path from the client device 202 to the wireless network. In at least one example, the client SDN application 2020 determines that there is active and/or measureable traffic on the j-th connecting path if existing flows are using the j-th connectivity path. The client SDN application 2020 determines that there is active/measureable traffic on the j-th connecting path if there are application level packets present at the client device 202. Otherwise, the client SDN application 2020 determines that there is no active/measureable traffic on the j-th connecting path.
If the client SDN application 2020 determines that there is active and/or measurable traffic on the j-th connecting path from the client device 202 to the wireless network at step S407, then at step S408 the client SDN application 2020 measures the current available throughput Tputpath
At step S410, the client SDN application 2020 increments the counter value j=j+1. The process then returns to step S406 and continues as discussed above.
Returning to step S407, if the client SDN application 2020 determines that there is no active and/or measurable traffic flowing on the j-th connectivity path between the client device 202 and the corresponding wireless edge node, then client SDN application 2020 is unable to directly measure the current available throughput on the j-th path. In this case, the client SDN application 2020 initiates and/or requests that the SDN application on the corresponding wireless edge node (e.g., eNB SDN application 2040 at the eNB 204) estimates the theoretically expected throughput Tputpath
In response to the request from the client SDN application 2020, the SDN application at the wireless edge node estimates the theoretically expected throughput Tputpath
Returning to
Returning to step S406, if the index j is greater than or equal to the number of currently available edge nodes M, then at step S411 the client SDN application 2020 determines a maximum achievable throughput TputMax among all available connectivity paths M according to Equation (1) shown below.
TputMax=Max(Tput1,Tput2, . . . ,TputM-1,TputM) (1)
Also at step S411, the client SDN application 2020 resets the index j to 1 to track the connectivity path identity within the multi-connectivity context for the client device 202.
At step S412, the client SDN application 2020 again checks whether the index j is less than the number of currently available edge nodes M.
If the index j is less than the number of current available edge nodes M, then at step S413 the client SDN application 2020 computes a throughput gap parameter TputΔpath
At step S414, the client SDN application 2020 compares the throughput gap parameter TputΔpath
If the throughput gap parameter TputΔpath
In response to the signal from the client SDN application 2020, at step S4152 the SDN controlling entity/entities involves the SDN wireless controller (e.g., 206 within the EPC), which determines whether the problem is a result of link congestion in the WAN segment. In one example, the SDN controller may contact other SDN controller(s) in the WAN segment to determine whether the problem is caused by link congestion in the WAN segment along the end-to-end path content delivery between the client device 202 and the application server. Note that if the SDN controlling entity/entities involves only the client SDN application 2020, then the SDN application, in a similar way as described above, may contact the SDN controller(s) in the WAN segment via the SDN wireless controller that is in the end-to-end path of the content delivery.
If the problem is a result of link congestion in the WAN segment, then at step S4154 the SDN controller attempts to resolve the problem by changing the routing path for the flow FlowID or by re-directing the flow to other available content server(s) that may provide better networking performance at the moment. As discussed briefly herein, an SDN controller may dynamically adapt/reconfigure routing paths through the WAN in response to changes in network conditions and/or Quality of Service (QoS) rules that may be updated by service providers (e.g., Internet Service Providers (ISPs)) using SDN Northbound Application Programming Interfaces (APIs) based on various networking feedback (e.g., current link capacity and/or packet loss rate on a link) collected from WAN routers in real-time.
After sending the signal to the SDN controller, at step S4156 the client SDN application 2020 determines whether the problem persists and whether the local wireless access network congestion is causing the problem. In one example, the client SDN application 2020 may determine whether the congestion problem persists and is a result of wireless access congestion by re-computing the throughput gap parameter TputΔpath
Still referring to step S4156, if the client SDN application 2020 determines that the problem is resolved, and the local wireless access network congestion is not the cause of the congestion problem, then the client SDN application 2020 increments the index j=j+1 at step S418. The process then returns to step S412, and continues as discussed above.
If, however, the client SDN application 2020 determines that the congestion problem has not been resolved at step S4156, then the client SDN application 2020 removes, disconnects and/or disables the j-th connectivity path for the flow FlowID at step S4158.
As shown in
In an example in which the flow is a MPTCP flow, the client SDN application 2020 may remove, disconnect and/or disable the j-th connectivity path by sending a TCP RST message segment to the application server associated with the flow FlowID over the j-th connectivity path. However, in this case, the in-flight packets on the j-th connectivity path may be lost and would need to be resent again over another connectivity path. In an effort to reduce re-transmission of these in-flight packets, the client SDN application 2020 may utilize the method shown in
Referring to
At step S504, the client SDN application 2020 checks whether all in-flight packets on the j-th connectivity path have been delivered to the client device 202.
If, at step S504, the client SDN application 2020 determines that all in-flight packets on the j-th connectivity path have not been delivered to the client device 202, then the client SDN application 2020 loops back and awaits delivery of the remaining in-flight packets to the client device 202.
If, at step S504, the client SDN application 2020 determines that all in-flight packets on the j-th connectivity path have been delivered, then the client SDN application 2020 sends the TCP RST message segment to disconnect the j-th connectivity path at step S506.
Returning to
Returning to step S414, if the throughput gap parameter TputΔpath
At step S416, the client SDN application 2020 determines whether the j-th connectivity path is already in use by the flow FlowID.
If the j-th connectivity path is already in use by the flow FlowID, then the throughput on the j-th connectivity path was measured by the client SDN application 2020 at step S408. On the other hand, if the j-th connectivity path is not in use by the flow FlowID, then the throughput on the j-th connectivity path was estimated at the eNB SDN application 2040 on the wireless edge node 204 at step S409. Accordingly, in one example, the client SDN application 2020 may determine whether the j-th connectivity path is already in use by the flow FlowID according to whether active and/or measurable traffic was present on the j-th connectivity path at step S407.
If the client SDN application 2020 determines that the j-th connectivity path is already in use by the flow FlowID at step S416, then the process proceeds to step S418 and continues as discussed above.
Returning to step S416, if the client SDN application 2020 determines that the j-th connectivity path is not in use by the flow FlowID, then at step S417 the client SDN application 2020 sends a connectivity path addition message to the application server to add the j-th connectivity path for data transmission between the application server and the client device 202. In one example, the connectivity path addition message may be a MP_JOIN message.
The connectivity path addition message to the application server to use the j-th connectivity path for data transmission enables the flow FlowID from the application server to be carried over the j-th connectivity path.
Still referring to step S417, the client SDN application 2020 also sends a message to the SDN application on each wireless edge node and to the SDN wireless controller(s) it can communicate with to update their respective flow database FlowDB with the new connectivity path for the flow FlowID. The process then proceeds to step S418 and continues as discussed above.
Note that in the case when there are multiple flows delivered in parallel to the same client device (e.g., a video flow and a data flow), according to at least one example embodiment, each flow may be mapped to a separate source port on the client device, and the delivery path may be associated with the respective 4-tuple (source and destination IP addresses and TCP port pairs) to which the flow is mapped.
In this example, the j-th connectivity path may not be currently in use by the flow FlowID, but after estimating relatively good throughput conditions over the j-th connectivity path (e.g., at step S409), the client SDN application 2020 may establish a new TCP subflow (with its own source port) over the j-th connectivity path for the flow FlowID, while maintaining connectivity for other parallel flows, which have their own ports.
According to one or more example embodiments in which flows are MPTCP flows, creating new MPTCP subflows includes obtaining a TCP source port number from the Operating System (OS) and establishing a TCP connection to the server. Since methods for obtaining TCP source port numbers and establishing TCP connections are generally well-known, a detailed discussion is omitted.
Returning now to step S412 in
If the client SDN application 2020 identifies a new k-th path during the measurement interval ΔT at step S419, then at step S420 the client SDN application 2020 includes the newly discovered k-th path within the set of connectivity paths and M serving edge nodes. The client SDN application 2020 also communicates with the SDN applications on the wireless edge nodes and the SDN controller(s) it can communicate with to update their respective flow databases at the respective network elements with the k-th path information. The client SDN application 2020 may communicate with the SDN applications on the wireless edge nodes and SDN controller(s) using any well-known signaling.
According to at least some example embodiments, the algorithm exercised through the client SDN application 2020 includes the newly discovered k-th path within the set of connectivity paths and M serving edge nodes. If, however, the new k-th path is associated with a new wireless edge node that is not in the set of M edge nodes, then the client SDN application 2020 increments the value of M (M=M+1).
Returning to step S419 in
If the client SDN application 2020 determines that the flow FlowID has ended at step S422, then the client SDN application 2020 removes the flow FlowID from the flow database FlowDB at the client device 202 at step S424. Also at step S424, the client SDN application 2020 communicates with the SDN applications at the wireless edge nodes and the SDN controller(s) to remove the flow FlowID from the flow databases at the respective network elements. The client SDN application 2020 may communicate with the SDN applications on the wireless edge nodes and SDN controller(s) using any well-known signaling.
Returning to step S422 in
After refreshing the connectivity configuration at step S423, the process proceeds to step S405 and continues as discussed herein.
As discussed above, at step S405, if the client SDN application 2020 determines that the difference between the updated current time t_cur and the reference time t_ref is less than the measurement sampling interval ΔT, then the client SDN application 2020 checks whether the counter value j is less than the number of currently available edge nodes Mat step S406.
If, on the other hand, the client SDN application 2020 determines that the difference between the updated current time t_cur and the reference time t_ref is greater than or equal to the measurement sampling interval ΔT at step S405, then the client SDN application 2020 updates the reference time t_ref with the current time t_cur (t_ref=t_cur) at step S421. The process then proceeds to step S422 and continues as discussed above.
According to one or more example embodiments, throughput gap parameter threshold value TputΔthreshold may be adjusted over time (e.g., through a control loop). As a result, throughput gap parameter threshold value TputΔthreshold may be increased (e.g., more conservative, wherein poorer links are dropped faster) or decreased (e.g., more aggressive, wherein poorer links are dropped more slowly) to improve and/or maximize throughput performance. In yet another example embodiment, different throughput gap parameter threshold values may be used for adding (TputΔThreshold_AddPath) and dropping (TputΔThreshold_DropPath) connectivity paths.
For the sake of clarity, a more specific and simplified example will now be provided with regard to the framework shown in
In this example, the framework includes two serving wireless edge nodes (i.e., M=2); that is, the eNB 204 and the WLAN AP 208. Further, in this example, the SDN application at the wireless network controller initializes a theoretical maximum over-the-air (OTA) throughput TputLTEMax supported by the eNB 204 and a theoretical maximum over-the-air (OTA) throughput TputWLANMax supported by the WLAN AP 208.
As discussed similarly above, the theoretical maximum OTA throughput TputWLANMax supported by the WLAN AP 208 may be computed using the measured Received Signal Strength Indicator (RSSI) and the Modulation and Coding Scheme (MCS) information for the client device 202.
As also discussed similarly above, the theoretical maximum over-the-air (OTA) throughput TputLTEMax supported by the eNB 204 (also referred to as a peak data rate) may be computed based on information such as Channel Quality Indicator (CQI), MCS, bandwidth and number of antennas usable at the eNB 204.
The WLAN AP SDN application 2080 at the WLAN AP 208 estimates the theoretically expected throughput TputWLANExp for the WLAN path through the WLAN AP 208, and the eNB SDN application 2040 at the eNB 204 estimates the theoretically expected throughput TputLTEExp for the LTE path through the eNB 204 with the support of the corresponding SDN controllers.
In one example, assuming that there are L established flows coming from L different users through the WLAN path, the WLAN AP SDN application 2080 at the WLAN AP 208 may calculate the theoretically expected throughput TputWLANExp for the client device 202 over the WLAN path according to Equation (3) shown below.
TputWLANExp=Min(TputWLANWAN,TputWLANLocal) (3)
In Equation (3), the throughput TputWLANLocal is a function of the theoretical maximum achievable throughput TputWLANMax at the client device 202 over the WLAN path and the aggregate current over-the-air (OTA) throughput TputWLANUser
TputWLANLocal=TputWLANMax−Σi=1L-1TputWLANUser
Similarly, assuming that there are P established flows coming from P different users through the LTE path, the eNB SDN application 2040 at the eNB 204 may calculate the theoretically expected throughput TputLTEExp for the client device 202 over the LTE path according to Equation (5) shown below.
TputLTEExp=Min(TputLTELocal) (5)
In Equation (5), the throughput TputLTELocal is a function of the theoretical maximum achievable throughput TputLTEMax at the client device 202 over the LTE path and the aggregate current over-the-air (OTA) throughput TputLTEUser
TputLTELocal=TputLTEMax−Σi=1P-1TputLTEUser
Since experimental results have shown that MPTCP causes relatively poor performance due to increased size of reordering queue under relatively heavily unbalanced traffic load conditions, before utilizing a multi-connectivity protocol (e.g., MPTCP) over the WLAN and LTE paths in
Additionally, the throughput gap for the WLAN path TputΔWLAN and the throughput gap for the LTE path TputΔLTE with respect to the maximum throughput TputMax across the two paths is given by Equations (8) and (9) shown below.
In Equations (8) and (9), the maximum throughput TputMax across the two paths is given by Equation (10) shown below.
TputMax=Max(TputLTEMax,TputWLANMax) (10)
In at least one example embodiment, if the computed throughput gaps over both the LTE path TputΔLTE and the WLAN path TputΔWLAN are less than the tunable throughput gap parameter threshold value TputΔthreshold, both paths are used by the multi-connectivity protocol (e.g., MPTCP). Otherwise, the path with the larger throughput among the two paths is used.
Once the path decisions are complete, at least the client SDN application 2020 at the client device 202 and the SDN applications 2040 and 2080 at the eNB 204 and the WLAN AP 208, respectively, update the traffic information such as the application identification and the connected paths in their local databases (e.g., FlowDB). The client SDN application 2020 at the client device 202 continually monitors the current throughput on the connectivity paths (e.g., LTE and/or WLAN paths) while the client device 202 is downloading content (e.g., streaming audio and/or video, during a telephone call).
According to at least one example embodiment, when the throughput gap TputΔ across the connectivity paths becomes larger than the tunable throughput gap parameter threshold value TputΔthreshold, the client SDN application 2020 at the client device 202 sends a signal to the SDN controller for an edge node to diagnose the network conditions. The SDN controller for the edge node may contact other SDN controller(s) in the WAN segment to determine whether the problem is a result of link congestion in the WAN segment along the end-to-end path between the client device and server. If this is the case, as discussed above, the problem may be resolved either by changing the routing path by the SDN controller(s) or by re-directing the flow to other available content server(s) that may provide better networking performance at the moment.
If after this diagnosis, the problem persists and is a result of local wireless access network congestion, the client SDN application 2020 at the client device 202 may re-calculate the throughput gap parameters to adjust the number of multi-connectivity (e.g., MPTCP) paths with the support of the SDN controller. In one example, the client SDN application 2020 on the client device 202 may remove and/or disable the LTE path if the computed throughput gap TputΔLTE is larger than the threshold. In one example, to remove and/or disable the path, the client SDN application 2020 on the client device 202 may send a TCP RST segment over the connected LTE path. However, in this case, the in-flight packets through the LTE path may be lost and would need to be resent again over the WLAN path. Accordingly, in at least one example embodiment, the client SDN application 2020 sets the RWIN (TCP Receive Window) size to zero, which causes the TCP transmission over the LTE path to be halted. After all in-flight packets are delivered, the client SDN application 2020 on the client device 202 sends the TCP RST segment to disconnect the LTE path.
For an example case in which a new WLAN path characterized by TputWLAN2 is attached during a download (e.g., as a result of the mobility of the client device 202), the client SDN application 2020 on the client device 202 obtains the theoretically expected throughput TputWLAN2Exp for the new WLAN path from the SDN application in the newly WLAN AP (not shown).
If the throughput gap over the newly found WLAN path TputΔWLAN2 is less than the tunable throughput gap parameter threshold value TputΔthreshold, then the client SDN application 2020 on the client device 202 adds the new path using, for example, a MP JOIN option as described above with regard to
The computer 900 also may include a cooperating module/process 905. The cooperating process 905 may be loaded into memory 904 and executed by the processor 902 to implement functions as discussed herein and, thus, cooperating process 905 (including associated data structures) can be stored on a computer readable storage medium, e.g., RAM memory, magnetic or optical drive or diskette, and the like.
The computer 900 also may include one or more input/output devices 906 (e.g., a user input device (such as a keyboard, a keypad, a mouse, and the like), a user output device (such as a display, a speaker, and the like), an input port, an output port, a receiver, a transmitter, one or more storage devices (e.g., a tape drive, a floppy drive, a hard disk drive, a compact disk drive, and the like), or the like, as well as various combinations thereof).
It will be appreciated that computer 900 depicted in
One or more example embodiments may be more resilient and/or suitable for mobile environments. One or more example embodiments may also supress and/or eliminate drawbacks in the state of the art MPTCP-based solutions, allow for improved end-user experience (e.g., better throughput, session continuity, etc.) and/or better use of network resources. Furthermore, one or more example embodiments may also allow a mobile client to more swiftly discover new connectivity paths and consider them for the data transmission while removing and/or dropping obsolete connectivity paths when deemed necessary.
One or more example embodiments address the requirements of mobile clients while preserving the benefits of the multi-connectivity protocols such as MPTCP. One or more example embodiments allow mobile devices to benefit from multi-connectivity while continuously adapting its configuration to the most reliable paths with assistance provided by the intelligence of the future programmable wireless networks.
According to one or more example embodiments, the available capacity of connecting paths (all of them or a preferential sub-set) between a server and a client device is tracked, and the most appropriate connectivity paths are selected depending on varying network conditions, which may be triggered either by network events, or mobility of client devices.
Accordingly, while example embodiments are capable of various modifications and alternative forms, the embodiments are shown by way of example in the drawings and will be described herein in detail. It should be understood, however, that there is no intent to limit example embodiments to the particular forms disclosed. On the contrary, example embodiments are to cover all modifications, equivalents, and alternatives falling within the scope of this disclosure. Like numbers refer to like elements throughout the description of the figures.
Reference is made in detail to embodiments, examples of which are illustrated in the accompanying drawings, wherein like reference numerals refer to the like elements throughout. In this regard, the example embodiments may have different forms and should not be construed as being limited to the descriptions set forth herein. Accordingly, the example embodiments are merely described below, by referring to the figures, to explain example embodiments of the present description. Aspects of various embodiments are specified in the claims.
This non-provisional U.S. patent application claims priority under 35 U.S.C. §119(e) to provisional U.S. patent application No. 62/341,351, filed May 25, 2016, the entire contents of which are incorporated herein by reference.
Number | Date | Country | |
---|---|---|---|
62341351 | May 2016 | US |