The present invention relates generally to mobile packet core networks. More particularly, enclosed herein is a system and method for enrichment of upper layer protocol content in Transmission Control Program (TCP) based sessions when such sessions pass through mobile packet core gateways such as a Gateway General Packet Radio Service (GPRS) Support Node (GGSN) in 2nd Generation (2G)/Third Generation (3G) or PDN gateway (P-GW) in 4th Generation (4G) mobile networks. Specifically, the disclosure herein includes procedures and mechanisms for making content enrichment efficient and eliminates the possibility of occurrence of a TCP signaling storm due to content enrichment being performed in mobile networks.
The GPRS or Universal Mobile Telecommunications System (UMTS) is an evolution of the global system for mobile communications (GSM) standard to provide packet switched data services to GSM mobile stations. Packet-switched data services are used for transmitting chunks of data or for data transfers of an intermittent or bursty nature. Typical applications for 3rd Generation Partnership Project (3GPP) packet service include Internet browsing, wireless e-mail, video streaming, and credit card processing, etc. used by human users.
The main new network architecture entities in the 2G/3G network are GGSN and Serving GPRS Support Node (SGSN) and those in a 4G network are Serving Gateway S-GW and PDN Gateway P-GW. In brief, the SGSN/S-GW is a point of attachment for transport purposes of the data sessions from a radio access network while GGSN/P-GW acts as an Internet Protocol (IP) end point and a router to external networks. The GGSN/P-GW contains routing information for GPRS mobile devices, which is used to tunnel packets through the IP based internal network to the correct SGSN/S-GW. When a mobile device wishes to get access to data services such as the Internet, it must first attach to the mobile network and then obtain an IP address from GGSN/P-GW. This is known as activating a Packet Data Protocol (PDP)-Context in 2G/3G and as activating a bearer in 4G.
Typically, a Transmission Control Program (TCP) session is first established between a user equipment (UE) and a server beyond the mobile network gateways GGSN/P-GW to allow a Hypertext Transfer Protocol (HTTP) session, or a session using any other appropriate upper layer protocol, between the UE and server. The GGSN/P-GW acts as a transparent gateway between the mobile network and the Internet network. This allows the UE to make an HTTP request to the server to access, for example, an Internet address. Note that while the rest of the disclosure refers to GGSN, to the skilled in the art it would be clear that it applies to P-GW as well.
The TCP behavior through a transparent proxy and content enrichment related issues are described in prior art U.S. Patent Publication 20130024523A1 which is hereby incorporated by reference. Some of the text and figures of this reference are reproduced in the disclosure for reference and for providing a context. In general, TCP provides reliable, ordered delivery of a stream of bytes from one application to another. TCP uses a sequence number to identify each segment of data. The sequence number identifies the order of the segments sent from each computer so that the data can be reconstructed in order, regardless of any fragmentation, disordering, or packet loss that may occur during transmission. TCP also uses a cumulative acknowledgment scheme, where the receiver sends an acknowledgment number which signifies that the receiver has received all data preceding the acknowledged sequence number. A TCP message consists of a header and a body section. The TCP header includes identifiers (such as source IP address, destination IP address, source port, destination port, protocol), the sequence and acknowledgement numbers, and other TCP header fields. The body section follows the header and contains the payload data carried for the application. The TCP body section may also contain a header for an application layer protocol. TCP packets are validated by a checksum. The checksum is included in each packet for the receiver to verify the integrity of the transmission.
Referring now to Prior Art
HTTP header enrichment (HE) enables the GGSN to insert HTTP headers into a HTTP request in real time. HTTP header enrichment may be triggered by a packet inspection rule, indicating that information must be added to the header of the HTTP request. The enriched content in the HTTP header will be used by other servers in the network to complete specific authorization, accounting, etc. When HTTP header enrichment is employed, the GGSN is no longer able to act fully transparent. When HTTP headers are added to an HTTP request, the packet size will be changed by the addition of the new content to the message. In order to handle the new packet size, the GGSN must adjust the TCP sequence and acknowledgement numbers.
Referring now to Prior Art
The GGSN 104 must store this information related to the enriched HTTP session so that it is able to properly adjust the TCP sequence and acknowledgement numbers so as to not break the TCP communication session between the UE 102 and the server 106. The GGSN 104 will store a table or database of this enriched flow information for all active flows. The table may include session identifiers (i.e. source IP address, destination IP address, source port number), destination adjustments made to the TCP sequence and/or acknowledgement numbers between the messages sent to the UE 102 and the server 106. Returning to
Presently, terminating the flows in the GGSN only involves releasing resources in the GGSN. The possibility exists that further TCP messages related to a deleted flow may still originate from a UE or from a web server. When this scenario occurs, the GGSN no longer has the flow information stored to make the required adjustments to the TCP sequence or acknowledge numbers before forwarding the message. This mismatch in the TCP sequence and acknowledgement numbers causes TCP miscommunication between the client and server which can lead to a TCP signaling storm in the network, causing high central processing unit (CPU) utilization in the GGSN and a waste of network resources.
After describing the problem associated with content enrichment reference US 20130024523A1 goes on to present an invention that avoids signaling storm scenario by sending RESETs to each end whenever flows are to be deleted from GGSN memory as illustrated in
Aspects of the disclosure herein include a network element for processing message flow of a network comprising: an access network interface unit configured to send and receive communications from a mobile device; and a processor with a memory associated with the network interface unit and adapted to: receive an HTTP Request from a mobile device and identify if the HTTP Request needs to be enriched; if so, create a Redirect URL including: i) an original requested URL; and ii) a Substitution String; and send the Redirect URL back to the mobile device.
Other aspects of the disclosure include a method performed within a network element having an access network interface unit, a processor and memory, said network element configured to process network signaling of a packet core network, the method comprising: receiving an HTTP Request from a mobile device and identifying if the HTTP Request needs to be enriched; if so, creating a Redirect URL including: i) an original requested URL; and ii) a Substitution String; and sending the Redirect URL back to the mobile device.
Other aspects of the disclosure include a network element for processing message flow of a network comprising: an access network interface unit configured to send and receive communications from a mobile device; and a processor with a memory associated with the network interface unit and adapted to: receive an HTTP Request from a mobile device and identify if the HTTP Request needs to be enriched; if so, create a Redirect URL including: i) an original requested URL; and ii) a Substitution String, wherein the size of the Substitution String equals a predicted size of an Enriched Header if the network element were to enrich the HTTP Request; send the Redirect URL back to the mobile device; identify an HTTP Request having the Substitution String; replace the Substitution String in the HTTP Request with the Enriched Header; and transmit the modified HTTP Request to a server.
The present invention is illustrated by way of example and not limitation in the figures of the accompanying drawings in which like references indicate similar elements.
Reference may be made below to specific elements, numbered in accordance with the attached figures. The discussion below should be taken to be exemplary in nature, and not as limiting of the scope of the present invention. The scope of the present invention is defined in the claims, and should not be considered as limited by the implementation details described below, which as one skilled in the art will appreciate, can be modified by replacing elements with equivalent functional elements.
While Prior Art reference US 20130024523A1 addresses the signaling storm scenario, it does not help with per flow sequence storage in the GGSN. The overhead of storage of flow sequence numbers and the task of changing the sequence number in both directions per TCP packet for tens of millions of flows is quite substantial. This disclosure presents a different system and method whereby a network element such as a GGSN leverages its proxy role and utilizes the HTTP redirect mechanism to eliminate the above-said overhead. Accordingly, it should be readily appreciated that in order to overcome the deficiencies and shortcomings of the existing solutions, it would be advantageous to have a solution for eliminating per flow overhead and also preventing TCP signaling storm during content enrichment. As discussed, an issue in content enrichment is the fact that when content is enriched (i.e., modified) the TCP packet size changes and the TCP sequence number reflecting number of bytes sent in the pack become out of sync with the counter maintained at the user and server ends.
The present disclosure is generally directed to a system and method for eliminating the need for an in path gateway to maintain and alter TCP related counters for each flow that goes through the gateway and is subject to content enrichment procedures. Since the gateway does not need to alter the TCP counters this system and method of content enrichment disclosed herein is not susceptible to TCP signaling storms.
The GGSN 504 then issues the redirect 514 to the UE 502 with this as Redirect URL. With that it sends TCP FIN to indicate this TCP connection needs to be terminated. The TCP connection is terminated with RST-ACK 516. Upon receiving the HTTP Redirect the UE 502 issues a new HTTP request to the redirected URL 518 which again comes to GGSN 504. The GGSN 504 identifies the Marker and realizes that the Marker and HE placeholder in the URL need to be replaced by the appropriate X-Header. It proceeds to restore the original URL and augment X-header to it in step 520. The Marker+HE placeholder add up exactly to the size of the X-header. This operation does not require the TCP sequence number to be changed. The GGSN 504 can reduce the delay cause by redirection by precomputing the X-header and use the Marker as a key to insert the correct X-header. The resulting request 522 is then sent to the server 506. The server 506 will then acknowledge (ACK) the TCP sequence number received 105. This signal can now flow through GGSN unmodified since that is what UE 502 expects as well. From this point onwards the normal TCP flow continues and GGSN's header enrichment has no impact whether the session terminates or lasts very long.
In one aspect of the disclosure a network element such as a GGS utilizes its ability to alter the upper layer constructs such as HTTP Redirect. Further, a GGSN can change the URL in anticipation of enrichment it needs to do. For example, it can add marker and placeholder as suffix to the original URL as discussed above. The size of the marker and placeholder could be made exactly to match the size of enrichment text that needs to be done. When the user browser receives the Redirect URL, it will initiate another TCP connection with redirected URL in an HTTP packet. Since this URL contains extra bytes of marker and placeholder, the TCP sequence number will include them as well.
In another aspect of this disclosure, when the redirected HTTP request reaches the GGSN, the marker in the URL tells the GGSN that the URL has been pre-adjusted for the content enrichment. Therefore the GGSN can now safely remove the marker and the placeholder and add the content enrichment information in the HTTP packet. Thus the original URL is restored and the GGSN can forward this to an Internet server without modifying the TCP sequence since the TCP sequence is already correct for the overall HTTP packet. The server unaware of original request, redirection and content enrichment continues to process the request and acknowledges all the bytes received in the TCP packet. This will be fine with the user since that is what is expected. From this point onwards the user and server can continue to communicate without the need for the GGSN to be altering the TCP sequence numbers. In another aspect of this invention, the resumption or termination of TCP session will not cause signaling storm since the UE and server are already in sync with respect to acknowledgments.
As discussed above, the embodiments disclosed herein allow for enrichment of upper layer protocol content in TCP based sessions when such sessions pass through mobile packet core gateways such as a GGSN in 2G/3G networks or P-GW in 4G mobile networks.
The network element 700 as described above and further illustrated in
Alternatively, some embodiments and methods discussed above may be implemented by a non-transitory computer-readable medium storing a program for performing the process. The computer readable medium may store (in any appropriate format) those program elements which are appropriate to perform the method. The term “non-transitory computer readable medium” refers to any medium, a plurality of the same, or a combination of different media, that participate in providing data (e.g., instructions, data structures) which may be read by a computer, a processor or a like device. Such a medium may take many forms, including but not limited to, non-volatile media, volatile media, and transmission media. Non-volatile media may include, for example, optical or magnetic disks and other persistent memory. Volatile media may include dynamic random access memory (DRAM), which typically constitutes the main memory. Common forms of computer-readable media include, for example, a floppy disk, a flexible disk, hard disk, magnetic tape, any other magnetic medium, a CD-ROM, DVD, any other optical medium, a Random Access Memory (RAM), a programmable read only memory (PROM), an erasable programmable read only memory (EPROM), a flash electrically erasable programmable read only memory (FLASH-EEPROM), any other memory chip or cartridge, a carrier wave as described hereinafter, or any other medium from which a computer can read.
In an embodiment, a server computer, network element or centralized authority may not be necessary or desirable. For example, an embodiment may be practiced on one or more devices without a central authority. In such an embodiment, any functions described herein as performed by the server computer or data described as stored on the server computer may instead be performed by or stored on one or more such devices.
Although process (or method) steps may be described or claimed in a particular sequential order, such processes may be configured to work in different orders. In other words, any sequence or order of steps that may be explicitly described or claimed does not necessarily indicate a requirement that the steps be performed in that order unless specifically indicated. Further, some steps may be performed simultaneously despite being described or implied as occurring non-simultaneously (e.g., because one step is described after the other step) unless specifically indicated. Moreover, the illustration of a process by its depiction in a drawing does not imply that the illustrated process is exclusive of other variations and modifications thereto, does not necessarily imply that the illustrated process or any of its steps are necessary to the embodiment(s), and does not imply that the illustrated process is preferred.
In this disclosure, devices or networked elements that are described as in “communication” with each other or “coupled” to each other need not be in continuous communication with each other or in direct physical contact, unless expressly specified otherwise.
In the foregoing specification, embodiments have been described with reference to specific exemplary embodiments thereof. It will be evident that various modifications may be made thereto without departing from the broader spirit and scope of the invention as set forth in the following claims. The specification and drawings are, accordingly, to be regarded in an illustrative sense rather than a restrictive sense.
Number | Name | Date | Kind |
---|---|---|---|
6748386 | Li | Jun 2004 | B1 |
7058626 | Pan | Jun 2006 | B1 |
7058633 | Gnagy | Jun 2006 | B1 |
8780796 | Ballal | Jul 2014 | B1 |
9319476 | Joachimpillai | Apr 2016 | B2 |
9345041 | Ben-Nun | May 2016 | B2 |
9351331 | Meylan | May 2016 | B2 |
20030177274 | Sun | Sep 2003 | A1 |
20030186680 | Bhasin | Oct 2003 | A1 |
20040039822 | Bensimon | Feb 2004 | A1 |
20040111488 | Allan | Jun 2004 | A1 |
20050108299 | Nakajima | May 2005 | A1 |
20060056307 | Hellgren | Mar 2006 | A1 |
20060080439 | Chud | Apr 2006 | A1 |
20060218304 | Mukherjee | Sep 2006 | A1 |
20060242241 | Tock | Oct 2006 | A1 |
20070025374 | Stefan | Feb 2007 | A1 |
20080077809 | Hayler | Mar 2008 | A1 |
20080177829 | Banerjee | Jul 2008 | A1 |
20080220797 | Meiby | Sep 2008 | A1 |
20080256187 | Kay | Oct 2008 | A1 |
20090252072 | Lind | Oct 2009 | A1 |
20100161762 | Saxena | Jun 2010 | A1 |
20100323730 | Karmarkar | Dec 2010 | A1 |
20110022722 | Castellanos Zamora | Jan 2011 | A1 |
20110138458 | Kumar | Jun 2011 | A1 |
20110145435 | Bhatawdekar | Jun 2011 | A1 |
20110202491 | Pandya | Aug 2011 | A1 |
20120054809 | Chowdhury | Mar 2012 | A1 |
20120233333 | Ganesan | Sep 2012 | A1 |
20120275383 | Matsukawa | Nov 2012 | A1 |
20120322470 | Said | Dec 2012 | A1 |
20130024523 | Albasheir | Jan 2013 | A1 |
20130262567 | Walker | Oct 2013 | A1 |
20130324082 | Mohajeri | Dec 2013 | A1 |
20130339477 | Majeti | Dec 2013 | A1 |
20130340094 | Majeti | Dec 2013 | A1 |
20140018063 | Mattsson | Jan 2014 | A1 |
20140059343 | Mohajeri | Feb 2014 | A1 |
20140177507 | Hsu | Jun 2014 | A1 |
20140187195 | Pallares Lopez | Jul 2014 | A1 |
20140226658 | Kakadia | Aug 2014 | A1 |
20140245359 | De Foy | Aug 2014 | A1 |
20140258461 | L'Heureux | Sep 2014 | A1 |
20150088968 | Wei | Mar 2015 | A1 |
20150109995 | Mathai | Apr 2015 | A1 |
20150135283 | Tofighbakhsh | May 2015 | A1 |
20150170072 | Grant | Jun 2015 | A1 |
Entry |
---|
Extended European Search Report and Written Opinion for the corresponding application EP15836426.5, dated Mar. 15, 2018, 7 pages. |
Number | Date | Country | |
---|---|---|---|
20160065644 A1 | Mar 2016 | US |