METHODS AND SYSTEMS FOR 5G TRAFFIC ROUTING IN IPX WITH NETWORK SLICING
A system and method for routing of 5G mobile data traffic along a routing path in an Internetwork Packet Exchange (IPX) network having requisite Quality of Service (QoS). A proxy is deployed in the IPX network to intercept Session Create request and response messages exchanges between the home network and the visited network. The routing platform extracts Single-Network Slice Selection Assistance Information (S-NSSAI) attribute and uses this attribute and the geographic locations of the visited network and the home network to select a routing path in the IPX network having requisite QoS for the network slice use case. The routing platform uses layer-3 routing technique to anchor User Plane Function (UPF) Proxies deployed at different routing paths in the IPX network. Alternately, the routing platform uses layer-2 routing technique, with Software-Defined Networking (SDN) controller and SDN-switches to route traffic via the selected routing path in the IPX network.
This non-provisional application claims priority to a U.S. Provisional Application having Ser. No. 62/833,347 filed on Apr. 12, 2019.
BACKGROUND OF THE INVENTION 1. Field of the InventionThis invention relates generally to the field of telecommunications networks. More specifically, the invention relates to methods and systems of routing 5G mobile data traffic along Interment Protocol (IP) paths with different Quality of Service (QoS) in Internetwork Packet Exchange (IPX) networks based on network slicing information in a Protocol Data Unit (PDU) session between a mobile device and the Public Data Network (PDN).
2. Brief Description of the Related ArtOne of the key advantages of 5G telecommunications networks is the ability to allocate the appropriate network resources based on the type of a mobile device. This feature is referred to as “network slicing.” In the context of 5G networks, 3GPP defines “network slicing” as a technology for providing a logic end-to-end network from a mobile device to the PDN.
Network slicing enables operators to provide logical networks of different quality of service (QoS) for each 5G use case. Use cases in 5G are broadly divided into three categories, Enhanced Mobile Broadband (eMBB), Massive Internet of Things (mIoT), and Ultra-Reliable and Low Latency Communications (uRLLC). Network slicing enables 5G networks to accommodate the unique characteristics and requirements of each use case category by selecting network paths having appropriate bandwidth, latency, reliability, cost, and concurrency.
Although network slicing is often seen as the future of telecommunication networks, implementing network slicing in roaming scenarios presents serious challenges. One such challenge pertains to implementation of network slicing in Internetwork Packet Exchange (IPX) networks, which were established by GSM Association (GSMA) to provide network interconnectivity between mobile operators. Many network operators rely on IPX to establish interconnectivity with their roaming partners to provide mobile roaming services to their subscribers. Mobile roaming refers to a scenario in which a mobile subscriber of a Home Public Land Mobile Network (HPLMN) operator is using mobile service in a foreign location provided by a Visited Public Land Mobile Network (VPLMN).
In 5G mobile roaming, there are two common approaches for mobile devices to access the Public Data Network (PDN)—“local breakout” and “home-routed.” In local breakout roaming scheme, user traffic is routed to the Internet directly from the VPLMN. In contrast, in the home-routed scenario, user traffic is routed to HPLMN to reach the Internet. Home-routed is the more widely adopted roaming scheme because it provides the HPLMN operator greater control over the service quality and user experience.
When the HPLMN and the VPLMN interconnect via an IPX network and employ home-routed roaming scheme, both signaling and user payload of mobile device traffic traverse the IPX network. To enable roaming mobile devices to take full advantage of the network slicing feature of 5G, the user traffic traversing the IPX network must be sorted based on the mobile device use case category—i.e., eMBB, mIoT, and uRLLC. However, in the current state of the art, there is no solution for efficiently and effectively implementing network slicing in an IPX network.
3. References5G system architecture is described in 3GPP TS23.501 “3rd Generation Partnership Project; Technical Specification Group Services and System Aspects; System Architecture for the 5G System; Stage 2” and TS23.502 “3rd Generation Partnership Project; Technical Specification Group Services and System Aspects; Procedures for the 5G System; Stage 2”. Detailed of network slicing are described in 3GPP TS28.530 “3rd Generation Partnership Project; Technical Specification Group Services and System Aspects; Telecommunication management; Management and orchestration of 5G networks; Concepts, use cases and requirements”, TS28.531 “3rd Generation Partnership Project; Technical Specification Group Services and System Aspects; Management and orchestration of 5G networks; Provisioning;”, TS28.532 “3rd Generation Partnership Project; Technical Specification Group Services and System Aspects; Management and orchestration of networks and network slicing; Provisioning” and TS28.533 “3rd Generation Partnership Project; Technical Specification Group and System Aspects; Management and orchestration; Architecture framework”.
SUMMARY OF THE INVENTIONThis invention pertains to methods and systems for routing 5G user data along Internet Protocol (IP) routing paths with different QoS in an IPX network based on the network slicing information in PDU Session Establishment to address the specific needs of 5G applications.
In an embodiment, the invention pertains to a method of routing 5G roaming mobile data traffic between a visited public land mobile network (VPLMN) and a home public land mobile network (HPLMN), which are interconnected via an Internetwork Packet Exchange (IPX) network. The IPX network has a plurality of predefined routing paths having different QoS. When the VPLMN sends a Protocol Data Unit (PDU) Session Create request message, this message is captured by 5G HyperText Transfer Protocol (HTTP)/2 Proxy deployed at the IPX network. The captured PDU Session Create request message carries a Single-Network Slice Selection Assistance Information (S-NSSAI) value and an IP address of a visited User Plane Function (v-UPF) selected by the VPLMN for this PDU session.
Next, 5G HTTP/2 Proxy identifies the S-NSSAI value within the captured PDU Session Create request message. Based on the identified S-NSSAI value, 5G HTTP/2 Proxy selects a routing path from the plurality of predefined routing paths in the IPX network. The selected routing path is configured to provide requisite QoS for data traffic type corresponding to the S-NSSAI value. In an embodiment, the selected routing path is associated with a UPF-Proxy deployed in the IPX network.
After selecting the UPF-Proxy, the 5G HTTP/2 Proxy modifies the PDU Session Create Request message by replacing the IP address of the v-UPF with an IP address of the selected UPF-Proxy. The modified PDU Session Create request message is sent to the HPLMN. The HPLMN selects a home User Plane Function (h-UPF) and responds with a PDU Session Create response message.
The 5G HTTP/2 Proxy captures the PDU Session Create response message and selects the routing path within the IPX network for data traffic from the HPLMN to the VPLMN (downlink traffic). The 5G HTTP/2 Proxy modifies the PDU Session Create response message by replacing the IP address of the h-UPF with an IP address of a UPF-Proxy associated with the selected routing path for the downlink data traffic. The routing path for the uplink traffic can be the same as the routing path selected for the downlink traffic or, alternatively, the two routing paths can be different. (The data traffic in which downlink packets and uplink traffic traverse different routing paths is known as asymmetric traffic.)
Next, the 5G HTTP/2 Proxy sends the modified PDU Session Create response message to the VPLMN. After PDU session is created, subsequent uplink data packets from the VPLMN to the HPLMN are delivered to the UPF-Proxy via the selected routing path in the IPX network. For asymmetric traffic, subsequent downlink data packets from the HPLMN to the VPLMN can be delivered to a different UPF-Proxy via another routing path in the IPX network. For symmetric traffic, the same UPF-Proxy is used for both uplink and downlink data packets.
In an embodiment, the 5G HTTP/2 Proxy modifies the PDU Session Create request and response messages by replacing an ‘ipv4Addr’ value or an ‘ipv6Addr’ value in a ‘vcnTunnelInfo’ attribute with the IP address of the selected UPF-Proxy.
Each routing path in the IPX network has one or more parameters associated with a 5G use case, wherein the use cases include an Enhanced Mobile Broadband (eMBB), Massive Internet of Things (mIoT), and Ultra-Reliable and Low Latency Communications (uRLLC). Some of the parameters associated with these 5G cases include bandwidth, latency, cost, capacity, and reliability.
In an embodiment, one or more Software-Defined Networking (SDN) switches may be deployed in the IPX network. In this embodiment, the 5G HTTP/2 Proxy communicates with a General Packet Radio Service Tunneling Protocol (GTP) Steering Controller to establish a rule according to which the SDN switches steer data traffic via the selected routing paths. The GTP Steering Controller acts as an Openflow Controller to control the SDN switches to steer data packets.
In an embodiment, the invention pertains to networking and application systems that include the following components: (1) a 5G HTTP/2 Proxy that proxies N16 messages between v-SMF and h-SMF; (2) a UPF Proxy that proxies N9 packets between v-UPF and h-UPF; and (3) a General Packet Radio Service Tunneling Protocol (GTP) Steering Controller that acts as an Openflow Controller to control Software-Defined Networking (SDN) switches to steer GTP-U packets.
When a mobile device attempts to establish a data session, the Access and Mobility Management Function (AMF) in the VPLMN sends a ‘Nsmf_PDUSession_CreateSMContext’ request to v-SMF (N11 interface). V-SMF executes a UPF selection procedure and sends a ‘Nsmf_PDUSession_Create’ request to h-SMF. This request carries the S-NSSAI and v-UPF-IP and is traversed through a 5G HTTP/2 Proxy in the IPX network. The 5G HTTP/2 Proxy captures the S-NSSAI and the IP address of the v-UPF within the request message and the IP address of the h-VPU within the corresponding response message from h-SMF to v-SMF. The 5G HTTP/2 Proxy determines the best routing path for user payload traffic based on the S-NSSAI and VPLMN and HPLMN identities which indicate their geographical locations.
In an embodiment, mobile device traffic is steered with layer-3 routing technique by deploying UPF-Proxy at different path/links in IPX network. The 5G HTTP/2 Proxy manipulates the ‘vcnTunnelInfo’ and ‘hcnTunnelInfo’ attributes in ‘Nsmf_PDUSession_Create’ request and response messages respectively, and replaces the UPF ipv4Addr (or ipv6Addr) in these attributes with the selected UPF-Proxy's IP for the desired routing path.
In another embodiment, mobile device traffic is steered with layer-2 routing technique by deploying SDN-switches that can route traffic along different path/links in IPX network. A ‘GTP Steering Controller’ acts as an SDN-Controller that supports the OpenFlow protocol. It obtains the S-NSSAI information from the 5G HTTP/2 Proxy and installs rules at SDN-switches to examine and route GTP-U packets to the desired path. The OpenFlow matching rules specify the 5-tuples of IP flow between v-UPF and h-UPF (source-IP, destination-IP, source-port, destination-port, protocol-id), together with the uplink and downlink tunnel ID of GTP-U packets. The OpenFlow action rules specifies which egress network interface/port the traffic shall be delivered to.
For a fuller understanding of the invention, reference should be made to the following detailed disclosure, taken in connection with the accompanying drawings, in which:
According to TS23.502, network slice selection procedure happens at registration and Protocol Data Unit (PDU) session establishment procedure. During PDU session establishment, network slice selection procedure is used to select the appropriate v-UPF 28 on the visited network side and, also, to select the appropriate h-UPF 30 on the home network side. The v-UPF 28 and h-UPF 30 are selected based on the type of the use case—e.g., Enhanced Mobile Broadband (eMBB), Massive Internet of Things (mIoT), and Ultra-Reliable and Low Latency Communications (uRLLC).
In a home-routed roaming scenario, the PDU session establishment procedure begins with User Equipment (UE) 32 sending a PDU session establishment request to Access and Mobility Management Function (AMF) 38. Next, AMF 38 sends a PDU Session Create request (‘Nsmf_PDUSession_CreateSMContext Request’) to v-SMF 22, to which v-SMF 22 replies with a response back to AMF 38. Then, v-SMF 22 selects an appropriate v-UPF 28 for this session based on the type of use case.
After selecting the appropriate v-UPF 28, VPLMN 12 communicates this information to HPLMN 14. This step is accomplished by v-SMF 22 sending a PDU Session Create request (‘Nsmf_PDUSession_Create’) to h-SMF 24. The PDU Session Create request carries a Single-Network Slice Selection Assistance Information (S-NSSAI) 40 attribute and tunnel information for v-UPF 28. Next, HPLMN 14 selects the appropriate h-UPF 30 on the home-network side. To select the appropriate h-UPF 30, h-SMF 24 executes a UPF selection procedure. After selecting the appropriate h-UPF 30, h-SMF 24 replies to v-SMF 22 with a PDU Session Create response (‘Nsmf_PDUSession_Create Response’), which carries the tunnel information for the selected h-UPF 30.
The structures of PDU Session Create Request message 42 and PDU Session Create Response message 44 are depicted in
An embodiment of the invention is depicted in
As shown in
In the embodiment depicted in
As will be discussed in more detail below with reference to
In the embodiment depicted in
In step 108, v-SMF sends a PDU Session Create request 42 (Nsmf_PDUSession_Create request) toward h-SMF 24 via 5G HTTP/2 Proxy 52. PDU Session Create request 42 carries S-NSSAI value 40 and IP address of the selected v-UPF 28. In step 110, 5G HTTP/2 Proxy 52 performs UPF-Proxy selection procedure to determine the best UPF-Proxy 54 or 56 based on the type of traffic indicated by S-NSSAI value 40 and geographical location of VPLMN 12 and HPLMN 14. In this example, 5G HTTP/2 Proxy 52 is configured to select first UPF-Proxy 54 if S-NSSAI value 40 indicates eMBB traffic or, alternatively, to select second UPF-Proxy 56 if S-NSSAI value 40 indicates mIoT traffic.
Next, 5G HTTP/2 Proxy 52 mediates PDU Session Create request message 42 by replacing the IP address of v-UPF 28 with the IP address of selected UPF-Proxy 54/56. By replacing the IP address in PDU Session Create request 42, subsequent downlink GTP-U traffic from h-UPF 30 will be routed to the selected UPF-Proxy 54/56. In step 112, the modified PDU Session Create request message 42 is sent to h-SMF 24.
In step 114, h-SMF 24 selects an appropriate h-UPF 30 based on S-NSSAI value 40 in PDU Session Create request 42. In step 116, h-SMF 24 replies to PDU Session Create request 42 with PDU Session Create response 44, which carries the IP address of the selected h-UPF 30. PDU Session Create response 44 is sent via a 5G HTTP/2 Proxy 52 in IPX network 50. 5G HTTP/2 Proxy 52 mediates PDU Session Create response 44, replacing the IP address of h-UPF 30 with the IP address of the selected UPF-Proxy 54/56. Thus, subsequent uplink GTP-U traffic from v-UPF 28 will be routed to the selected UPF-Proxy 54/56. It shall be noted that 5G HTTP/2 Proxy may select different UPF-Proxies 54/56 for uplink (from v-UPF 28 to h-UPF 30) and downlink (from h-UPF 30 to v-UPF 28) GTP-U (asymmetric traffic).
In step 118, 5G HTTP/2 Proxy 52 sends the modified PDU Session Create response 46 to v-SMF 22 to establish the PDU session. In steps 120-124, subsequent data traffic is routed between v-UPF 28 and h-UPF 30 via the appropriate UPF-Proxy (in this example, UPF-Proxy 54 for eMBB traffic or UPF-Proxy 56 for mIoT traffic).
In the embodiment depicted in
In this embodiment, 5G HTTP/2 Proxy 52 intercepts the PDU Session Create Request and Response messages 42 and 44 but does not modify their attributes. Instead, 5G HTTP/2 Proxy 52 extracts S-NSSAI value 40, IP address of v-UPF 28, IP address of h-UPF 30, and GTP-U tunnel ID from messages 42 and/or 44 and passes these values to GTP Steering Controller 58.
In this embodiment, a plurality of SDN switches—e.g., SDN-switches 60 and 62—are deployed in the IPX network 50. Openflow matching and action rules are installed at each SDN-switch 60/62 for each PDU-Session based on the extracted IP address of the v-UPF, IP address of the h-UPF, and tunnel-ID, such that subsequent GTP-U traffic is steered to the desired IP links. For example, GTP-U traffic for eMBB is steered through a different routing path than GTP-U traffic for mIoT. The routing path (IP links) for eMBB have low-latency at higher-cost whereas the routing path (IP links) for mIoT have high-latency at lower-cost.
In step 208, v-SMF 22 sends PDU Session Create request message 42, carrying the S-NSSAI 40 and IP address of v-UPF 28. 5G HTTP/2 Proxy 52 intercepts PDU Session Create request message 42 and extracts the S-NSSAI 40 and IP address of v-UPF 28. In step 210, 5G HTTP/2 Proxy 52 sends PDU Session Create request message 42 to h-SMF 24. In step 212, h-SMF 24 selects h-UPF 30. In step 214, h-SMF 24 sends PDU Session Create response message 44. This message is also captured by 5G HTTP/2 Proxy 52. 5G HTTP/2 Proxy 52 extracts IP address of the selected h-UPF 30 from the PDU Session Create response message 44. In step 216, 5G HTTP/2 Proxy 52 sends PDU Session Create response message 44 to AMF 38.
Next, 5G HTTP/2 Proxy 52 executes its logic to select appropriate routing path/IP link between v-UPF 28 and h-UPF 30 for the PDU Session according to the S-NSSAI value 40 and geographic location of VPMN 12 and HPMN 14. In step 218, 5G HTTP/2 Proxy 52 sends a command to the GTP Steering Controller 58 to perform steering. The command contains the PDU session information including IP address of v-UPF 28, IP address of h-UPF 30, uplink and downlink GTP-U tunnel-id and S-NSSAI 40. In step 220, GTP Steering Controller 58 sends Openflow commands to SDN-switches 60/62 to create rules to perform traffic steering (OFPT_FLOW_MOD), which is a ‘Modify Flow Table’ message. The matching rule is the GTP-U IP 5-tuple (source-IP, source-port, destination-IP, destination-port and IP protocol), together with the uplink and downlink GTP-U tunnel-id. The action rule is to determine which egress network interface port the traffic shall be delivered to. It shall be noted that the IP path/link for uplink (from v-UPF 28 to h-UPF 30) and downlink (from h-UPF 30 to v-UPF 28) GTP-U may be different (asymmetric traffic).
In steps 222-226, after the PDU session is established, subsequent data packets sent between VPLMN 12 and HPLMN 14 are delivered to SDN Switches 60/62. In step 228, SDN Switches 60/62 route the data packets according to the Openflow rules established in step 220. In this manner, the data packets are steered via the routing path in the IPX network that is best suited for handling them based on their type—i.e., an eMBB, a mIoT and an uRLLC.
Software and Hardware Examples
The various techniques described herein can be implemented in connection with hardware or software or, where appropriate, with a combination of both. Thus, the methods and system described herein, or certain aspects or portions thereof, can take the form of program code (i.e., instructions) embodied in tangible media, such as hard drives, solid state drives, or any other machine-readable storage medium, wherein, when the program code is loaded into and executed by a machine, such as a computing device, the machine becomes an apparatus for practicing the invention. In the case of program code execution on programmable computers, the computing device will generally include a processor, a storage medium readable by the processor (including volatile and non-volatile memory and/or storage elements), at least one input device, and at least one output device. The program(s) can be implemented in assembly or machine language, if desired. In any case, the language can be a compiled or interpreted language, and combined with hardware implementations.
The invention can also be practiced via communications embodied in the form of program code that is transmitted over some transmission medium, such as over electrical wiring or cabling, through fiber optics, or via any other form of transmission, wherein, when the program code is received and loaded into and executed by a machine, such as an EPROM, a gate array, a programmable logic device (PLD), a client computer, or the like, the machine becomes an apparatus for practicing the invention. When implemented on a general-purpose processor, the program code combines with the processor to provide a unique apparatus that operates to invoke the functionality of the invention. Additionally, any storage techniques used in connection with the invention can be a combination of hardware and software.
The advantages set forth above, and those made apparent from the foregoing disclosure, are efficiently attained. Since certain changes may be made in the above construction without departing from the scope of the invention, it is intended that all matters contained in the foregoing disclosure or shown in the accompanying drawings shall be interpreted as illustrative and not in a limiting sense.
Claims
1. A method of routing 5G roaming mobile data traffic between a visited public land mobile network (VPLMN) and a home public land mobile network (HPLMN) interconnected via an Internetwork Packet Exchange (IPX) network having a plurality of predefined routing paths, comprising:
- capturing, within the IPX network, a Protocol Data Unit (PDU) Session Create request message from the VPLMN, wherein the PDU Session Create request message carries a Single-Network Slice Selection Assistance Information (S-NSSAI) value and an Internet Protocol (IP) address of a visited User Plane Function (v-UPF);
- identifying the S-NSSAI value within the PDU Session Create request message;
- selecting a first routing path from the plurality of predefined routing paths in the IPX network based on the S-NSSAI value identified from the PDU Session Create Request message, wherein the first routing path is associated with a first UPF-Proxy deployed in the IPX network, the first routing path configured to provide a predefined Quality of Service (QoS) for data traffic associated with the S-NSSAI value;
- modifying the PDU Session Create Request message by replacing the IP address of the v-UPF with an IP address of the first UPF-Proxy, thereby creating a modified PDU Session Create request message;
- sending the modified PDU Session Create request message to the HPLMN;
- capturing, within the IPX network, a PDU Session Create response message from the HPLMN, wherein the PDU Session Create response message carries an IP address of the home User Plane Function (h-UPF);
- modifying the PDU Session Create response message by replacing the IP address of the h-UPF with an IP address of a second UPF-Proxy associated with a second routing path in the IPX network, thereby creating a modified PDU Session Create response message; and
- sending the modified PDU Session Create response message to the VPLMN;
- wherein subsequent uplink data packets from the VPLMN to the HPLMN are delivered to the first UPF-Proxy via the first routing path in the IPX network, and wherein subsequent downlink data packets from the HPLMN to the VPLMN are delivered to the second UPF-Proxy via the second routing path in the IPX network.
2. The method of claim 1, wherein the second routing path is the same as the first routing path and the second UPF-Proxy is the same as the first UPF-Proxy.
3. The method of claim 1, wherein the second routing path is different than the first routing path and the second UPF-Proxy is different than the first UPF-Proxy.
4. The method of claim 1, wherein a geographic location of the VPLMN or the HPLMN is used as a factor in selecting the first routing path, the second routing path, or both.
5. The method of claim 1, wherein the an ‘ipv4Addr’ value or an ‘ipv6Addr’ value in a ‘vcnTunnelInfo’ attribute of the PDU Session Create Request message is replaced with the IP address of the first UPF-Proxy.
6. The method of claim 1, wherein the an ‘ipv4Addr’ value or an ‘ipv6Addr’ value in a ‘hcnTunnelInfo’ attribute of the PDU Session Create Response message is replaced with the IP address of the second UPF-Proxy.
7. The method of claim 1, wherein each of the plurality of the predefined routing paths in the IPX network has one or more attributes associated with a 5G use case.
8. The method of claim 7, wherein the 5G use case is selected from the group consisting of an Enhanced Mobile Broadband (eMBB), Massive Internet Of Things (mIoT), and Ultra-Reliable and Low Latency Communications (uRLLC).
9. The method of claim 7, wherein the one or more attributes associated with the 5G use case is selected from the group consisting of bandwidth, latency, cost, capacity, and reliability.
10.-20. (canceled)
Type: Application
Filed: Apr 13, 2020
Publication Date: Oct 15, 2020
Inventors: Edward Yau (Tseung Kwan O), Huiyue Xu (Tampa, FL), Prashant Datar (Tampa, FL), Ravi Tandon (Sandweiler), Rakesh Mehta (Tampa, FL)
Application Number: 16/847,079