USRE50106E1 - Pre-fetching random-value resource locators - Google Patents
Pre-fetching random-value resource locators Download PDFInfo
- Publication number
- USRE50106E1 USRE50106E1 US18/086,946 US202218086946A USRE50106E US RE50106 E1 USRE50106 E1 US RE50106E1 US 202218086946 A US202218086946 A US 202218086946A US RE50106 E USRE50106 E US RE50106E
- Authority
- US
- United States
- Prior art keywords
- url
- fetch
- resource
- random
- client device
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Active, expires
Links
- 238000004891 communication Methods 0.000 claims abstract description 32
- 230000004044 response Effects 0.000 claims abstract description 15
- 238000000034 method Methods 0.000 claims description 68
- 230000001052 transient effect Effects 0.000 claims description 21
- 230000006870 function Effects 0.000 description 21
- 238000009877 rendering Methods 0.000 description 6
- 230000003068 static effect Effects 0.000 description 4
- 230000009471 action Effects 0.000 description 3
- 230000004048 modification Effects 0.000 description 3
- 238000012986 modification Methods 0.000 description 3
- 230000008901 benefit Effects 0.000 description 2
- 230000001413 cellular effect Effects 0.000 description 2
- 238000013515 script Methods 0.000 description 2
- 238000010586 diagram Methods 0.000 description 1
- 238000005516 engineering process Methods 0.000 description 1
- 239000000835 fiber Substances 0.000 description 1
- 239000000463 material Substances 0.000 description 1
- 238000012545 processing Methods 0.000 description 1
- 239000000758 substrate Substances 0.000 description 1
- 238000012546 transfer Methods 0.000 description 1
- 230000000007 visual effect Effects 0.000 description 1
Images
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L67/00—Network arrangements or protocols for supporting network services or applications
- H04L67/01—Protocols
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L67/00—Network arrangements or protocols for supporting network services or applications
- H04L67/01—Protocols
- H04L67/02—Protocols based on web technology, e.g. hypertext transfer protocol [HTTP]
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L67/00—Network arrangements or protocols for supporting network services or applications
- H04L67/14—Session management
- H04L67/146—Markers for unambiguous identification of a particular session, e.g. session cookie or URL-encoding
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L67/00—Network arrangements or protocols for supporting network services or applications
- H04L67/50—Network services
- H04L67/56—Provisioning of proxy services
- H04L67/568—Storing data temporarily at an intermediate stage, e.g. caching
- H04L67/5681—Pre-fetching or pre-delivering data based on network characteristics
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04B—TRANSMISSION
- H04B7/00—Radio transmission systems, i.e. using radiation field
- H04B7/14—Relay systems
- H04B7/15—Active relay systems
- H04B7/185—Space-based or airborne stations; Stations for satellite systems
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L67/00—Network arrangements or protocols for supporting network services or applications
- H04L67/50—Network services
- H04L67/60—Scheduling or organising the servicing of application requests, e.g. requests for application data transmissions using the analysis and optimisation of the required network resources
Definitions
- the URL is the same each time the network transaction is executed.
- the child resource identified by a static URL can be pre-fetched because the URL will be the same at the time of pre-fetch as when it is later encountered in the parent resource.
- dynamic URLs that resolve in predictable ways can be pre-fetched by first learning how the URL is resolved (e.g., during a prior execution of the network transaction). Then, during a subsequent execution of the network transaction, the now known manner of resolving the URL can be used to pre-fetch the resource.
- the URL is dynamic, it resolves to the same value each time it is resolved.
- the child resource identified by such a dynamic URL can be pre-fetched because the URL will resolve to the same value at the time of pre-fetch as when later encountered in the parent resource.
- a random-value universal resource locator can comprise a variable field and a random-value function for generating a random value for the variable field. Because the variable field will likely contain a different value each time the RV-URL is resolved, it has been thought that RV-URLs cannot be pre-fetched. In some embodiments of the invention, an RV-URL is pre-fetched in anticipation of a client device later requesting the RV-URL while executing a network transaction.
- An RV-URL encountered during pre-fetch can be resolved and a request (often referred to herein as a “pre-fetch request”) for a resource identified by the resolved RV-URL can be sent to the appropriate host server.
- the host server can then respond with the resource (often referred to herein as a “pre-fetched resource”), which can be prepositioned on the client-side of the network along with generation information indicating how the pre-fetch request was generated.
- the generation information can include, for example, the random value of the variable field in the resolved RV-URL.
- the client device first checks a client-side cache for generation information corresponding to the encountered RV-URL. If the client device finds such generation information, the client device uses the generation information to resolve the encountered RV-URL, which should be materially the same as the pre-fetch request previously used to obtain the pre-fetched resource from the host server. If the client device does not find corresponding generation information, the client device resolves the encountered RV-URL by calling the random-value function. Regardless of how the encountered RV-URL is resolved, the client device generates a request for the resolved RV-URL and sends the request to the appropriate host server.
- An interceptor on the client-side of the network intercepts resource requests and checks a client-side cache for a pre-fetched resource that corresponds to the intercepted request. If the interceptor finds such a pre-fetched resource, the interceptor sends the pre-fetched resource to the client device. If the interceptor does not find a corresponding pre-fetched resource, the interceptor forwards the intercepted resource request across the network to the host server.
- FIG. 1 illustrates an example network system according to some embodiments of the invention.
- FIG. 2 shows an example of a computing device.
- FIG. 3 is an example of a method for pre-fetching random-value URLs according to some embodiments of the invention.
- FIGS. 4 A- 5 illustrate a first example of the method of FIG. 3 according to some embodiments of the invention.
- FIGS. 6 A- 7 illustrate a second example of the method of FIG. 3 according to some embodiments of the invention.
- FIG. 8 illustrates an example of a portion of a method for executing a network transaction according to some embodiments of the invention.
- FIG. 9 illustrates a first example of operation of the methods of FIGS. 8 and 11 according to some embodiments of the invention.
- FIG. 10 shows a second example of operation of the methods of FIGS. 8 and 11 according to some embodiments of the invention.
- FIG. 11 is an example of a method for utilizing pre-fetched resources while executing a network transaction according to some embodiments of the invention.
- one object e.g., a material, a layer, a substrate, etc.
- one object can be “on,” “attached to,” or “coupled to” another object regardless of whether the one object is directly on, attached, or coupled to the other object or there are one or more intervening objects between the one object and the other object.
- directions e.g., above, below, top, bottom, side, up, down, under, over, upper, lower, horizontal, vertical, “x,” “y,” “z,” etc.), if provided, are relative and provided solely by way of example and for ease of illustration and discussion and not by way of limitation.
- substantially means sufficient to work for the intended purpose. If used with respect to a numerical value or range, substantially means within ten percent. The term “ones” means more than one.
- a “network resource” includes a visual (e.g., text, image, video, or the like) object, an audio object, a collection of one or more instructions (e.g., a page encoded in hypertext, a style sheet such as a cascading style sheet (CSS) for displaying and/or playing a network resource, a script file such as a JavaScript file, or the like), or a network service made available and/or provided by one device on a network to other devices upon request by one of the other devices.
- a “network resource” is sometimes referred to simply as a “resource.”
- a “parent” resource includes, among other elements, one or more instructions to fetch a “child” resource from a specified device.
- Examples of a parent resource include a web page (e.g., written in a markup language such as hypertext markup language (HTML), extensible markup language (XML), or the like), a media manifest file or other file that references other media objects (e.g., a movie, a prerecorded television show), a service providing access to a streaming media object (e.g., a podcast, a live television broadcast, streaming music, or the like) that references other media objects, a service for transferring a specified data file that references other data objects, or the like. Any of the foregoing can also be a child resource. Additional examples of child resources include images, audio files, video files, style files such as cascaded style sheets (CSS), executable scripts such as JavaScripts, and the like.
- CSS cascaded style sheets
- a “random-value function” is a function that produces a random or pseudorandom value. Examples of random value functions include a random number generation function, a pseudorandom number generation function, or the like.
- a “universal resource locator” specifies the location of a network resource and is sometimes abbreviated URL.
- a universal resource locator comprises a “host identifier” and a “resource identifier.”
- the “host identifier” identifies a host server from which a network resource is to be fetched, and the “resource identifier” identifies the network resource.
- the resource identifier is a path to the resource on the host server.
- universal resource locator includes within its meaning but is not limited to what is commonly referred to in Internet or world-wide-web applications as a universal resource locator or URL.
- a “dynamic universal resource locator” is a resource locator that includes one or more variable fields and one or more instructions (e.g., function(s)) for generating values for the variable fields. “Resolving” a dynamic universal resource locator means executing the instruction(s) and inserting the resulting value(s) into the variable field(s).
- the term dynamic universal resource locator is sometimes abbreviated D-URL herein.
- a “random-value universal resource locator” is a dynamic universal resource locator in which at least one instruction for generating a value for at least one variable field is a random-value or pseudorandom value function.
- a random-value universal resource locator is sometimes abbreviated RV-URL herein.
- pre-fetching means obtaining the resource from the host server identified by the static or resolved URL.
- an RV-URL comprises a variable field and a random-value function and is resolved by executing the random-value function and inserting the resulting random value into the variable field.
- RV-URL when an RV-URL is encountered while attempting to pre-fetch resources likely to be needed during execution of a network transaction, the RV-URL is resolved and utilized to send a pre-fetch request to the identified host server. Resolution information indicating the manner in which the RV-URL was resolved during pre-fetch is provided to the client device.
- the pre-fetched resource When the host server responds with the requested resource (referred to herein as the “pre-fetched resource”), the pre-fetched resource is sent to the client device, which locally caches it. Later, when the client device encounters an RV-URL as part of executing the network transaction, the client device determines whether it has received resolution information indicating how the RV-URL was resolved during pre-fetch. If so, the client device uses the resolution information to resolve the RV-URL to the same value as during pre-fetch. The client device then sends a request for the resolved RV-URL to the relevant host server. An interceptor associated with the client device intercepts the request and determines whether the requested resource has been pre-fetched and locally stored. If yes, the interceptor responds to the request with the locally stored pre-fetched resource and discards the intercepted request. If no, the interceptor forwards the intercepted request to the host server, which responds by sending the requested resource back to the client device.
- An interceptor associated with the client device intercepts the request and determines whether the
- FIG. 1 shows a high level, block diagram depiction of an example of a system 100 according to some embodiments of the invention.
- the system 100 can comprise a network 140 to which one or more client devices 102 (two are shown but there can be fewer or more) and one or more host servers 150 (three are shown but there can be more or fewer) are connected.
- the network 140 can have one or more communication links 142 between client devices 102 and host servers 150 .
- the client devices 102 are on one side (sometimes referred to herein as the “client side”) of such a communications link 142 or network 140
- the host servers 150 are on an opposite side (sometimes referred to herein as the “server side”) of the communications link 142 or network 140 .
- the communications link 142 is a relatively high latency link such as a satellite link.
- the communications link 142 need not be high latency, and the invention is not limited to operating over a satellite link or any type of high latency link.
- a client device 102 can be a computing device such as a desktop or laptop personal computer, a smart cellular telephone, a tablet device, or the like. As such, a client device 102 can comprise any of the hardware and software modules typical of such devices.
- client device 102 a is depicted as comprising a plurality of applications 120 , a resolution information cache 122 , a client-side pre-fetch module 124 , an interceptor 126 , and a pre-fetched cache 128 .
- Each application 120 can be, for example, a software module such as one would expect to be on any of the above-mentioned computing devices.
- One or more of the applications 120 can be configured to execute a network transaction by initially requesting a parent resource from a host server (e.g., 150 a) and then fetching additional resources identified in the parent resource from other host servers (e.g., 150 b and/or 150 c).
- a web browser is an example of such an application 120 , and requesting and rendering a web page (an example of a parent resource) is an example of a network transaction.
- a media player is another example of an application 120 , and requesting and consuming a media manifest (which is another example of a parent resource) is another example of a network transaction.
- the resolution information cache 122 can work with the hinting service 154 and server-side pre-fetch module 152 to identify and pre-fetch one or more of the additional resources that the client device 102 a may need before the client device 102 a encounters instructions to fetch those resources in the parent resource. And those additional resources can be pre-fetched even if the resources are identified in the parent resource by RV-URLs.
- the resolution information cache 122 , client-side pre-fetch module 124 , interceptor 126 , and pre-fetched cache 128 are illustrated as modules of client device 102 a. In other embodiments, one or more of those modules can alternatively be in a separate computing device such as a client proxy device 130 to which the client device 102 a is connected.
- pre-fetched cache 128 , pre-fetch module 124 , and interceptor 126 can be part of a client proxy 130
- resolution information cache 122 is part of the client device 102 a (e.g., part of an application 120 executing a network transaction).
- client device 102 b can be configured like client device 102 a.
- the network 140 can comprise a single network of interconnected computing devices, a plurality of interconnected single networks, or the like.
- the network 140 can comprise one or more local area networks (LANs), wide area networks (WANs), or the like.
- Individual networks that comprise the network 110 can be public and/or private. All or part of the network 140 can be part of the world-wide web (a.k.a. the public Internet). In some embodiments, the network 140 can be the public Internet.
- Host servers 150 can store and provide network resources to other entities (e.g., a client device 102 ) over the network 140 .
- Examples of host servers 150 include web page servers, media servers, email servers, file transfer protocol (FTP) servers, or the like.
- Examples of resources a host server 150 might provide include web pages, images, audio files, video files, text files, streaming content, or the like.
- the hinting service 154 can be configured to provide services that may be used to accelerate execution of a network transaction.
- the hinting service 154 collects information regarding the network transaction and generates hints that can thereafter be used by another subscribing device (e.g., client device 102 a) to execute the same network transaction more efficiently and thus typically in a shorter amount of time.
- the pre-fetch module 152 can be configured to receive hints from the hinting service 154 for a particular network transaction and pre-fetch resources identified in the hints.
- the server-side pre-fetch module 152 and the hinting service 154 can reside on one computing device or multiple computing devices.
- the server-side pre-fetch module 152 can reside on a proxy server (not shown in FIG. 1 ), and the hinting service 154 can reside on a hinting server (not shown in FIG. 1 ).
- FIGS. 4 A- 4 C An example of the foregoing is illustrated in FIGS. 4 A- 4 C .
- the server-side pre-fetch module 152 and the hinting service 154 can reside on the same computing device (not shown in FIG. 1 ).
- An example is illustrated in FIGS. 6 A- 6 C .
- the server-side pre-fetch module 152 and hinting service 154 can be on the server-side of the communications link 142 .
- the server-side pre-fetch module 152 can receive hints from the hinting service 154 that identify one or more of those resources. Some such resources are identified in the hints by RV-URLs. When the server-side pre-fetch module 152 encounters such RV-URLs in the hints, the server-side pre-fetch module 152 can resolve and pre-fetch the RV-URLs.
- the server-side pre-fetch module 152 For each such resolved and pre-fetched RV-URL, the server-side pre-fetch module 152 sends to the client-side pre-fetch module 124 both the pre-fetched child resource and resolution information indicating how the server-side pre-fetch module 152 resolved the RV-URL.
- the client-side pre-fetch module 124 can then store the resolution information in the resolution information cache 122 and the pre-fetched child resource in the pre-fetched cache 128 .
- the application 120 resolves each RV-URL and generates a request to the appropriate host server 150 .
- the application 120 resolves each RV-URL by determining whether resolution information previously stored in the resolution information cache 122 corresponds to the RV-URL. If yes, the application 120 uses the resolution information to resolve the RV-URL to have the same random value as the pre-fetched module 154 previously used to pre-fetch a corresponding child resource. If no, the application 120 resolves the RV-URL by executing the corresponding random-value function and inserting the resulting random value into the variable field of the RV-URL. Regardless of which way the RV-URL was resolved, the application 120 sends a request for the child resource to the host server 150 identified by the resolved RV-URL.
- the interceptor 126 intercepts requests generated by the application 120 and determines whether each intercepted request corresponds to a pre-fetched child resource stored in the pre-fetched cache 128 . If yes, the interceptor 126 responds to the intercepted request with the pre-fetched child resource from the pre-fetched cache 128 and discards the intercepted request. If no. the interceptor 126 forwards the intercepted request to the corresponding host server 150 .
- FIG. 2 illustrates an example computing device 200 suitable for use in system 100 of FIG. 1 .
- Any one or more of the client devices 102 and/or host servers 150 can comprise a computing device that is the same as or similar to computing device 200 of FIG. 2 .
- the client proxy 130 can operate on a computing device like device 200 .
- the hinting service 154 and server-side pre-fetch module 152 can operate on one or multiple distinct computing devices like 200 .
- each of the proxy server 402 and hinting server 404 of FIGS. 4 A- 4 C and/or the hinting server 602 of FIGS. 6 A- 6 C can likewise be the same as or similar to the computing device 200 of FIG. 2 .
- the computing device 200 can include a processor 210 , a memory 220 , a network interface 230 , a display 240 , and one or more user input device 250 . Each of these components can be in communication with the other components via one or more communications buses 260 .
- the computing device 200 illustrated in FIG. 2 is but an example, and many variations are possible.
- the example shown in FIG. 2 includes a user input device 250 and a display 240 , such components are optional and may not be present in some examples, such as in some examples used as servers such as host servers 150 , one or more servers on which the hinting service 140 and the server-side pre-fetch module 152 is located, and/or a server on which a client proxy 130 is located.
- Suitable network interfaces 230 may employ wireless Ethernet, including 802.11 a, g, b, or n standards.
- the network interface 230 can communicate using Radio Frequency (RF), Bluetooth, CDMA, TDMA, FDMA, GSM, Wi-Fi, satellite, or other cellular or wireless technology.
- RF Radio Frequency
- the network interface 230 may communicate through a wired connection and may be in communication with one or more networks, such as Ethernet, token ring, USB, FireWire 1394 , fiber optic, etc.
- any configuration of the memory 220 and processor 210 can be such that computer readable instructions (e.g., software, microcode, firmware, or the like) are stored in memory 220 as non-transient signals.
- the memory 220 can be a non-transient digital memory device.
- Such instructions can cause the processor 210 to perform one or more functions, methods, or the like.
- such instructions can cause the processor 210 to perform all or part of any of method 300 of FIG. 3 , method 800 of FIG. 8 , and/or method 1100 of FIG. 11 .
- any configuration or instance of the computing device 200 can comprise hardwired logic (not shown) that causes the computing device 200 to perform all or any part of the foregoing methods.
- any configuration or instance of the computing device 200 can comprise a combination of non-transient computer readable instructions stored in the memory 220 that can be executed by the processor 210 and hardwired logic (not shown) that causes the computing device 200 to perform all or any part of the foregoing methods.
- each client device 102 , the client proxy 130 (if present), and the one or more computing devices on which the server-side pre-fetch module 152 and hinting service 154 operate can comprise one or more computing devices like device 200 .
- Each application 120 , the client-side pre-fetch module 124 , the interceptor 126 , the server-side pre-fetch module 152 , and/or the hinting service 154 can thus comprise hardwired logic (not shown) and/or non-transient computer readable instructions stored in memory 220 that can be executed by the processor 210 in one or more computing devices like 200 .
- the pre-fetched cache 128 and the resolution information cache 122 can be part of the memory 220 or a similar memory (not shown) of one or more computing devices like 200 .
- FIG. 3 illustrates an example of a method 300 for pre-fetching RV-URLs.
- method 300 is described as being performed on the system 100 of FIG. 1 , and two examples of operation of method 300 are provided. Method 300 is not, however, limited to being performed on system 100 , nor is method 300 limited to any aspect of either of the examples.
- FIGS. 6 A- 7 The second of the examples is shown in FIGS. 6 A- 7 .
- the server-side pre-fetch module 152 is co-located with the hinting service 154 on the same computing device 602 (see FIGS. 6 A- 6 C ).
- communications between client devices 102 and the hinting service 154 may be encrypted and thus not “snoopable” by a proxy server like 402 of FIG. 4 A .
- the pre-fetch module 124 , interceptor 126 , and pre-fetched cache 128 are part of the client device 102 a.
- an event is detected in system 100 that triggers a request to the hinting service 154 for hints for a particular network transaction.
- the event can be any event that indicates a client device 102 a has, might, or probably will initiate the network transaction.
- a proxy server 402 can detect a request by the client device 102 a to a host server 150 a for a particular URL or resource, and the proxy server 402 can then request from the hinting service 154 hints associated with the network transaction that corresponds to the requested URL or resource.
- the method 300 of FIG. 3 is discussed with respect to two examples. It is noted that the examples also illustrate examples of different possible triggers.
- a user of a web browser application e.g., one of applications 120 ) of client device 102 a hovers a mouse cursor over a URL for a web page www.example1.com.
- the mouse hover event is labeled 410 in FIGS. 4 A and 5 .
- the mouse hover 410 is detected (e.g., by the server-side pre-fetch module 152 ) at block 302 of FIG. 3 as an event indicating the possibility that client device 102 a will request the web page www.example1.com.
- a user of a web browser application 120 of client device 102 a selects (e.g., clicks on) a URL for the web page www.example2.com.
- the mouse click is not illustrated in FIGS. 6 A and 7 , but as noted below, the resulting request from client device 102 a for www.example2.com is labeled 632 in FIGS. 6 A and 7 .
- a request for hints associated with the particular network transaction is sent to the hinting service 154 .
- the request for hints can originate from any of a number of possible sources including the client device 102 a, a client proxy 130 , the proxy server 402 , or the like.
- the proxy server 402 detects the mouse hover at block 302 and sends, at block 304 , a request 412 to the hinting service 154 for hints associated with rendering the web page www.example1.com. (See FIGS. 4 A and 5 .)
- the event of block 302 is the client device 102 a selecting (e.g., clicking) a URL representing www.example2.com, and the client device 102 a itself sends, at block 304 , a request 612 to the hinting service 154 for hints associated with rendering the web page www.example2.com. (See FIGS. 6 A and 7 .)
- the hinting service 154 responds by sending the hints, which are received at block 306 .
- the hinting service 154 can send the hints to, which can thus be received by, any of a number of possible entities including the client device 102 a, the client proxy 130 , the server-side pre-fetch module 152 , the proxy server 402 , or the like.
- the hints can be sent to one entity on the network (e.g., the client device 102 a) and also intercepted by another entity (e.g., the server-side pre-fetch module 152 ).
- the hinting service 154 sends hints 414 for rendering the web page www.example1.com to the proxy server 402 . (See FIGS. 4 A and 5 .) In example 2, the hinting service 154 sends hints 614 for rendering the web page www.example2.com to the server-side pre-fetch 152 . (See FIGS. 6 A and 7 .)
- RV-URLs are encountered in the hints.
- the presence of each RV-URL in the hints indicates a possibility, a probability, or a certainty that the client device 102 a will eventually resolve and request the RV-URL as part of executing the particular network transaction.
- Block 308 can be performed by a number of possible entities including the server-side pre-fetch module 152 .
- all or part of block 308 can be performed by the client proxy 130 or the client device 102 a (e.g., the server-side pre-fetch module 152 , one of the applications 120 , or the like).
- the server-side pre-fetch module 152 performs some processing of the hints (e.g., to identify and pre-fetch resources) received from the hinting service 154 and, in doing so, encounters RV-URLs in the hints.
- the hints can also be provided at some point in time to the client device 102 a (e.g., to the application 120 that is expected to execute the network transaction). Alternatively, the hints can be provided at block 320 to the client proxy 130 .
- Blocks 310 through 318 are now executed for each RV-URL identified at block 308 .
- an RV-URL can comprise a host identifier and a resource identifier, which includes at least one variable field and identifies a random-value function for producing a random or pseudorandom value for the variable field.
- Resolving the RV-URL comprises executing the random-value function to produce a random value and then inserting the random value into the variable field.
- the server-side pre-fetch module 152 of FIGS. 4 A- 4 C calls the random number generator, which produces a random number such as “1593.”
- the pre-fetch module 152 in FIGS. 4 A- 4 C thus resolves the RV-URL “hostserver 150 c/FILE- ⁇ variable field ⁇ ” to “host- 150 c/FILE-1593.”
- the pre-fetch module 152 in FIGS. 6 A- 6 C calls the random number generator, which produces a random number such as “3117.”
- the pre-fetch module 152 in FIGS. 6 A- 6 C thus resolves the RV-URL “hostserver 150 c/FILE- ⁇ variable field ⁇ ” to “host- 150 c/FILE-3117.”
- a pre-fetch request for the RV-URL resolved at block 310 is generated.
- a resolved RV-URL points to a particular resource on a particular host.
- the pre-fetch request generated at block 312 can thus be a request to that particular host for the identified resource. Examples of such requests include an HTTP or HTTPS Get command.
- the pre-fetch module 152 of FIGS. 4 A- 4 C generates a pre-fetch request addressed to host server 150 c for the resource at “FILE-1593.”
- the pre-fetch module 152 generates a pre-fetch request addressed to host server 150 c for the resource at “FILE-3117.”
- information regarding resolution of the RV-URL at block 310 is provided to the client-side pre-fetch module 124 , which can store the “resolution information” in the resolution information cache 122 .
- the client device 102 a e.g., the application 120 executing the network transaction
- the resolution information may take any of a number of forms.
- the resolution information can be the random value generated by the random-value function, the resolved RV-URL generated at block 310 , the pre-fetch request generated at block 312 , or the like.
- the resolution information may be sent to the client device 102 a in any number of possible ways.
- the resolution information may be added to the hints received from the hinting service 154 (see block 306 ), which can occur prior to performing block 320 .
- the resolution information can thus be in the hints (e.g., stored in association with the RV-URL) when the hints are sent to the client device 102 a (or proxy client 130 ) at block 320 .
- the resolution information may be sent directly to the client device 102 a (or proxy client 130 ) in which case block 320 can be performed prior to block 314 .
- the resolution information can be cached in the resolution information cache 122 .
- the server-side pre-fetch module 152 of FIGS. 4 A- 4 C sends, to client-side pre-fetch module 124 , resolution information 422 in the form of the pre-fetch request generated at block 312 , namely, the pre-fetch request addressed to host server 150 c for the resource at “FILE-1593.” (See FIGS. 4 B and 5 .)
- 6 A- 6 C adds the resolution information (in this example, the pre-fetch request for “FILE-3117” addressed to host server 150 c) to the hints 614 received from the hinting service 154 (see block 306 ) and later sends the hints 614 with the resolution information 622 to the client-side pre-fetch module 124 (see FIGS. 6 B and 7 ) at block 320 .
- the resolution information in this example, the pre-fetch request for “FILE-3117” addressed to host server 150 c
- the RV-URL resolved at block 310 is pre-fetched. This can be accomplished by sending the pre-fetch request generated at block 312 to the designated host server 150 c.
- the pre-fetch module 152 of FIGS. 4 A- 4 C sends, to host server 150 c, the pre-fetch request 420 for the resource at “FILE-1593” (see FIGS. 4 B and 5 ).
- the pre-fetch module 152 of FIGS. 6 A- 6 C sends, to host server 150 c, the pre-fetch request 620 for the resource at “FILE-3117” (see FIGS. 6 B and 7 ).
- a pre-fetched resource is received from the host server 150 c and sent to the client-side pre-fetch module 124 , where it can be cached in the pre-fetched cache 128 in anticipation of the client device 102 a later requesting the pre-fetched resource while executing the network transaction.
- Block 318 can be accomplished by receiving the pre-fetched resource from the host server 150 c to which the pre-fetch request was sent as part of block 316 , and sending the received pre-fetched resource to the client-side pre-fetch module 124 , which can store the pre-fetched resource in the pre-fetched resource cache 122 .
- the pre-fetch module 152 of FIGS. 4 A- 4 C receives the pre-fetched resource 430 located at “FILE-1593” on host server 150 c and forwards the pre-fetched resource 430 to the client-side pre-fetch module 124 , which stores the pre-fetched resource 430 in the pre-fetched cache 128 .
- the pre-fetch module 152 of FIGS. 6 A- 6 C receives the pre-fetched resource 630 located at “FILE-3117” on host server 150 c and forwards the pre-fetched resource 630 to the client-side pre-fetch module 124 , which stores the pre-fetched resource 630 in pre-fetched cache 128 .
- FIGS. 6 C and 7 See FIGS. 6 C and 7 .
- Method 300 has now resolved an RV-URL encountered in the hints for a particular network transaction with a generated random number and pre-fetched the resolved RV-URL. Moreover, the pre-fetched resource and sufficient resolution information to resolve the RV-URL to the same value has been cached at the client device 102 a and/or a client proxy 130 associated with the client device 102 a.
- FIG. 5 Operation of method 300 with respect to example 1 is summarized in FIG. 5 , which illustrates that the pre-fetched resource 430 is locally stored in pre-fetched cache 128 and resolution information 422 is locally stored in resolution information cache 122 .
- Example 2 is summarized in FIG. 7 , which illustrates that the pre-fetched resource 630 is locally stored in pre-fetched cache 128 and resolution information 622 is locally stored in resolution information cache 122 .
- blocks 310 - 318 can be repeated for each RV-URL encountered in the hints at block 308 .
- Each of blocks 302 - 318 of method 300 can be performed by the server-side pre-fetch module 152 .
- one or more of blocks 302 - 318 can be performed by another network entity such as client proxy 130 or one or more modules in a client device 102 a.
- FIGS. 8 and 11 illustrate examples of methods 800 and 1100 by which a client device 102 (and/or a client proxy 130 if included in system 100 ) utilizes resources pre-fetched by the method 300 of FIG. 3 to accelerate execution of the particular network transaction for which hints were obtained by method 300 FIG. 3 .
- method 800 is described as being performed by an application 120 of device 102 a and method 1100 is described as being performed by the interceptor 126 of system 100 of FIG. 1 .
- the same two examples as discussed above with respect to method 300 are continued to illustrate operation of methods 800 and 1100 .
- Methods 800 and 1100 are not, however, limited to being performed by the application 120 or interceptor 126 but can be performed in whole or in part by other entities of system 100 . Nor are those methods limited to being performed on system 100 . Methods 800 and 1100 are likewise not limited to either of the examples.
- an application 120 of client device 102 a can initiate a network transaction.
- executing a network transaction can result in the application 120 receiving a parent resource from a host server (e.g., 150 a) that includes instructions (e.g., URLs) to fetch additional resources from other host servers (e.g., 150 b, 150 c).
- Examples of network transactions include rendering a web page, playing a media object comprising a manifest that references other media objects, and the like.
- the application 120 can initiate a network transaction at block 802 by, for example, requesting a web page, a media object, or the like.
- an event in example 1 that triggers a request for hints at block 302 in FIG. 3 is a cursor of a browser application 120 of device 102 a hovering over the displayed URL for www.example1.com.
- the user eventually clicks the URL www.example1.com, which, causes the application 120 to send a request for a parent resource 432 associated with www.example1.com.
- the request for a parent resource 432 may occur after one or more RV-URLs from hints 414 for the parent resource have been pre-fetched.
- the request for a parent resource 432 may alternatively occur before one or more RV-URLs from hints 414 for the parent resource have been pre-fetched
- an event in example 2 that triggers a request for hints at block 302 in FIG. 3 is the user of a browser application 120 of device 102 a clicking a displayed URL www.example2.com.
- the user's click causes the application 120 to send a request for a parent resource 632 associated with www.example2.com to host server 150 a, which in this example, may occur generally at about the same time as the request for hints 612 made as part of block 304 .
- the application 120 receives the parent resource requested at block 802 . As shown in FIGS. 9 and 10 , in both examples 1 and 2, the application 120 receives the parent resource 434 (example 1) or parent resource 634 (example 2) of the selected URL.
- the application 120 identifies in the parent resource, among other elements, RV-URLs.
- RV-URLs As the application 120 parses the parent resource 434 www.example1.com, the application 120 eventually finds the same RV-URL that was found as part of executing method 300 , namely, host-server- 150 c/FILE- ⁇ variable field ⁇ and a random number generator for the variable field.
- the application 120 eventually finds the same RV-URL in parent resource 634 www.example2.com.
- Method 800 can perform blocks 808 - 818 for each RV-URL found at block 806 .
- application 120 determines whether the RV-URL corresponds to resolution information locally stored in resolution information cache 122 . Any such resolution information would have been sent from the server-side pre-fetch module 152 to the client-side pre-fetch module 124 at block 314 of FIG. 3 .
- the application 120 finds in resolution information cache 122 resolution information 422 for RV-URL host-server- 150 c/FILE- ⁇ variable field ⁇ indicating that it was resolved at block 310 of method 300 to host-server- 150 c/FILE-1593. (See FIG. 9 .)
- the application 120 finds in resolution information cache 122 resolution information 622 that the RV-URL host-server- 150 c/FILE- ⁇ variable field ⁇ was resolved at block 310 of method 300 to host-server- 150 c/FILE-3117. (See FIG. 10 .)
- the application 120 branches at block 810 to block 812 , where the application 120 resolves the RV-URL using the cached resolution information. This can be accomplished, for example, by inserting the random number from the resolution information into the variable field of the RV-URL.
- the RV-URL, as resolved at block 812 should therefore be materially the same (e.g., have the same random value) as the RV-URL previously resolved at block 310 of FIG. 3 and then used to pre-fetch the RV-URL at block 316 .
- the application 120 of client device 102 a thus inserts the random number 1593 from resolution information cache 122 into the RV-URL found at block 806 , which resolves to host-server- 150 c/FILE-1593.
- the application 120 of the client device 102 a inserts the random number 3117 from resolution information cache 122 into the RV-URL found at block 806 , which resolves to host-server- 150 c/FILE-3117.
- the application 120 branches at block 810 to block 814 , where the application 120 resolves the RV-URL found at block 806 by executing the random-value function and inserting the resulting random value into the variable field of the RV-URL. This is a resolved RV-URL that has not been pre-fetched.
- the application 120 proceeds to block 816 , where the application 120 generates a request for the resolved RV-URL found at block 806 . This can be accomplished generally as discussed above with respect to block 312 , except that the request is not a pre-fetch but is an actual request from the application 120 .
- the application 120 can send the request for the resolved RV-URL to the corresponding host server 150 .
- the application 120 sends the request 442 (which was generated at block 812 ) to host server 150 c for a resource at FILE-1593. (See FIG. 9 .)
- the application 120 sends the request 642 (which was generated at block 812 ) to host server 150 c for a resource at FILE-3117. (See FIG. 10 .)
- the interceptor 126 in client device 102 a intercepts the request for the resolved RV-URL sent at block 818 of FIG. 8 .
- the interceptor 126 determines whether there is a locally stored pre-fetched response in the pre-fetched cache 128 that corresponds to the intercepted request.
- the interceptor 126 can match the intercepted request to a pre-fetched response in the pre-fetched cache 128 in any of a number of ways. For example, the interceptor 126 can compare all or a portion (e.g., the random value) of the resolved RV-URL of the intercepted request to a corresponding portion of the resolved RV-URLs of the pre-fetched requests in the pre-fetched cache 128 .
- the interceptor 126 can compare all or a portion (e.g., the random value) of the resolved RV-URL of the intercepted request to a corresponding portion of the resolved RV-URLs of the pre-fetched requests in the pre-fetched cache 128 .
- the interceptor 126 can then determine that a matching pre-fetched resource corresponds to the intercepted request and branch at block 1106 to block 1108 , where the interceptor 126 can fulfill the intercepted request with the corresponding pre-fetched resource from the pre-fetched cache 128 . Because the pre-fetched resource is thus a complete response to the intercepted request, the intercepted request can be discarded at block 1112 .
- the interceptor 126 intercepts, at block 1102 , the request 642 to host server 150 c for the resource at FILE-3117 and finds, at block 1104 , a corresponding pre-fetched resource 630 in pre-fetched cache 128 (which, as discussed above, was sent to the client device 102 a as part of block 318 of FIG. 3 ).
- the interceptor 126 therefore branches to block 1108 , where the interceptor sends, as a response to the intercepted request 642 , the pre-fetched resource 630 from pre-fetched cache 128 that corresponds to a request to host server 150 c for resource at FILE-3117.
- the interceptor 126 then discards the intercepted request 642 . (See FIG. 10 .)
- the interceptor 126 determines at block 1104 that no matching pre-fetched resource is locally cached, the interceptor branches to block 1110 , where the interceptor 126 forwards the intercepted request to the host server 150 c to which the request is addressed.
- the host server 150 c will receive the request and respond with the requested resource, which will then be received from the host server 150 c by the client device 102 a.
- the RV-URLs are described as identifying content resources.
- the RV-URLs can represent any network resource or service.
- Pre-fetched resources can thus be any type of network resource or service.
Landscapes
- Engineering & Computer Science (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Information Transfer Between Computers (AREA)
Abstract
Description
Claims (56)
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US18/086,946 USRE50106E1 (en) | 2016-12-02 | 2022-12-22 | Pre-fetching random-value resource locators |
Applications Claiming Priority (3)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US201662429578P | 2016-12-02 | 2016-12-02 | |
US15/819,679 US10880396B2 (en) | 2016-12-02 | 2017-11-21 | Pre-fetching random-value resource locators |
US18/086,946 USRE50106E1 (en) | 2016-12-02 | 2022-12-22 | Pre-fetching random-value resource locators |
Related Parent Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US15/819,679 Reissue US10880396B2 (en) | 2016-12-02 | 2017-11-21 | Pre-fetching random-value resource locators |
Publications (1)
Publication Number | Publication Date |
---|---|
USRE50106E1 true USRE50106E1 (en) | 2024-08-27 |
Family
ID=62244129
Family Applications (2)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US15/819,679 Active 2038-11-26 US10880396B2 (en) | 2016-12-02 | 2017-11-21 | Pre-fetching random-value resource locators |
US18/086,946 Active 2038-11-26 USRE50106E1 (en) | 2016-12-02 | 2022-12-22 | Pre-fetching random-value resource locators |
Family Applications Before (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US15/819,679 Active 2038-11-26 US10880396B2 (en) | 2016-12-02 | 2017-11-21 | Pre-fetching random-value resource locators |
Country Status (1)
Country | Link |
---|---|
US (2) | US10880396B2 (en) |
Families Citing this family (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US10447811B2 (en) * | 2017-07-18 | 2019-10-15 | Citrix Systems, Inc. | Cloud to on-premises debug service routing |
Citations (47)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5485609A (en) | 1994-05-20 | 1996-01-16 | Brown University Research Foundation | Online background predictors and prefetchers for locality management |
US6055569A (en) | 1998-01-27 | 2000-04-25 | Go Ahead Software Inc. | Accelerating web access by predicting user action |
US6085193A (en) | 1997-09-29 | 2000-07-04 | International Business Machines Corporation | Method and system for dynamically prefetching information via a server hierarchy |
US6301617B1 (en) * | 1997-08-25 | 2001-10-09 | Intel Corporation | Selection of resources utilizing virtual uniform resource locators |
US20010047517A1 (en) | 2000-02-10 | 2001-11-29 | Charilaos Christopoulos | Method and apparatus for intelligent transcoding of multimedia data |
US20020010761A1 (en) | 1997-08-06 | 2002-01-24 | Carneal Bruce L. | Distributed system and method for prefetching objects |
US6622168B1 (en) | 2000-04-10 | 2003-09-16 | Chutney Technologies, Inc. | Dynamic page generation acceleration using component-level caching |
US20040064577A1 (en) | 2002-07-25 | 2004-04-01 | Dahlin Michael D. | Method and system for background replication of data objects |
US6721780B1 (en) | 1999-11-09 | 2004-04-13 | Fireclick, Inc. | Predictive pre-download of network objects |
EP1041497B1 (en) | 1999-03-31 | 2005-01-19 | Kabushiki Kaisha Toshiba | Information fetching control scheme using data type dependent strategy for reducing user response time |
US20050193096A1 (en) | 2000-06-12 | 2005-09-01 | Yu Shun Z. | System for wireless push and pull based services |
US7113935B2 (en) | 2000-12-06 | 2006-09-26 | Epicrealm Operating Inc. | Method and system for adaptive prefetching |
US20070180019A1 (en) * | 2005-10-27 | 2007-08-02 | Woods Michael E | System, Method, and Computer Program Product for Internet Tool |
US20080091711A1 (en) | 2003-07-02 | 2008-04-17 | Snodgrass Ryan J | Predictive prefetching to improve parallelization of document generation subtasks |
US20080114773A1 (en) | 2006-11-09 | 2008-05-15 | Samsung Electronics Co., Ltd. | Apparatus and method for prefetching web page |
US20090019153A1 (en) | 2007-07-12 | 2009-01-15 | Viasat, Inc. | Methods and systems for performing a prefetch abort operation |
US20090112975A1 (en) | 2007-10-31 | 2009-04-30 | Microsoft Corporation | Pre-fetching in distributed computing environments |
US20090228782A1 (en) | 2008-03-04 | 2009-09-10 | Simon Fraser | Acceleration of rendering of web-based content |
US20090276488A1 (en) | 2008-05-05 | 2009-11-05 | Strangeloop Networks, Inc. | Extensible, Asynchronous, Centralized Analysis And Optimization Of Server Responses To Client Requests |
US7716332B1 (en) | 2001-06-20 | 2010-05-11 | At&T Intellectual Property I, L.P. | System and method for server-based predictive caching of back-end system data |
US20100125590A1 (en) * | 2008-11-18 | 2010-05-20 | Rajiv Puranik | Efficient caching for dynamic webservice queries using cachable fragments |
US20100146415A1 (en) | 2007-07-12 | 2010-06-10 | Viasat, Inc. | Dns prefetch |
WO2010081160A2 (en) | 2009-01-12 | 2010-07-15 | Viasat, Inc. | Web optimization |
US20110258532A1 (en) | 2009-03-31 | 2011-10-20 | Luis Ceze | Memoizing web-browsing computation with dom-based isomorphism |
US20110295979A1 (en) | 2010-05-28 | 2011-12-01 | Strangeloop Networks Inc. | Accelerating HTTP Responses In A Client/Server Environment |
US20120066586A1 (en) | 2010-09-07 | 2012-03-15 | Yaniv Shemesh | Systems and methods for accelerating web page loading |
US8224964B1 (en) | 2004-06-30 | 2012-07-17 | Google Inc. | System and method of accessing a document efficiently through multi-tier web caching |
US20120239598A1 (en) | 2011-03-15 | 2012-09-20 | Cascaval Gheorghe C | Machine Learning Method to Identify Independent Tasks for Parallel Layout in Web Browsers |
US8335838B2 (en) | 2009-08-26 | 2012-12-18 | Microsoft Corporation | Web page load time prediction and simulation |
US8341245B1 (en) | 2011-09-26 | 2012-12-25 | Google Inc. | Content-facilitated speculative preparation and rendering |
US20130031459A1 (en) | 2011-07-27 | 2013-01-31 | Behrooz Khorashadi | Web browsing enhanced by cloud computing |
US20130166634A1 (en) | 2011-12-23 | 2013-06-27 | Akamai Technologies Inc. | Assessment of content delivery services using performance measurements from within an end user client application |
US8478843B1 (en) | 2011-03-01 | 2013-07-02 | IMDB. COM, Inc. | Templates with static parameter caching |
US20130226992A1 (en) | 2012-02-24 | 2013-08-29 | Qualcomm Incorporated | Cooperative loading of webpages based on shared meta information |
US20130297561A1 (en) * | 2012-05-01 | 2013-11-07 | Qualcomm Iskoot, Inc | Web acceleration based on hints derived from crowd sourcing |
US9037638B1 (en) * | 2011-04-11 | 2015-05-19 | Viasat, Inc. | Assisted browsing using hinting functionality |
US20150156194A1 (en) | 2013-12-04 | 2015-06-04 | Symantec Corporation | Certificate status delivery through a local endpoint |
US20150189038A1 (en) * | 2011-12-09 | 2015-07-02 | Google Inc. | Method and apparatus for pre-fetching remote resources for subsequent display on a mobile computing device |
US9083583B1 (en) | 2011-07-01 | 2015-07-14 | Google Inc. | Latency reduction via adaptive speculative preconnection |
US9106607B1 (en) * | 2011-04-11 | 2015-08-11 | Viasat, Inc. | Browser based feedback for optimized web browsing |
US9135364B1 (en) | 2011-11-10 | 2015-09-15 | Google Inc. | Delivery of web pages with markup for speed |
US9456050B1 (en) * | 2011-04-11 | 2016-09-27 | Viasat, Inc. | Browser optimization through user history analysis |
US9460229B2 (en) | 2007-10-15 | 2016-10-04 | Viasat, Inc. | Methods and systems for implementing a cache model in a prefetching system |
US9747386B1 (en) | 2012-08-10 | 2017-08-29 | Amazon Technologies, Inc. | User-perceived performance through browser hints |
US10372780B1 (en) | 2011-04-11 | 2019-08-06 | Viasat, Inc. | Browser based feedback for optimized web browsing |
US10484473B2 (en) * | 2016-06-28 | 2019-11-19 | Solano Labs, Inc. | Systems and methods for efficient distribution of stored data objects |
US11176223B1 (en) | 2014-10-21 | 2021-11-16 | Amazon Technologies, Inc. | Page rendering by an intermediary system that uses a truncated library |
-
2017
- 2017-11-21 US US15/819,679 patent/US10880396B2/en active Active
-
2022
- 2022-12-22 US US18/086,946 patent/USRE50106E1/en active Active
Patent Citations (51)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5485609A (en) | 1994-05-20 | 1996-01-16 | Brown University Research Foundation | Online background predictors and prefetchers for locality management |
US20020010761A1 (en) | 1997-08-06 | 2002-01-24 | Carneal Bruce L. | Distributed system and method for prefetching objects |
US6301617B1 (en) * | 1997-08-25 | 2001-10-09 | Intel Corporation | Selection of resources utilizing virtual uniform resource locators |
US6085193A (en) | 1997-09-29 | 2000-07-04 | International Business Machines Corporation | Method and system for dynamically prefetching information via a server hierarchy |
US6055569A (en) | 1998-01-27 | 2000-04-25 | Go Ahead Software Inc. | Accelerating web access by predicting user action |
EP1041497B1 (en) | 1999-03-31 | 2005-01-19 | Kabushiki Kaisha Toshiba | Information fetching control scheme using data type dependent strategy for reducing user response time |
US6721780B1 (en) | 1999-11-09 | 2004-04-13 | Fireclick, Inc. | Predictive pre-download of network objects |
US20060075068A1 (en) | 1999-11-09 | 2006-04-06 | Stephane Kasriel | Predictive pre-download of a network object |
US20010047517A1 (en) | 2000-02-10 | 2001-11-29 | Charilaos Christopoulos | Method and apparatus for intelligent transcoding of multimedia data |
US6622168B1 (en) | 2000-04-10 | 2003-09-16 | Chutney Technologies, Inc. | Dynamic page generation acceleration using component-level caching |
US20050193096A1 (en) | 2000-06-12 | 2005-09-01 | Yu Shun Z. | System for wireless push and pull based services |
US7113935B2 (en) | 2000-12-06 | 2006-09-26 | Epicrealm Operating Inc. | Method and system for adaptive prefetching |
US7716332B1 (en) | 2001-06-20 | 2010-05-11 | At&T Intellectual Property I, L.P. | System and method for server-based predictive caching of back-end system data |
US20040064577A1 (en) | 2002-07-25 | 2004-04-01 | Dahlin Michael D. | Method and system for background replication of data objects |
US20080091711A1 (en) | 2003-07-02 | 2008-04-17 | Snodgrass Ryan J | Predictive prefetching to improve parallelization of document generation subtasks |
US8566788B2 (en) | 2003-07-02 | 2013-10-22 | Amazon.Com, Inc. | Predictive prefetching to improve parallelization of data retrieval subtasks |
US8136089B2 (en) | 2003-07-02 | 2012-03-13 | Amazon.Com, Inc. | Predictive prefetching to improve parallelization of document generation subtasks |
US8224964B1 (en) | 2004-06-30 | 2012-07-17 | Google Inc. | System and method of accessing a document efficiently through multi-tier web caching |
US20070180019A1 (en) * | 2005-10-27 | 2007-08-02 | Woods Michael E | System, Method, and Computer Program Product for Internet Tool |
US20080114773A1 (en) | 2006-11-09 | 2008-05-15 | Samsung Electronics Co., Ltd. | Apparatus and method for prefetching web page |
US20090019153A1 (en) | 2007-07-12 | 2009-01-15 | Viasat, Inc. | Methods and systems for performing a prefetch abort operation |
US20100146415A1 (en) | 2007-07-12 | 2010-06-10 | Viasat, Inc. | Dns prefetch |
US9460229B2 (en) | 2007-10-15 | 2016-10-04 | Viasat, Inc. | Methods and systems for implementing a cache model in a prefetching system |
US20090112975A1 (en) | 2007-10-31 | 2009-04-30 | Microsoft Corporation | Pre-fetching in distributed computing environments |
US20090228782A1 (en) | 2008-03-04 | 2009-09-10 | Simon Fraser | Acceleration of rendering of web-based content |
US20090276488A1 (en) | 2008-05-05 | 2009-11-05 | Strangeloop Networks, Inc. | Extensible, Asynchronous, Centralized Analysis And Optimization Of Server Responses To Client Requests |
US20100125590A1 (en) * | 2008-11-18 | 2010-05-20 | Rajiv Puranik | Efficient caching for dynamic webservice queries using cachable fragments |
WO2010081160A2 (en) | 2009-01-12 | 2010-07-15 | Viasat, Inc. | Web optimization |
US20110258532A1 (en) | 2009-03-31 | 2011-10-20 | Luis Ceze | Memoizing web-browsing computation with dom-based isomorphism |
US8335838B2 (en) | 2009-08-26 | 2012-12-18 | Microsoft Corporation | Web page load time prediction and simulation |
US20110295979A1 (en) | 2010-05-28 | 2011-12-01 | Strangeloop Networks Inc. | Accelerating HTTP Responses In A Client/Server Environment |
US20120066586A1 (en) | 2010-09-07 | 2012-03-15 | Yaniv Shemesh | Systems and methods for accelerating web page loading |
US8478843B1 (en) | 2011-03-01 | 2013-07-02 | IMDB. COM, Inc. | Templates with static parameter caching |
US20120239598A1 (en) | 2011-03-15 | 2012-09-20 | Cascaval Gheorghe C | Machine Learning Method to Identify Independent Tasks for Parallel Layout in Web Browsers |
US9456050B1 (en) * | 2011-04-11 | 2016-09-27 | Viasat, Inc. | Browser optimization through user history analysis |
US9106607B1 (en) * | 2011-04-11 | 2015-08-11 | Viasat, Inc. | Browser based feedback for optimized web browsing |
US11176219B1 (en) | 2011-04-11 | 2021-11-16 | Viasat, Inc. | Browser based feedback for optimized web browsing |
US10372780B1 (en) | 2011-04-11 | 2019-08-06 | Viasat, Inc. | Browser based feedback for optimized web browsing |
US9037638B1 (en) * | 2011-04-11 | 2015-05-19 | Viasat, Inc. | Assisted browsing using hinting functionality |
US9083583B1 (en) | 2011-07-01 | 2015-07-14 | Google Inc. | Latency reduction via adaptive speculative preconnection |
US20130031459A1 (en) | 2011-07-27 | 2013-01-31 | Behrooz Khorashadi | Web browsing enhanced by cloud computing |
US8341245B1 (en) | 2011-09-26 | 2012-12-25 | Google Inc. | Content-facilitated speculative preparation and rendering |
US9135364B1 (en) | 2011-11-10 | 2015-09-15 | Google Inc. | Delivery of web pages with markup for speed |
US20150189038A1 (en) * | 2011-12-09 | 2015-07-02 | Google Inc. | Method and apparatus for pre-fetching remote resources for subsequent display on a mobile computing device |
US20130166634A1 (en) | 2011-12-23 | 2013-06-27 | Akamai Technologies Inc. | Assessment of content delivery services using performance measurements from within an end user client application |
US20130226992A1 (en) | 2012-02-24 | 2013-08-29 | Qualcomm Incorporated | Cooperative loading of webpages based on shared meta information |
US20130297561A1 (en) * | 2012-05-01 | 2013-11-07 | Qualcomm Iskoot, Inc | Web acceleration based on hints derived from crowd sourcing |
US9747386B1 (en) | 2012-08-10 | 2017-08-29 | Amazon Technologies, Inc. | User-perceived performance through browser hints |
US20150156194A1 (en) | 2013-12-04 | 2015-06-04 | Symantec Corporation | Certificate status delivery through a local endpoint |
US11176223B1 (en) | 2014-10-21 | 2021-11-16 | Amazon Technologies, Inc. | Page rendering by an intermediary system that uses a truncated library |
US10484473B2 (en) * | 2016-06-28 | 2019-11-19 | Solano Labs, Inc. | Systems and methods for efficient distribution of stored data objects |
Non-Patent Citations (7)
Title |
---|
De La Ossa et al., , "Delfos: the Oracle to Predict Next Web User's Accesses", 21st International Conference on Advanced Networking and Applications (AINA '07), DOI: 0-7695-2846, May 2007, 8 pgs. |
Grigorik , et al., "Resource Hints," W3C First Public Working Draft, https://wwww3.org/TR/2014/WD-resource-hints-20141021, Oct. 21, 2014, 10 pgs. |
Grigorik , et al., "Resource Hints," W3C Working Draft, https://www.w3.org/TR/2016/WD-resource-hints-20160225, Feb. 25, 2016, 13 pgs. |
Grigorik, Ilya , "Chrome Networking: DNS Prefetch & TCP Preconnect", Jun. 4, 2012, 5pgs. |
Grigorik, Ilya , "Eliminating Roundtrips with Preconnect", https://www.igvita.com/2015/08/17/eliminating-roundtrips-with-preconnect, Aug. 17, 2015, 4 pgs. |
Grigorik, Ilya , "High Performance Networking in Google Chrome", https://www.igvita.com/posa/high-performance-networking-in-google-chrome, Jan. 31, 2013, 20 pgs. |
Souders, Steve , "Prebrowsing", https://www.stevesouders.com/blog/2013/11/07/prebrowsing, Nov. 7, 2013, 8 pgs. |
Also Published As
Publication number | Publication date |
---|---|
US10880396B2 (en) | 2020-12-29 |
US20180159948A1 (en) | 2018-06-07 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US10667101B2 (en) | Contextual deep linking of applications | |
KR101824222B1 (en) | Fast rendering of websites containing dynamic content and stale content | |
CN106489145B (en) | Access method, device and the Web site system of web site | |
US8862777B2 (en) | Systems, apparatus, and methods for mobile device detection | |
US9055124B1 (en) | Enhanced caching of network content | |
WO2020199751A1 (en) | Method and apparatus for loading page picture, and electronic device | |
US9230036B2 (en) | Enhanced browser cookie management | |
US8812737B2 (en) | Context-specific unicode characters in shortened URLs | |
US10909104B2 (en) | Caching of updated network content portions | |
US9323860B2 (en) | Enhancing client-side object caching for web based applications | |
US10735528B1 (en) | Geographic relocation of content source in a content delivery network | |
US7987243B2 (en) | Method for media discovery | |
US9088462B2 (en) | Common web accessible data store for client side page processing | |
US10178147B1 (en) | Client-side location address translation | |
US8484373B2 (en) | System and method for redirecting a request for a non-canonical web page | |
CN105930528A (en) | Webpage cache method and server | |
US9654575B1 (en) | Pass-through web traffic systems and methods | |
US20120150988A1 (en) | Provider-specific parsing for content retrieval | |
US20120166526A1 (en) | Request forwarding and result aggregating systems, methods and computer readable media | |
US9058399B2 (en) | System and method for providing network resource identifier shortening service to computing devices | |
JP2021516381A (en) | Enhanced online privacy | |
USRE50106E1 (en) | Pre-fetching random-value resource locators | |
CN110708402A (en) | Accessible resource display method and device and resource access system | |
CN111259283A (en) | Page resource preloading processing method and device, electronic device and storage device | |
US9378178B1 (en) | Enhancing HTTP caching by allowing content sharing of data blocks across resources identified by different uniform resource locators |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
FEPP | Fee payment procedure |
Free format text: ENTITY STATUS SET TO UNDISCOUNTED (ORIGINAL EVENT CODE: BIG.); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY |
|
AS | Assignment |
Owner name: BANK OF AMERICA, N.A., NORTH CAROLINA Free format text: SUPPLEMENTAL PATENT SECURITY AGREEMENT;ASSIGNOR:VIASAT, INC.;REEL/FRAME:064164/0498 Effective date: 20230628 Owner name: WILMINGTON TRUST, NATIONAL ASSOCIATION, AS COLLATERAL TRUSTEE, MINNESOTA Free format text: SUPPLEMENTAL PATENT SECURITY AGREEMENT;ASSIGNOR:VIASAT, INC.;REEL/FRAME:064176/0566 Effective date: 20230628 Owner name: BANK OF AMERICA, N.A., NORTH CAROLINA Free format text: SUPPLEMENTAL PATENT SECURITY AGREEMENT;ASSIGNOR:VIASAT, INC.;REEL/FRAME:064164/0152 Effective date: 20230628 |
|
AS | Assignment |
Owner name: VIASAT, INC., CALIFORNIA Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:LEPESKA, PETER J.;TSILLAS, DEMETRIOS J.;SIGNING DATES FROM 20171212 TO 20171213;REEL/FRAME:064362/0896 |
|
AS | Assignment |
Owner name: MUFG BANK, LTD., AS AGENT, NEW YORK Free format text: SUPPLEMENTAL PATENT SECURITY AGREEMENT;ASSIGNOR:VIASAT, INC.;REEL/FRAME:064948/0379 Effective date: 20230901 |