US20190028560A1 - Assessment of content delivery services using performance measurements from within an end user client application - Google Patents

Assessment of content delivery services using performance measurements from within an end user client application Download PDF

Info

Publication number
US20190028560A1
US20190028560A1 US16/012,445 US201816012445A US2019028560A1 US 20190028560 A1 US20190028560 A1 US 20190028560A1 US 201816012445 A US201816012445 A US 201816012445A US 2019028560 A1 US2019028560 A1 US 2019028560A1
Authority
US
United States
Prior art keywords
client
proxy server
markup language
cdn
language file
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.)
Abandoned
Application number
US16/012,445
Inventor
Mark C. Holland
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Akamai Technologies Inc
Original Assignee
Akamai Technologies Inc
Priority date (The priority date 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 date listed.)
Filing date
Publication date
Application filed by Akamai Technologies Inc filed Critical Akamai Technologies Inc
Priority to US16/012,445 priority Critical patent/US20190028560A1/en
Assigned to AKAMAI TECHNOLOGIES, INC. reassignment AKAMAI TECHNOLOGIES, INC. ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: HOLLAND, MARK C.
Publication of US20190028560A1 publication Critical patent/US20190028560A1/en
Abandoned legal-status Critical Current

Links

Images

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/50Network services
    • H04L67/56Provisioning of proxy services
    • H04L67/561Adding application-functional data or data for application control, e.g. adding metadata
    • H04L67/2804
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/30Monitoring
    • G06F11/3003Monitoring arrangements specially adapted to the computing system or computing system component being monitored
    • G06F11/3006Monitoring arrangements specially adapted to the computing system or computing system component being monitored where the computing system is distributed, e.g. networked systems, clusters, multiprocessor systems
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/30Monitoring
    • G06F11/34Recording or statistical evaluation of computer activity, e.g. of down time, of input/output operation ; Recording or statistical evaluation of user activity, e.g. usability assessment
    • G06F11/3409Recording or statistical evaluation of computer activity, e.g. of down time, of input/output operation ; Recording or statistical evaluation of user activity, e.g. usability assessment for performance assessment
    • G06F11/3419Recording or statistical evaluation of computer activity, e.g. of down time, of input/output operation ; Recording or statistical evaluation of user activity, e.g. usability assessment for performance assessment by assessing time
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/30Monitoring
    • G06F11/34Recording or statistical evaluation of computer activity, e.g. of down time, of input/output operation ; Recording or statistical evaluation of user activity, e.g. usability assessment
    • G06F11/3466Performance evaluation by tracing or monitoring
    • G06F11/3476Data logging
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/30Monitoring
    • G06F11/34Recording or statistical evaluation of computer activity, e.g. of down time, of input/output operation ; Recording or statistical evaluation of user activity, e.g. usability assessment
    • G06F11/3466Performance evaluation by tracing or monitoring
    • G06F11/3495Performance evaluation by tracing or monitoring for systems
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L41/00Arrangements for maintenance, administration or management of data switching networks, e.g. of packet switching networks
    • H04L41/14Network analysis or design
    • H04L67/22
    • H04L67/2842
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/34Network arrangements or protocols for supporting network services or applications involving the movement of software or configuration parameters 
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/50Network services
    • H04L67/535Tracking the activity of the user
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/50Network services
    • H04L67/56Provisioning of proxy services
    • H04L67/568Storing data temporarily at an intermediate stage, e.g. caching
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F2201/00Indexing scheme relating to error detection, to error correction, and to monitoring
    • G06F2201/875Monitoring of systems including the internet
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/01Protocols
    • H04L67/02Protocols based on web technology, e.g. hypertext transfer protocol [HTTP]
    • H04L67/2823
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/50Network services
    • H04L67/56Provisioning of proxy services
    • H04L67/565Conversion or adaptation of application format or content

Definitions

  • This application relates generally to distributed data processing systems and to the delivery of content to end users over computer networks, and more particularly to the measurement and assessment of content delivery services.
  • a “distributed system” of this type typically refers to a collection of autonomous computers linked by a network or networks, together with the software, systems, protocols and techniques designed to facilitate various services, such as content delivery or the support of outsourced site infrastructure.
  • content delivery refers to the storage, caching, or transmission of content—such as web pages, streaming media and applications—on behalf of content providers, and ancillary technologies used therewith including, without limitation, DNS query handling, provisioning, data monitoring and reporting, content targeting, personalization, and business intelligence.
  • a distributed computer system 100 is configured as a content delivery network (CDN) and is assumed to have a set of machines 102 distributed around the Internet.
  • CDN content delivery network
  • machines 102 typically, most of the machines are content servers located near the edge of the Internet, i.e., at or adjacent end user access networks.
  • a network operations command center (NOCC) 104 may be used to administer and manage operations of the various machines in the system.
  • Third party sites affiliated with content providers such as web site 106 , offload delivery of content (e.g., HTML, embedded page objects, streaming media, software downloads, and the like) to the distributed computer system 100 and, in particular, to the servers (which are sometimes referred to as proxy servers if running a proxy application as described below, or sometimes as “edge” servers in light of the possibility that they are near an “edge” of the Internet).
  • content e.g., HTML, embedded page objects, streaming media, software downloads, and the like
  • Such servers may be grouped together into a point of presence (POP) 107 .
  • POP point of presence
  • content providers offload their content delivery by aliasing (e.g., by a DNS CNAME) given content provider domains or sub-domains to domains that are managed by the service provider's authoritative domain name service.
  • End user client machines 122 that desire such content may be directed to the distributed computer system to obtain that content more reliably and efficiently.
  • the servers respond to the client requests, for example by obtaining requested content from a local cache, from another content server, from the origin server 106 , or other source.
  • the distributed computer system may also include other infrastructure, such as a distributed data collection system 108 that collects usage and other data from the content servers, aggregates that data across a region or set of regions, and passes that data to other back-end systems 110 , 112 , 114 and 116 to facilitate monitoring, logging, alerts, billing, management and other operational and administrative functions.
  • Distributed network agents 118 monitor the network as well as the server loads and provide network, traffic and load data to a DNS query handling mechanism 115 , which is authoritative for content domains being managed by the CDN.
  • a distributed data transport mechanism 120 may be used to distribute control information (e.g., metadata to manage content, to facilitate load balancing, and the like) to the servers.
  • a given machine 200 in the CDN (sometimes referred to as an “edge machine”) comprises commodity hardware (e.g., an Intel processor) 202 running an operating system kernel (such as Linux® or variant) 204 that supports one or more applications 206 a - n .
  • given machines typically run a set of applications, such as an HTTP proxy 207 , a name server 208 , a local monitoring process 210 , a distributed data collection process 212 , and the like.
  • the HTTP proxy 207 (sometimes referred to herein as a global host or “ghost” application) typically includes a manager process for managing a cache and delivery of content from the machine.
  • the machine typically includes one or more media servers, such as a Windows® Media Server (WMS) or Flash® 2.0 server, as required by the supported media formats.
  • WMS Windows® Media Server
  • Flash® 2.0 server as required by the supported media formats.
  • the machine 200 shown in FIG. 2 may be configured to provide one or more extended content delivery features, preferably on a domain-specific, content-provider-specific basis, preferably using configuration files that are distributed to the content servers using a configuration system.
  • a given configuration file preferably is XML-based and includes a set of content handling rules and directives that facilitate one or more advanced content handling features.
  • the configuration file may be delivered to the servers via the data transport mechanism.
  • U.S. Pat. Nos. 7,111,057 and 7,240,100 illustrate a useful infrastructure for delivering and managing CDN server content control information and this and other content server control information (sometimes referred to as “metadata”) can be provisioned by the CDN service provider itself, or (via an extranet or the like) the content provider customer who operates the origin server.
  • the CDN may include a network storage subsystem for the content providers to store and originate content (sometimes referred to herein as “NetStorage”) which may be located in a network datacenter accessible to the content servers, such as described in U.S. Pat. No. 7,472,178, the disclosure of which is incorporated herein by reference.
  • NetworkStorage for live streaming delivery, the CDN may include a live delivery subsystem, such as described in U.S. Pat. No. 7,296,082, and U.S. Publication No. 2011/0173345, the disclosures of which are incorporated herein by reference.
  • the CDN resources may be used to facilitate wide area network (WAN) acceleration services between enterprise data centers (which may be privately managed) and third party software-as-a-service (SaaS) providers.
  • WAN wide area network
  • SaaS software-as-a-service
  • a server may be configured to apply modifications to a given web page as it traverses the server (e.g., going from an origin/source to an end-user client) so as to reduce the number of requests the client has to make, to reduce the payload of the content, to accelerate client application processing/rendering, to tailor the content for a particular client device (and its capabilities), or otherwise enhance the performance and functionality of the content.
  • modifications to a given web page as it traverses the server e.g., going from an origin/source to an end-user client
  • client application processing/rendering e.g., a wide variety of such treatments are known in the art and often referred to as ‘front-end’ web optimizations or as ‘web content’ optimizations.
  • U.S. Publication No. 2011/0314091 describes systems and methods for applying performance-enhancing modifications to web pages, and teachings of this publication are hereby incorporated by reference herein.
  • a dynamic image delivery system is described in U.S. Pat. No. 8,060,581, the content of which are hereby incorporated by reference.
  • U.S. Patent Publication No. 2012/0265853 and U.S. Patent Publication No. 2012/0259942 describes systems and methods for streaming media and for executing a byte-based interpreter in a proxy server that can be used to modify content, to add rights management information and/or watermarks and the like.
  • the content of all of the foregoing patent documents are hereby incorporated by reference in their entireties.
  • the CDN may operate a cache hierarchy to provide intermediate caching of customer content; one such cache hierarchy subsystem is described in U.S. Pat. No. 7,376,716, the disclosure of which is incorporated herein by reference.
  • a transport and routing mechanism for arbitrary data flows is described in U.S. Pat. No. 7,660,296, the disclosure of which is hereby incorporated by reference.
  • a system and method for delivery of content using intermediate nodes to facilitate content delivery is described in U.S. Pat. No. 6,820,133, the content of which are hereby incorporated by reference.
  • a global hosting system that can utilize a network map is described in U.S. Pat. No. 6,108,703, the contents of which are hereby incorporated by reference.
  • the system includes an intermediary device, such as a web proxy server, that receives requests for content from clients, such as requests for a web page.
  • the intermediary device obtains the requested content, modifies it (e.g., by applying one or more performance-enhancing optimizations), and serves the modified content to the client.
  • the modifications are typically products and/or features offered by a service provider managing the intermediary device and/or a content delivery network (CDN) of which the device is a part.
  • CDN content delivery network
  • the device also inserts code into the content that will be executed by the client so as to cause the client to gather timing data reflecting how quickly the client gets and is able to process the content for the end-user, and to report that data back to a back-end processing system.
  • the code further includes information identifying the modifications that the intermediary device made. This information is included in the reported data, so that the effect of the modification(s) on performance can be analyzed.
  • the back-end processing system receives the data and processes it so that it can be viewed in a user interface (e.g., visualized in various ways to show the performance improvements associated with the performance features provided by the service provider), analyzed by CDN service provider personnel, and/or fed into mapping/configuration systems in order to tune the operation of the device and the CDN.
  • a user interface e.g., visualized in various ways to show the performance improvements associated with the performance features provided by the service provider
  • CDN service provider personnel e.g., analyzed by CDN service provider personnel, and/or fed into mapping/configuration systems in order to tune the operation of the device and the CDN.
  • the intermediary device can select one of multiple versions of content, and the inserted code can contain information identifying the selected content version, so that performance data can be correlated with content versions selected by the intermediary.
  • the intermediary device can send the content with or without modification, and the inserted code can contain information relating to or identify the intermediary device, devices from which the intermediary device obtained the content, or information about the client (e.g., characteristics of the client device, etc.), so that performance data can be correlated with these factors.
  • FIG. 1 is a schematic diagram illustrating one embodiment of a known distributed computer system configured as a content delivery network
  • FIG. 2 is a schematic diagram illustrating one embodiment of a machine on which a content server in the system of FIG. 1 can be implemented;
  • FIG. 3 is a schematic diagram illustrating one embodiment of a performance monitoring and measurement system for a CDN
  • FIG. 4 is a schematic diagram illustrating one embodiment of a user interface for a web portal for configuring and otherwise interacting with the system
  • FIG. 5 is a schematic diagram illustrating one embodiment of NavTiming page load phase breakdown, as it might appear in the portal;
  • FIG. 6 is a block diagram illustrating hardware in a computer system that may be used to implement the teachings hereof.
  • FIG. 3 illustrates, at a high-level, an embodiment of a performance measurement and monitoring system 300 which can be built as an overlay to the CDN shown in FIGS. 1-2 .
  • FIG. 3 shows an intermediary device 302 , which is preferably (though without limitation) one of the machines 102 configured as a proxy server, as shown and described above with respect to FIGS. 1-2 .
  • the client 306 in this example a web browser 306 running on an end-user machine—has made a request (e.g., an HTTP ‘Get’ request) for a particular web page to the proxy server 302 after having been mapped to that proxy server via a DNS system lookup.
  • a request e.g., an HTTP ‘Get’ request
  • the proxy server 302 obtains the page from the origin/source server 301 , or from an internally cached copy that was previously retrieved.
  • the functionality of the proxy server 302 is extended to insert measurement code 304 into the web page (e.g., an HTML file, although other content and/or markup language file formats could be used) that was obtained by the proxy server 302 and is being delivered to the client application.
  • the insertion of the code can be controlled and customized on a content provider by content provider basis (or even a page by page basis), using the metadata approach described previously.
  • the code enables and facilitates the collection of performance data from within the client application and the reporting back of this data to the CDN.
  • the CDN can then provide this information to content providers (e.g., through an extranet portal), report the information for internal use, and/or act on this information directly.
  • the insertion of code can be performed by any intermediary device, and is not limited to the example of CDN proxy servers, which are merely examples.
  • the intermediary might be another device or a software module residing in the communication path between the content origin and the client.
  • the client can be any application and is not limited to a browser 306 , though that is used herein for illustrative purposes.
  • the inserted code 304 is preferably a small, relatively fixed body of JavaScript. This code will gather timing data and cause the browser 306 to send it back to the CDN as query string arguments on an http GET request, referred to herein as a beacon.
  • the beacon is sent on a content-provider-controlled hostname; alternatively, the beacon can be sent to the hostname of the base page (the page on which the JavaScript is loaded), which will save a DNS lookup and a TCP connect in the common case.
  • a configuration (config) for how to deliver the beacon may be provided to the proxy server.
  • an alternative is to inline a script that asynchronously loads the main body of code.
  • a simple object-delivery configuration for delivering the browser-cacheable JavaScript to the end user from the proxy server is possible.
  • this will be on a provider-controlled hostname to avoid multiply caching the object at proxy server.
  • a back-end system 308 for receiving the beacons generated at the browser, producing download receipts, forwarding them to a processing engine, and inserting summary results into a database.
  • the download receipt contains the full beacon URL and client IP address. It should be appreciated that in many cases, the system can be set up so that the client 306 sends the data back to the server 302 , which then relays it to the back-end system 308 , since the server 302 may be closer to the client 306 .
  • a visualization system 310 extracts data from the database on-demand and produces charts for display to participating content providers in the service provider extranet web portal.
  • a control system 312 can be used to process the performance information and identify and address performance issues affecting the operation and performance of the CDN platform.
  • the system may identify, for example, that certain web page optimizations/treatments are causing a problem for a particular content provider or particular category of client (e.g., a client device running a particular browser). It might determine, by way of further example, that a particular set of end-user clients is receiving poor performance because certain proxy servers are functioning sub-optimally, or those proxy servers are being mapped to sub-optimal cache hierarchy parents, or those clients are being mapped sub-optimally to the proxy servers, or otherwise. Using this kind of information, new control information to address the performance issue, in the form of an updated configuration file for example, can be fed back to the proxy server 300 (or to another component of the CDN such as the mapmaker in FIG. 1 ).
  • JavaScript has some ability to gather performance data; for example, there are universally-supported hooks for millisecond-granularity timers and for registering a function that gets executed when the browser considers the page to be fully loaded (e.g., the “onload” event).
  • This allows, for example, the inserted code to grab a timestamp as the first step in the ⁇ head> section of a page, grab another when the onload event fires, and compute the difference. This does not capture network time (DNS, connect, first-byte), however, and is dependent on browser operation with regards to the firing of the onload event.
  • DNS network time
  • Browsers have varying abilities to gather more detailed data. Many different techniques are available to capture the point in time at which a page becomes “ready” for use by the end-user, and to capture estimates of network time. These techniques are generally browser-specific and known to those skilled in the art. Many of them have been incorporated into general-purpose libraries like jQuery and Boomerang.
  • an HTTP request for a page can be broken into a series of phases: Prompt for unload, Redirect, App cache, DNS, TCP, Request, Response, Processing, and onLoad.
  • a browser implementing the Navigation Timing specification makes available a timestamp (milliseconds since the epoch) at a variety of points in each phase, including the start and stop time of each phase. Notably, five distinct timestamps are made available during the “Processing” phase of the transaction: start time, the time at which the page becomes interactive to the user, the time at which the browser fires the content-loaded event, the time at which the content-loaded event completes, and the time at which the document object model (DOM) is complete in memory.
  • the specification provides more precise definitions for all these events.
  • the Resource Timing specification provides timing data for each embedded object on a page. A variety of timestamps (including start and stop times) for the phases of Redirect, App Cache, DNS, Request, Response.
  • the level of detail in the Resource Timing specification is available only when the server sending the embedded object includes a particular response header with that object. In the absence of that header, the browser makes available only the end-to-end timing for each embedded object. With a content provider's permission, however, a CDN proxy server can insert the header on any CDN-directed object on a hostname controlled by the same content provider as the base page.
  • the data available through the Navigation Timing/Resource Timing-compliant browsers may not correlate exactly to that obtained through other approaches described above. Therefore, preferably the system 300 displays results from Navigation Timing data separately from non-Navigation Timing data.
  • the inserted code (a snippet of JavaScript in the current example) supports data collection in the case where NavTiming is present in the browser and the case where it is absent.
  • the JavaScript does nothing more than to collect up the data and send it back to the service provider.
  • the JavaScript can grab a timestamp at the beginning and the end of the page and at the DOMContentLoaded event (where supported), and optionally execute an asynchronous fetch of a small test object from the edge.
  • the back-end 308 will use the timing of the test object fetch to infer the round trip time between the browser and the proxy server, as observed by the browser.
  • “asbw” Site Beacon Wrapper
  • site Beacon.js Site Beacon Wrapper
  • This code grabs a timestamp used when NavTiming is not available. This approach is used if it is infeasible to inline the main body of the data collection script.
  • this body of code can be inlined directly as the first element of the ⁇ head> section in the content provider page.
  • Sitebeacon.js supports both the NavTiming and non-NavTiming cases.
  • Support for NavTiming can be inferred by the proxy server from the User Agent header sent by the client 306 with the request.
  • the code attaches a function to the onload event. When that function executes it determines whether NavTiming is available, and if so collects a subset of the timing data.
  • the script computes DOMContentLoaded and the onload event timestamps, and then optionally fetches a small test object from the same hostname.
  • the back-end will use the elapsed time of the fetch as an estimate of the round trip time (RTT) to the proxy server.
  • RTT round trip time
  • the JavaScript sends the data to the back-end system 308 via query strings on an HTTP ‘Get’ request. It uses a detached ⁇ image> tag for this send, so no cross-domain restrictions are imposed by JavaScript.
  • the beacon payload may vary, but for illustrative purposes, an example of a base set of information to be carried is tabulated below. All the NavTiming data is expressed as the delta in milliseconds between the domainLookupStart timestamp and some other NavTiming timestamp. Absolute timestamps can be used, but are not preferred since they are based on the end-user's clock. To use absolute timestamps, though, the raw domainLookupStart time can be sent back, in addition to the other data. The NT column indicates whether or not the datum is derived from the NavTiming data, which clarifies what data would be received from non-NT browsers. All integers are signed in this implementation. The back-end 308 can discard malformed data such as strings in the integer columns or strings of excessive length.
  • the design described herein gives control over the beacon insertion rate to the content provider or the service provider.
  • the insertion rate is controlled because the beacon has the potential to impact page performance and so the content provider will likely want to restrict it to a fraction of all page loads.
  • the beaconed data has the capability of overwhelming the back-end system 308 with data; restricting the insertion rate is a way to control load on the back-end system 308 .
  • Rates can be set depending on the page being delivered, the type of client device (e.g., OS, browser, device type such as mobile) requested the page. Beacon insertion rates may also be controlled by whether or not the proxy server is applying some feature (e.g., a web content optimization) to the page.
  • Edge node-supported code is used to insert the body of asbw.js immediately after the ⁇ head> tag in the page markup language.
  • the extranet portal can have a section that configures the metadata to conditionally insert the JavaScript.
  • the portal can have a configuration page that allows the content provider to control the following:
  • Configuration might be controlled on many parameters beyond those above: cookies, A/B testing, specific browser types, geographies, and so on.
  • FIG. 4 is a wireframe of what a web-based user interface might look like in the portal.
  • the configurator might generate metadata control information that looks like the following pseudo-code:
  • the system maintains a base rate of beacon insertion and then for certain content-provider-specified categories of traffic, it increases the insertion rate so as to ensure the sample size of data for those categories is sufficiently large to be useful (e.g., high resolution, statistically significant) in performance analyses.
  • the system activates the beacon insertion function on all pages of a content provider's site, except for a set of pages that the content provider can optionally specify to be excluded. As the CDN serves pages to clients, the system maintains the beacon insertion rate within certain bounds.
  • the CDN Since the CDN is serving the pages to end-user clients, the CDN knows the historical page-request rate and the capacity of the back-end system 308 to handle the performance data that will be sent by the beacons. The CDN can use these two pieces of information set the beacon insertion rate within acceptable bounds, e.g., so that the back-end 308 is not overwhelmed.
  • the content-provider can specify that particular traffic categories of interest (e.g., certain geographies, browsers, feature sets, etc.), and the CDN can increase the beacon insertion rate for those categories.
  • a given proxy server 302 in the CDN fields client requests, it will determine whether a given request falls within a particular category (e.g., by mapping client IP address to geography, by examining the user-agent header to determine browser or other client device characteristic, or any such technique known in the art). For requests falling within the category, the proxy server 302 inserts beacons at a particular rate ‘N’. For requests falling outside the category, the proxy server 302 inserts beacons at another rate ‘M’, which would usually be lower than ‘N’.
  • the configuration that delivers sitebeacon.js to the browser is an object delivery service of the CDN service provider.
  • an infrastructure (servers, databases, software, APIs, and so forth) is used for receiving beacon data generated from end-user clients 306 .
  • the beacon data is sent from the browser by executing an http GET on a hostname private to the company collecting the data; that hostname points to the back-end 308 .
  • the configuration validates any associated authentication token and sends a download receipt to additional back-end infrastructure, where it is consumed by a processing engine that writes the data to a database.
  • the visual layout of the console might include a set of tabs via which various different graphs can be selected.
  • the interface preferably supports the metrics listed below, in one embodiment.
  • the portal user can have the option of selecting subsets of these parameters to be displayed on the same graph, and of saving that report definition for future use.
  • the infrastructure provides support for reporting and viewing the data by population group rather than globally. All of the visualizations mentioned in the above section may be available broken down along the following axes:
  • the utility of the system 300 can be extended by enabling the insertion of certain custom fields into the beacon code for reporting back with the beacon data, for use by the visualization system 310 or the mapping/control system 312 of the CDN.
  • the proxy server 302 can be configured to construct a variable indicating some information of interest, and the value could be inserted into the page with the JavaScript block in the ⁇ head> section, and subsequently collected along with the NavTiming or other data and sent to the back-end.
  • the back-end 308 would recognize it as a custom field and automatically produce visualizations computed over the data on each branch of the test.
  • the value might indicate a wide variety of information relating to the content delivery process, such as:
  • the proxy server's request processing function may expose internally what features it had applied to any given page load.
  • the server could include these variables as internal uses of the custom beacon fields feature.
  • Visualization based on these fields can be made available to network operations personnel (e.g., in the NOCC) as well as content providers on the portal.
  • the information can be used to validate the effect of features, to make recommendations about configuration of the features that the content provide has signed up for, and/or making changes to the content itself, to improve performance.
  • the system 300 can be extended beyond performance and into conversion rates.
  • the portal could allow commerce content providers to specify that certain URLs or combinations of URLs indicate that a conversion event (e.g., an online sale) occurred, and the visualization system might give feedback on conversion rates as a function of performance or as a function of certain CDN features.
  • clients, servers, and other computer devices described herein may be implemented with conventional computer systems, as modified by the teachings hereof, with the functional characteristics described above realized in special-purpose hardware, general-purpose hardware configured by software stored therein for special purposes, or a combination thereof.
  • Software may include one or several discrete programs.
  • a given function may comprise part of any given module, process, execution thread, or other such programming construct.
  • each function described above may be implemented as computer code, namely, as a set of computer instructions, executable in one or more processors to provide a special purpose machine.
  • the code may be executed using conventional apparatus—such as a processor in a computer, digital data processing device, or other computing apparatus—as modified by the teachings hereof.
  • such software may be implemented in a programming language that runs in conjunction with a proxy on a standard Intel hardware platform running an operating system such as Linux. The functionality may be built into the proxy code, or it may be executed as an adjunct to that code.
  • FIG. 6 is a block diagram that illustrates hardware in a computer system 600 upon which such software may run in order to implement embodiments of the invention.
  • the computer system 600 may be embodied in a client, server, personal computer, workstation, tablet computer, wireless device, mobile device, network device, router, hub, gateway, or other device.
  • Computer system 600 includes a processor 604 coupled to bus 601 . In some systems, multiple processor and/or processor cores may be employed. Computer system 600 further includes a main memory 610 , such as a random access memory (RAM) or other storage device, coupled to the bus 601 for storing information and instructions to be executed by processor 604 . A read only memory (ROM) 608 is coupled to the bus 601 for storing information and instructions for processor 604 . A non-volatile storage device 606 , such as a magnetic disk, solid state memory (e.g., flash memory), or optical disk, is provided and coupled to bus 601 for storing information and instructions. Other application-specific integrated circuits (ASICs), field programmable gate arrays (FPGAs) or circuitry may be included in the computer system 600 to perform functions described herein.
  • ASICs application-specific integrated circuits
  • FPGAs field programmable gate arrays
  • the system 600 may have a peripheral interface 612 communicatively couples computer system 600 to a user display 614 that displays the output of software executing on the computer system, and an input device 615 (e.g., a keyboard, mouse, trackpad, touchscreen) that communicates user input and instructions to the computer system 600 .
  • the peripheral interface 612 may include interface circuitry and logic for local buses such as Universal Serial Bus (USB) or other communication links.
  • USB Universal Serial Bus
  • Computer system 600 is coupled to a communication interface 616 that provides a link between the system bus 601 and an external communication link.
  • the communication interface 616 provides a network link 618 .
  • the communication interface 616 may represent an Ethernet or other network interface card (NIC), a wireless interface, modem, an optical interface, or other kind of input/output interface.
  • NIC network interface card
  • Network link 618 provides data communication through one or more networks to other devices. Such devices include other computer systems that are part of a local area network (LAN) 626 . Furthermore, the network link 618 provides a link, via an internet service provider (ISP) 620 , to the Internet 622 . In turn, the Internet 622 may provide a link to other computing systems such as a remote server 630 and/or a remote client 631 . Network link 618 and such networks may transmit data using packet-switched, circuit-switched, or other data-transmission approaches.
  • ISP internet service provider
  • the computer system 600 may implement the functionality described herein as a result of the processor executing code.
  • code may be read from or stored on a non-transitory computer-readable medium, such as memory 610 , ROM 608 , or storage device 606 .
  • a non-transitory computer-readable medium such as memory 610 , ROM 608 , or storage device 606 .
  • Other forms of non-transitory computer-readable media include disks, tapes, magnetic media, CD-ROMs, optical media, RAM, PROM, EPROM, and EEPROM. Any other non-transitory computer-readable medium may be employed.
  • Executing code may also be read from network link 618 (e.g., following storage in an interface buffer, local memory, or other circuitry).

Abstract

A system for measuring and monitoring performance of online content is provided. In one embodiment, the system includes an intermediary device, such as a web proxy, that receives client requests for content, such as requests for web pages. The device obtains the requested content, modifies it by applying one or more performance optimizations, and serves it to the client. The device also inserts code into the content for execution by the client to gather and report data reflecting, e.g., how quickly the client is able to get and process the content. The code includes information identifying the modifications the device made, and this is reported with the timing data, so that the effect on performance can be analyzed. In other embodiments, the device selects one of multiple versions of content, and the inserted code contains information identifying the selected version. The foregoing are merely examples; other embodiments are described herein.

Description

    CROSS-REFERENCE TO RELATED APPLICATIONS
  • This application is a continuation of U.S. application Ser. No. 15/645,706, filed Jul. 10, 2017, which is a continuation of U.S. application Ser. No. 15/261,026, filed on Sep. 9, 2016, which is a continuation of U.S. application Ser. No. 13/720,636, filed Dec. 19, 2012, which claims the benefit of priority of U.S. Provisional Application No. 61/579,674, filed Dec. 23, 2011. The teachings of all of the foregoing applications are hereby incorporated by reference in their entireties.
  • This patent document contains material that is subject to copyright protection. The copyright owner has no objection to the facsimile reproduction by anyone of this patent document, as it appears in Patent and Trademark Office file or records, but otherwise reserves all copyright rights whatsoever.
  • BACKGROUND Technical Field
  • This application relates generally to distributed data processing systems and to the delivery of content to end users over computer networks, and more particularly to the measurement and assessment of content delivery services.
  • Brief Description of the Related Art
  • Distributed computer systems are well-known in the prior art. One such distributed computer system is a “content delivery network” or “CDN” that is operated and managed by a service provider. The service provider typically provides the content delivery service on behalf of third parties. A “distributed system” of this type typically refers to a collection of autonomous computers linked by a network or networks, together with the software, systems, protocols and techniques designed to facilitate various services, such as content delivery or the support of outsourced site infrastructure. Typically, “content delivery” refers to the storage, caching, or transmission of content—such as web pages, streaming media and applications—on behalf of content providers, and ancillary technologies used therewith including, without limitation, DNS query handling, provisioning, data monitoring and reporting, content targeting, personalization, and business intelligence.
  • In a known system such as that shown in FIG. 1, a distributed computer system 100 is configured as a content delivery network (CDN) and is assumed to have a set of machines 102 distributed around the Internet. Typically, most of the machines are content servers located near the edge of the Internet, i.e., at or adjacent end user access networks. A network operations command center (NOCC) 104 may be used to administer and manage operations of the various machines in the system. Third party sites affiliated with content providers, such as web site 106, offload delivery of content (e.g., HTML, embedded page objects, streaming media, software downloads, and the like) to the distributed computer system 100 and, in particular, to the servers (which are sometimes referred to as proxy servers if running a proxy application as described below, or sometimes as “edge” servers in light of the possibility that they are near an “edge” of the Internet). Such servers may be grouped together into a point of presence (POP) 107.
  • Typically, content providers offload their content delivery by aliasing (e.g., by a DNS CNAME) given content provider domains or sub-domains to domains that are managed by the service provider's authoritative domain name service. End user client machines 122 that desire such content may be directed to the distributed computer system to obtain that content more reliably and efficiently. The servers respond to the client requests, for example by obtaining requested content from a local cache, from another content server, from the origin server 106, or other source.
  • Although not shown in detail in FIG. 1, the distributed computer system may also include other infrastructure, such as a distributed data collection system 108 that collects usage and other data from the content servers, aggregates that data across a region or set of regions, and passes that data to other back- end systems 110, 112, 114 and 116 to facilitate monitoring, logging, alerts, billing, management and other operational and administrative functions. Distributed network agents 118 monitor the network as well as the server loads and provide network, traffic and load data to a DNS query handling mechanism 115, which is authoritative for content domains being managed by the CDN. A distributed data transport mechanism 120 may be used to distribute control information (e.g., metadata to manage content, to facilitate load balancing, and the like) to the servers.
  • As illustrated in FIG. 2, a given machine 200 in the CDN (sometimes referred to as an “edge machine”) comprises commodity hardware (e.g., an Intel processor) 202 running an operating system kernel (such as Linux® or variant) 204 that supports one or more applications 206 a-n. To facilitate content delivery services, for example, given machines typically run a set of applications, such as an HTTP proxy 207, a name server 208, a local monitoring process 210, a distributed data collection process 212, and the like. The HTTP proxy 207 (sometimes referred to herein as a global host or “ghost” application) typically includes a manager process for managing a cache and delivery of content from the machine. For streaming media, the machine typically includes one or more media servers, such as a Windows® Media Server (WMS) or Flash® 2.0 server, as required by the supported media formats.
  • The machine 200 shown in FIG. 2 may be configured to provide one or more extended content delivery features, preferably on a domain-specific, content-provider-specific basis, preferably using configuration files that are distributed to the content servers using a configuration system. A given configuration file preferably is XML-based and includes a set of content handling rules and directives that facilitate one or more advanced content handling features. The configuration file may be delivered to the servers via the data transport mechanism. U.S. Pat. Nos. 7,111,057 and 7,240,100 illustrate a useful infrastructure for delivering and managing CDN server content control information and this and other content server control information (sometimes referred to as “metadata”) can be provisioned by the CDN service provider itself, or (via an extranet or the like) the content provider customer who operates the origin server.
  • The CDN may include a network storage subsystem for the content providers to store and originate content (sometimes referred to herein as “NetStorage”) which may be located in a network datacenter accessible to the content servers, such as described in U.S. Pat. No. 7,472,178, the disclosure of which is incorporated herein by reference. For live streaming delivery, the CDN may include a live delivery subsystem, such as described in U.S. Pat. No. 7,296,082, and U.S. Publication No. 2011/0173345, the disclosures of which are incorporated herein by reference.
  • As an overlay, the CDN resources may be used to facilitate wide area network (WAN) acceleration services between enterprise data centers (which may be privately managed) and third party software-as-a-service (SaaS) providers.
  • Given the ability to configure the CDN servers described above, a wide variety of content delivery features may be implemented in the CDN platform generally and by the CDN servers specifically. For example, a server may be configured to apply modifications to a given web page as it traverses the server (e.g., going from an origin/source to an end-user client) so as to reduce the number of requests the client has to make, to reduce the payload of the content, to accelerate client application processing/rendering, to tailor the content for a particular client device (and its capabilities), or otherwise enhance the performance and functionality of the content. A wide variety of such treatments are known in the art and often referred to as ‘front-end’ web optimizations or as ‘web content’ optimizations.
  • By way of example, U.S. Publication No. 2011/0314091 describes systems and methods for applying performance-enhancing modifications to web pages, and teachings of this publication are hereby incorporated by reference herein. A dynamic image delivery system is described in U.S. Pat. No. 8,060,581, the content of which are hereby incorporated by reference. U.S. Patent Publication No. 2012/0265853 and U.S. Patent Publication No. 2012/0259942 describes systems and methods for streaming media and for executing a byte-based interpreter in a proxy server that can be used to modify content, to add rights management information and/or watermarks and the like. The content of all of the foregoing patent documents are hereby incorporated by reference in their entireties.
  • Other performance-enhancing aspects of the CDN platform relate to the ability to intelligently map end-user clients to servers, and to the ability to intelligently route and manage the transmission of content across the network. For example, the CDN may operate a cache hierarchy to provide intermediate caching of customer content; one such cache hierarchy subsystem is described in U.S. Pat. No. 7,376,716, the disclosure of which is incorporated herein by reference. A transport and routing mechanism for arbitrary data flows is described in U.S. Pat. No. 7,660,296, the disclosure of which is hereby incorporated by reference. A system and method for delivery of content using intermediate nodes to facilitate content delivery is described in U.S. Pat. No. 6,820,133, the content of which are hereby incorporated by reference. A global hosting system that can utilize a network map is described in U.S. Pat. No. 6,108,703, the contents of which are hereby incorporated by reference.
  • There are many ways to measure the performance of web pages (and of a CDN) in a general sense, be it using synthetic monitoring or so-called real-user monitoring from within a browser. However, current performance measurement approaches are limited. It would be desirable to be able to better show the value of individual features or enhancements offered by a CDN on page performance. Furthermore, it is desirable to improve the ability to identify and address performance issues that may be affecting particular features or particular aspects of the CDN platform, or particular kinds of end-user clients (particular browsers or other client applications or particular devices) served by the CDN, or particular combinations of the foregoing. The teachings herein address such needs and offers and other benefits and advantages that will become clear in view of this disclosure.
  • BRIEF SUMMARY
  • This disclosure describes, among other things, a performance monitoring and measurement system which may be implemented within a CDN. In one embodiment, the system includes an intermediary device, such as a web proxy server, that receives requests for content from clients, such as requests for a web page. The intermediary device obtains the requested content, modifies it (e.g., by applying one or more performance-enhancing optimizations), and serves the modified content to the client. Though not limiting, the modifications are typically products and/or features offered by a service provider managing the intermediary device and/or a content delivery network (CDN) of which the device is a part. Continuing the example, the device also inserts code into the content that will be executed by the client so as to cause the client to gather timing data reflecting how quickly the client gets and is able to process the content for the end-user, and to report that data back to a back-end processing system. The code further includes information identifying the modifications that the intermediary device made. This information is included in the reported data, so that the effect of the modification(s) on performance can be analyzed. The back-end processing system receives the data and processes it so that it can be viewed in a user interface (e.g., visualized in various ways to show the performance improvements associated with the performance features provided by the service provider), analyzed by CDN service provider personnel, and/or fed into mapping/configuration systems in order to tune the operation of the device and the CDN.
  • In other embodiments, rather than making modifications to the content, the intermediary device can select one of multiple versions of content, and the inserted code can contain information identifying the selected content version, so that performance data can be correlated with content versions selected by the intermediary. In other embodiments, the intermediary device can send the content with or without modification, and the inserted code can contain information relating to or identify the intermediary device, devices from which the intermediary device obtained the content, or information about the client (e.g., characteristics of the client device, etc.), so that performance data can be correlated with these factors.
  • As those skilled in the art will recognize, the foregoing merely refers to examples provided for purposes of overview and introduction. They do not represent all possible variants or embodiments. Other embodiments are described below. The foregoing is not limiting, and the teachings hereof may be realized in a variety of systems, methods, apparatus, and non-transitory computer-readable media. The appended claims define the subject matter for which protection is sought. It should also be noted that the allocation of functions to particular machines is not limiting, as the functions recited herein may be combined or allocated amongst different machines in a variety of ways.
  • BRIEF DESCRIPTION OF THE DRAWINGS
  • The disclosure will be more fully understood from the following detailed description taken in conjunction with the accompanying drawings, in which:
  • FIG. 1 is a schematic diagram illustrating one embodiment of a known distributed computer system configured as a content delivery network;
  • FIG. 2 is a schematic diagram illustrating one embodiment of a machine on which a content server in the system of FIG. 1 can be implemented;
  • FIG. 3 is a schematic diagram illustrating one embodiment of a performance monitoring and measurement system for a CDN;
  • FIG. 4 is a schematic diagram illustrating one embodiment of a user interface for a web portal for configuring and otherwise interacting with the system;
  • FIG. 5 is a schematic diagram illustrating one embodiment of NavTiming page load phase breakdown, as it might appear in the portal;
  • FIG. 6 is a block diagram illustrating hardware in a computer system that may be used to implement the teachings hereof.
  • DETAILED DESCRIPTION OF EMBODIMENTS
  • The following description sets forth embodiments of the invention to provide an overall understanding of the principles of the structure, function, manufacture, and use of the subject matter disclosed herein. The systems, methods and apparatus described herein and illustrated in the accompanying drawings are non-limiting examples; the scope of the invention is defined solely by the claims. The features described or illustrated in connection with one exemplary embodiment may be combined with the features of other embodiments. Such modifications and variations are intended to be included within the scope of the present invention. All patents, publications and references cited herein are expressly incorporated herein by reference in their entirety.
  • 1.0 Performance Measurement and Monitoring System
  • FIG. 3 illustrates, at a high-level, an embodiment of a performance measurement and monitoring system 300 which can be built as an overlay to the CDN shown in FIGS. 1-2. FIG. 3 shows an intermediary device 302, which is preferably (though without limitation) one of the machines 102 configured as a proxy server, as shown and described above with respect to FIGS. 1-2. Assume that the client 306—in this example a web browser 306 running on an end-user machine—has made a request (e.g., an HTTP ‘Get’ request) for a particular web page to the proxy server 302 after having been mapped to that proxy server via a DNS system lookup. The proxy server 302 obtains the page from the origin/source server 301, or from an internally cached copy that was previously retrieved. In the illustrated embodiment, the functionality of the proxy server 302 is extended to insert measurement code 304 into the web page (e.g., an HTML file, although other content and/or markup language file formats could be used) that was obtained by the proxy server 302 and is being delivered to the client application. The insertion of the code can be controlled and customized on a content provider by content provider basis (or even a page by page basis), using the metadata approach described previously. The code enables and facilitates the collection of performance data from within the client application and the reporting back of this data to the CDN. The CDN can then provide this information to content providers (e.g., through an extranet portal), report the information for internal use, and/or act on this information directly.
  • It should be noted that the insertion of code can be performed by any intermediary device, and is not limited to the example of CDN proxy servers, which are merely examples. The intermediary might be another device or a software module residing in the communication path between the content origin and the client. Moreover, the client can be any application and is not limited to a browser 306, though that is used herein for illustrative purposes.
  • In this embodiment, the inserted code 304 is preferably a small, relatively fixed body of JavaScript. This code will gather timing data and cause the browser 306 to send it back to the CDN as query string arguments on an http GET request, referred to herein as a beacon. In one embodiment the beacon is sent on a content-provider-controlled hostname; alternatively, the beacon can be sent to the hostname of the base page (the page on which the JavaScript is loaded), which will save a DNS lookup and a TCP connect in the common case.
  • As mentioned previously, a configuration (config) for how to deliver the beacon may be provided to the proxy server. In many cases, it is desirable to inline all the necessary JavaScript in the base page. However, if the base page grows too large, an alternative is to inline a script that asynchronously loads the main body of code. In this case a simple object-delivery configuration for delivering the browser-cacheable JavaScript to the end user from the proxy server is possible. Preferably, this will be on a provider-controlled hostname to avoid multiply caching the object at proxy server.
  • As shown in FIG. 3, there is also provided a back-end system 308 for receiving the beacons generated at the browser, producing download receipts, forwarding them to a processing engine, and inserting summary results into a database. Preferably, the download receipt contains the full beacon URL and client IP address. It should be appreciated that in many cases, the system can be set up so that the client 306 sends the data back to the server 302, which then relays it to the back-end system 308, since the server 302 may be closer to the client 306.
  • A visualization system 310 extracts data from the database on-demand and produces charts for display to participating content providers in the service provider extranet web portal.
  • A control system 312 can be used to process the performance information and identify and address performance issues affecting the operation and performance of the CDN platform. The system may identify, for example, that certain web page optimizations/treatments are causing a problem for a particular content provider or particular category of client (e.g., a client device running a particular browser). It might determine, by way of further example, that a particular set of end-user clients is receiving poor performance because certain proxy servers are functioning sub-optimally, or those proxy servers are being mapped to sub-optimal cache hierarchy parents, or those clients are being mapped sub-optimally to the proxy servers, or otherwise. Using this kind of information, new control information to address the performance issue, in the form of an updated configuration file for example, can be fed back to the proxy server 300 (or to another component of the CDN such as the mapmaker in FIG. 1).
  • 2.0 Gathering Performance Data from Browsers
  • There are several ways for the inserted code 304 to access and collect performance data from the browser 306. JavaScript has some ability to gather performance data; for example, there are universally-supported hooks for millisecond-granularity timers and for registering a function that gets executed when the browser considers the page to be fully loaded (e.g., the “onload” event). This allows, for example, the inserted code to grab a timestamp as the first step in the <head> section of a page, grab another when the onload event fires, and compute the difference. This does not capture network time (DNS, connect, first-byte), however, and is dependent on browser operation with regards to the firing of the onload event.
  • Browsers have varying abilities to gather more detailed data. Many different techniques are available to capture the point in time at which a page becomes “ready” for use by the end-user, and to capture estimates of network time. These techniques are generally browser-specific and known to those skilled in the art. Many of them have been incorporated into general-purpose libraries like jQuery and Boomerang.
  • Browsers that are compliant with W3C Navigation Timing (referred to herein as “NavTiming”) or Resource Timing (referred to herein as “ResTiming”) specifications offer another option for gathering performance data. These specifications describe a framework via which a browser can directly export page timing data. These specifications specify a framework via which a browser can export timing data about the base page and about embedded objects. As those skilled in the art will appreciate, more information about the specifications can be found at the W3C website.
  • From the browser's point of view, an HTTP request for a page can be broken into a series of phases: Prompt for unload, Redirect, App cache, DNS, TCP, Request, Response, Processing, and onLoad. A browser implementing the Navigation Timing specification makes available a timestamp (milliseconds since the epoch) at a variety of points in each phase, including the start and stop time of each phase. Notably, five distinct timestamps are made available during the “Processing” phase of the transaction: start time, the time at which the page becomes interactive to the user, the time at which the browser fires the content-loaded event, the time at which the content-loaded event completes, and the time at which the document object model (DOM) is complete in memory. The specification provides more precise definitions for all these events.
  • The Resource Timing specification provides timing data for each embedded object on a page. A variety of timestamps (including start and stop times) for the phases of Redirect, App Cache, DNS, Request, Response. The level of detail in the Resource Timing specification is available only when the server sending the embedded object includes a particular response header with that object. In the absence of that header, the browser makes available only the end-to-end timing for each embedded object. With a content provider's permission, however, a CDN proxy server can insert the header on any CDN-directed object on a hostname controlled by the same content provider as the base page.
  • The data available through the Navigation Timing/Resource Timing-compliant browsers may not correlate exactly to that obtained through other approaches described above. Therefore, preferably the system 300 displays results from Navigation Timing data separately from non-Navigation Timing data.
  • 3.0 Implementation
  • This section describes example implementations of the system components.
  • 3.1 Beacon
  • The inserted code (a snippet of JavaScript in the current example) supports data collection in the case where NavTiming is present in the browser and the case where it is absent. In the former case the JavaScript does nothing more than to collect up the data and send it back to the service provider. In the latter, the JavaScript can grab a timestamp at the beginning and the end of the page and at the DOMContentLoaded event (where supported), and optionally execute an asynchronous fetch of a small test object from the edge. The back-end 308 will use the timing of the test object fetch to infer the round trip time between the browser and the proxy server, as observed by the browser.
  • 3.1.1 Wrapper
  • “asbw” (Site Beacon Wrapper) is several lines of code whose function is to download the main body of the JavaScript (sitebeacon.js) in a way that minimizes performance impact on the content provider page. It does this by creating a new script element and adding it to the DOM, which allows the script to be fetched in parallel with other page activity. This code also grabs a timestamp used when NavTiming is not available. This approach is used if it is infeasible to inline the main body of the data collection script.
  • If used, this body of code can be inlined directly as the first element of the <head> section in the content provider page.
  • 3.1.2 Site Beacon
  • Sitebeacon.js supports both the NavTiming and non-NavTiming cases. Support for NavTiming can be inferred by the proxy server from the User Agent header sent by the client 306 with the request. There may be one script for NavTiming and one for Non-NavTiming browsers. The code attaches a function to the onload event. When that function executes it determines whether NavTiming is available, and if so collects a subset of the timing data. When NavTiming is not available the script computes DOMContentLoaded and the onload event timestamps, and then optionally fetches a small test object from the same hostname. The back-end will use the elapsed time of the fetch as an estimate of the round trip time (RTT) to the proxy server. In either case, the JavaScript sends the data to the back-end system 308 via query strings on an HTTP ‘Get’ request. It uses a detached <image> tag for this send, so no cross-domain restrictions are imposed by JavaScript.
  • 3.1.3 Beacon Data
  • The beacon payload may vary, but for illustrative purposes, an example of a base set of information to be carried is tabulated below. All the NavTiming data is expressed as the delta in milliseconds between the domainLookupStart timestamp and some other NavTiming timestamp. Absolute timestamps can be used, but are not preferred since they are based on the end-user's clock. To use absolute timestamps, though, the raw domainLookupStart time can be sent back, in addition to the other data. The NT column indicates whether or not the datum is derived from the NavTiming data, which clarifies what data would be received from non-NT browsers. All integers are signed in this implementation. The back-end 308 can discard malformed data such as strings in the integer columns or strings of excessive length.
  • FIELD TYPE EXPRESSION NT MEANING
    dnsE Int domainLookupEnd-domainLookupStart Y DNS lookup time
    conS Int connectStart-domainLookupStart Y Connect start time
    sslS Int secureConnectionStart- Y SSL start, blank for http
    domainLookupStart
    conE Int connectEnd-domainLookupStart Y Connect end time
    reqS Int requestStart-domainLookupStart Y Request start time
    respS Int responseStart-domainLookupStart Y Response start time
    respE Int responseEnd-domainLookupStart Y Response end time
    domL Int domLoading-domainLookupStart Y DOM Loading time
    domI Int domInteractive-domainLookupStart Y DOM Interactive time
    domCLS Int domContentLoadedEventStart- Y DOM CL event start
    domainLookupStart
    domCLE Int domContentLoadedEventEnd- Y DOM CL event complete
    domainLookupStart
    domC Int domComplete-domainLookupStart Y DOM Complete time
    leS Int loadEventStart-domainLookupStart Y Onload event start time
    leE Int loadEventEnd-domainLookupStart Y Onload event done time
    dclE Int Measured DOMContentLoaded - head N Time to DOMContentLoaded
    start event7 as measured by js
    plt Int Measured onload start - head start N Page Load Time as measured by
    js
    testo Int Measured testobj end - testobj start N Test object fetch time
    plat String navigator.platform N Platform string from BOM
    ua String navigator.userAgent N User Agent string from BOM
    uri String location.href N Full URI of base page
    hs Int Constant set by metadata N HTTP Status code for base page
    ver String Constant set by metadata N Beacon version number
  • 3.2 Beacon Rate Control
  • The design described herein gives control over the beacon insertion rate to the content provider or the service provider. The insertion rate is controlled because the beacon has the potential to impact page performance and so the content provider will likely want to restrict it to a fraction of all page loads. Further, the beaconed data has the capability of overwhelming the back-end system 308 with data; restricting the insertion rate is a way to control load on the back-end system 308.
  • Rates can be set depending on the page being delivered, the type of client device (e.g., OS, browser, device type such as mobile) requested the page. Beacon insertion rates may also be controlled by whether or not the proxy server is applying some feature (e.g., a web content optimization) to the page.
  • 3.3 Configuration and Insertion of the Code
  • Edge node-supported code is used to insert the body of asbw.js immediately after the <head> tag in the page markup language.
  • The extranet portal can have a section that configures the metadata to conditionally insert the JavaScript. The portal can have a configuration page that allows the content provider to control the following:
      • A method for selecting pages into which the beacon should be inserted. It can support controls by filename, path, and extension.
      • For each such URL/path/extension, three distinct rate controls: NavTiming-enabled browsers, other Browsers, and mobile devices. For each of these the content provider can specify the percentage of all page views that should receive the JavaScript.
      • When the rate control for non-NavTiming data is nonzero, the content provider can optionally specify a test object to be fetched from JavaScript asynchronously to the page load, for purposes of estimating the round trip time (RTT). If none is specified, none will be fetched and no RTT data will be available. When an object is specified the portal will add metadata that configures this object to return an empty body via a construct-response with status code 200. This avoids data pollution in the case when the test-object fetch takes a cache miss. The portal can suggest a test object name by pre-filling the form field with a file that is unlikely to conflict with any actual object, such as http://<hostname>/CDN_test_object_for_rum.txt.
  • Configuration might be controlled on many parameters beyond those above: cookies, A/B testing, specific browser types, geographies, and so on.
  • For illustration (only), FIG. 4 is a wireframe of what a web-based user interface might look like in the portal.
  • From this (and again only for illustration), the configurator might generate metadata control information that looks like the following pseudo-code:
  • <match file type is html>
    <match response status is 2xx>
    <set-variable RATE=0>
    <match path matches lowest-numbered-path>
    <match:devicecharacteristic NavTiming result=”false”> <set-variable
    RATE=X> </match>
    <match:devicecharacteristic NavTiming result=”true”> <set-variable
    RATE=Y> </match>
    <match:devicecharacteristic MobileDevice> <set-variable
    RATE=Z> </match>
    </match>
    [ Repeat the above block for each configured path, in order ]
    <match random( ) less-than RATE>
    <edgecomputing:akamaizer.tag-filter>
    <rule>#(&lt;head&gt;)# [ body of js to insert ] #</rule>
    </edgecomputing:akamaizer.tag-filter>
    </match>
    </match>
    </match>
  • In a preferred embodiment, the system maintains a base rate of beacon insertion and then for certain content-provider-specified categories of traffic, it increases the insertion rate so as to ensure the sample size of data for those categories is sufficiently large to be useful (e.g., high resolution, statistically significant) in performance analyses. To accomplish this, in one embodiment the system activates the beacon insertion function on all pages of a content provider's site, except for a set of pages that the content provider can optionally specify to be excluded. As the CDN serves pages to clients, the system maintains the beacon insertion rate within certain bounds. Since the CDN is serving the pages to end-user clients, the CDN knows the historical page-request rate and the capacity of the back-end system 308 to handle the performance data that will be sent by the beacons. The CDN can use these two pieces of information set the beacon insertion rate within acceptable bounds, e.g., so that the back-end 308 is not overwhelmed. Through the portal, the content-provider can specify that particular traffic categories of interest (e.g., certain geographies, browsers, feature sets, etc.), and the CDN can increase the beacon insertion rate for those categories. For example, as a given proxy server 302 in the CDN fields client requests, it will determine whether a given request falls within a particular category (e.g., by mapping client IP address to geography, by examining the user-agent header to determine browser or other client device characteristic, or any such technique known in the art). For requests falling within the category, the proxy server 302 inserts beacons at a particular rate ‘N’. For requests falling outside the category, the proxy server 302 inserts beacons at another rate ‘M’, which would usually be lower than ‘N’.
  • 3.4 Delivery of sitebeacon.js
  • The configuration that delivers sitebeacon.js to the browser is an object delivery service of the CDN service provider.
  • 3.5 Back-End
  • In the current embodiment, an infrastructure (servers, databases, software, APIs, and so forth) is used for receiving beacon data generated from end-user clients 306. The beacon data is sent from the browser by executing an http GET on a hostname private to the company collecting the data; that hostname points to the back-end 308. The configuration validates any associated authentication token and sends a download receipt to additional back-end infrastructure, where it is consumed by a processing engine that writes the data to a database.
  • 3.6 Visualization
  • Recall the wireframe diagram of the configuration page shown in FIG. 4. Clicking on one of the paths can take the end-user to the visualization console for that path.
  • The visual layout of the console might include a set of tabs via which various different graphs can be selected. The interface preferably supports the metrics listed below, in one embodiment. In each case, the portal user can have the option of selecting subsets of these parameters to be displayed on the same graph, and of saving that report definition for future use.
      • NavTiming average page-ready timing data: A graph giving average values for page-ready timing metrics that the customer might be interested in. These will be line graphs with time on the X axis. Some parameters of interest are:
      • End-to-end time: defined as loadEventEnd—domainLookupStart
      • Onload event time: loadEventStart—domainLookupStart
      • DOM complete time: domContentLoadedEventStart—domainLookupStart
      • Page interactive time: domInteractive—domainLookupStart
      • Download compete time: responseEnd—domainLookupStart
      • NavTiming 90th percentile page-ready timing data: the same graph as above, calculating the 90th percentile values of the metrics rather than the averages.
      • Non-NavTiming average page-ready timing data: A graph with time on the X axis and three lines:
      • Onload event time: elapsed time from the first execution of inlined JavaScript to the onload event
      • DOMContentLoaded time: elapsed time from the first execution of inlined
      • JavaScript to the DOMContentLoaded event, if any such data exists
      • Estimated round trip time from client to edge proxy: elapsed time to fetch the test object, if any such object has been configured
      • Non-NavTiming 90th percentile page-ready timing data: the same graph as above, calculating 90th percentile values of the metrics rather than averages.
      • Sample counts: a count of the number of samples that went into the plots being displayed, for both NavTiming and non-NavTiming plots, as specified by the current filter.
      • NavTiming page load phase breakdown: a graphic showing the average values for the components of the HTML transfer, as shown in FIG. 5.
  • The infrastructure provides support for reporting and viewing the data by population group rather than globally. All of the visualizations mentioned in the above section may be available broken down along the following axes:
      • Country-level geography, and/or state- or metro-area-level.
      • Connection speed category
      • Connection type (e.g. cable, DSL, mobile)
      • Platform (e.g. iPhone, Android, Windows, Linux_x64) as returned in the platform field of the beacon data.
      • Browser+version (e.g., IE9), or just browser (e.g., IE), or if neither of those is possible, User Agent.
  • Each of these can be selected independently of the others, making all combinations possible.
  • 4.0 Custom Beacon Fields
  • The utility of the system 300 can be extended by enabling the insertion of certain custom fields into the beacon code for reporting back with the beacon data, for use by the visualization system 310 or the mapping/control system 312 of the CDN. For example, the proxy server 302 can be configured to construct a variable indicating some information of interest, and the value could be inserted into the page with the JavaScript block in the <head> section, and subsequently collected along with the NavTiming or other data and sent to the back-end. The back-end 308 would recognize it as a custom field and automatically produce visualizations computed over the data on each branch of the test. The value might indicate a wide variety of information relating to the content delivery process, such as:
      • What web content optimizations the proxy server 302 applied to the page. As previously described (and as noted in U.S. Publication No. 2011/0314091), a wide variety of performance-enhancing modifications can be automatically applied to a page (or other content). Specific examples of such treatments include in-lining content, resource consolidation, minification, image optimization, domain sharding, version control for cacheability, just-in-time loading, adjusting the time at which page scripts are run, device-adaption modifications, and so on. Other treatments might involve compression and/or de-duplification of content. The proxy server can embed identifiers in the beacon to indicate what content optimization treatments it applied to the page, or more generally, what features of the server and CDN (e.g., possibly corresponding to products offered by the CDN) were engaged when processing the page. The resulting data can be interpreted and visualized to indicate the effect of particular optimizations/features and combinations thereof on each page of a content provider.
      • What version of a page was selected and delivered by the proxy server 302. Thus the variable could indicate whether an A or B side of a test was executed at any given page load.
      • Information relating to the proxy server 302, the CDN platform, and/or delivery circumstances. For example, the information can include an identifier for the given proxy server, or for the CDN region or point-of-presence of the CDN within which the proxy server resides. Further, information about where the proxy server 302 fetched the page (e.g., from local cache, from a particular cache-hierarchy parent or PoP, from NetStorage, or from a content-provider-managed-origin server, etc.) Note that this information might also reflect where the proxy server 302 has or will fetch embedded objects on the page, and thus be useful in assessing performance related to the delivery of embedded objects. The information might also identify which intermediate nodes within the CDN are being used for routing content (the page or the embedded objects) to the proxy server for delivery to the client. The resulting data can be interpreted and visualized to indicate whether certain servers or clusters or network functions are presenting performance issues. The data can also be sliced to focus on particular clients or categories of clients (e.g., certain browsers, mobile devices, etc.).
      • Information relating to the client and/or determined from the client's request. In addition to client IP address and other client identifiers, information derived from client request headers can be included in the beacon. Examples include a determination of geography based on client IP address, and a determination of client device identity or characteristics based on, e.g., the user agent. In the latter case, the proxy server can run an edge device identification module that ingests the user agent given by the client with its initial request for content, and based thereon returns a client device identifier (i.e., which may be an identifier internal to the CDN) and/or characteristics of the device like operating system, physical dimensions, etc. The resulting performance data can be interpreted and visualized to indicate the performance (or lack thereof) for certain clients or categories thereof.
  • To enable the insertion of custom values, the proxy server's request processing function may expose internally what features it had applied to any given page load. The server could include these variables as internal uses of the custom beacon fields feature.
  • Visualization based on these fields can be made available to network operations personnel (e.g., in the NOCC) as well as content providers on the portal. The information can be used to validate the effect of features, to make recommendations about configuration of the features that the content provide has signed up for, and/or making changes to the content itself, to improve performance.
  • 5.0 Conversion Rate Tracking
  • In a further embodiment, the system 300 can be extended beyond performance and into conversion rates. The portal could allow commerce content providers to specify that certain URLs or combinations of URLs indicate that a conversion event (e.g., an online sale) occurred, and the visualization system might give feedback on conversion rates as a function of performance or as a function of certain CDN features.
  • 6.0 Use of Computer Technologies
  • The clients, servers, and other computer devices described herein may be implemented with conventional computer systems, as modified by the teachings hereof, with the functional characteristics described above realized in special-purpose hardware, general-purpose hardware configured by software stored therein for special purposes, or a combination thereof.
  • Software may include one or several discrete programs. A given function may comprise part of any given module, process, execution thread, or other such programming construct. Generalizing, each function described above may be implemented as computer code, namely, as a set of computer instructions, executable in one or more processors to provide a special purpose machine. The code may be executed using conventional apparatus—such as a processor in a computer, digital data processing device, or other computing apparatus—as modified by the teachings hereof. In one embodiment, such software may be implemented in a programming language that runs in conjunction with a proxy on a standard Intel hardware platform running an operating system such as Linux. The functionality may be built into the proxy code, or it may be executed as an adjunct to that code.
  • While in some cases above a particular order of operations performed by certain embodiments is set forth, it should be understood that such order is exemplary and that they may be performed in a different order, combined, or the like. Moreover, some of the functions may be combined or shared in given instructions, program sequences, code portions, and the like. References in the specification to a given embodiment indicate that the embodiment described may include a particular feature, structure, or characteristic, but every embodiment may not necessarily include the particular feature, structure, or characteristic.
  • FIG. 6 is a block diagram that illustrates hardware in a computer system 600 upon which such software may run in order to implement embodiments of the invention. The computer system 600 may be embodied in a client, server, personal computer, workstation, tablet computer, wireless device, mobile device, network device, router, hub, gateway, or other device.
  • Computer system 600 includes a processor 604 coupled to bus 601. In some systems, multiple processor and/or processor cores may be employed. Computer system 600 further includes a main memory 610, such as a random access memory (RAM) or other storage device, coupled to the bus 601 for storing information and instructions to be executed by processor 604. A read only memory (ROM) 608 is coupled to the bus 601 for storing information and instructions for processor 604. A non-volatile storage device 606, such as a magnetic disk, solid state memory (e.g., flash memory), or optical disk, is provided and coupled to bus 601 for storing information and instructions. Other application-specific integrated circuits (ASICs), field programmable gate arrays (FPGAs) or circuitry may be included in the computer system 600 to perform functions described herein.
  • Although the computer system 600 is often managed remotely via a communication interface 616, for local administration purposes the system 600 may have a peripheral interface 612 communicatively couples computer system 600 to a user display 614 that displays the output of software executing on the computer system, and an input device 615 (e.g., a keyboard, mouse, trackpad, touchscreen) that communicates user input and instructions to the computer system 600. The peripheral interface 612 may include interface circuitry and logic for local buses such as Universal Serial Bus (USB) or other communication links.
  • Computer system 600 is coupled to a communication interface 616 that provides a link between the system bus 601 and an external communication link. The communication interface 616 provides a network link 618. The communication interface 616 may represent an Ethernet or other network interface card (NIC), a wireless interface, modem, an optical interface, or other kind of input/output interface.
  • Network link 618 provides data communication through one or more networks to other devices. Such devices include other computer systems that are part of a local area network (LAN) 626. Furthermore, the network link 618 provides a link, via an internet service provider (ISP) 620, to the Internet 622. In turn, the Internet 622 may provide a link to other computing systems such as a remote server 630 and/or a remote client 631. Network link 618 and such networks may transmit data using packet-switched, circuit-switched, or other data-transmission approaches.
  • In operation, the computer system 600 may implement the functionality described herein as a result of the processor executing code. Such code may be read from or stored on a non-transitory computer-readable medium, such as memory 610, ROM 608, or storage device 606. Other forms of non-transitory computer-readable media include disks, tapes, magnetic media, CD-ROMs, optical media, RAM, PROM, EPROM, and EEPROM. Any other non-transitory computer-readable medium may be employed. Executing code may also be read from network link 618 (e.g., following storage in an interface buffer, local memory, or other circuitry).

Claims (19)

What is claimed is:
1.-25. (canceled)
26. A proxy server in a content delivery network (CDN) that has a plurality of proxy servers delivering content to clients, the proxy server comprising:
a network interface for receiving a request for a markup language file associated with a web page, the request being received from a client;
circuitry forming one or more processors and memory holding instructions to be executed by the one or more processors to cause the proxy server to respond to the request by:
obtaining the markup language file from any of an origin server, a CDN network storage subsystem, a cache hierarchy parent, and a local cache;
inserting code into the markup language file for execution by the client when processing the markup language file, the code comprising instructions that instruct the client to gather timing information reflecting the client's processing of the markup language file in order to display the web page, and instructions that instruct the client to transmit the timing information in a beacon to the CDN;
including in the code an identifier that uniquely identifies at least one of:
(i) a point of presence in the CDN in which the proxy server resides;
(ii) an element from which the proxy server retrieved the markup language file, the network element comprising any of: the local cache, a cache-hierarchy parent, a CDN network storage subsystem, the origin server;
(iii) an element from which the proxy server file any of retrieved and will retrieve an embedded object in the markup language file, the network element comprising any of: a local cache, a cache-hierarchy parent, a CDN network storage subsystem, an origin server;
the code including instructions specifying that the client will transmit the identifier, as a field in the beacon, with the timing information;
serving the markup language file with the inserted code to the client, in response to the request.
27. The proxy server of claim 26, wherein the client comprises a web browser.
28. The proxy server of claim 26, wherein the markup language file comprises an HTML file.
29. The proxy server of claim 26, wherein the code is JavaScript code that is any of inlined into the markup language file and referenced by a URL inserted into the markup language file.
30. The proxy server of claim 26, wherein the timing information includes information specified in the Navigation Timing or Resource Timing specification.
31. The proxy server of claim 26, wherein the timing information includes one or more timestamps for a processing phase at the client.
32. The proxy server of claim 26, wherein the identifier that uniquely identifies:
(i) a point of presence in the CDN in which the proxy server resides.
33. The proxy server of claim 26, wherein the identifier that uniquely identifies:
(ii) a network element from which the proxy server retrieved the markup language file, the network element comprising any of a local cache, a cache-hierarchy parent, a CDN network storage subsystem, the origin server.
34. The proxy server of claim 26, the identifier that uniquely identifies:
(iii) a network element from which the proxy server file any of retrieved and will retrieve an embedded object in the markup language file, the network element comprising any of a local cache, a cache-hierarchy parent, a CDN network storage subsystem, the origin server.
35. A method performed by a proxy server in a content delivery network (CDN) that comprises a network interface, circuitry forming one or more processors, and memory holding instructions for execution by the one or more processors to perform the method, the method comprising:
receiving a request for a markup language file for a web page, the request being received from a client;
in response to the request, the proxy server:
obtaining the markup language file from any of an origin server, a CDN network storage subsystem, a cache hierarchy parent, and a local cache;
inserting code into the markup language file for execution by the client when processing the markup language file, the code comprising instructions that instruct the client to gather timing information reflecting the client's processing of the markup language file in order to display the web page, and instructions that instruct the client to transmit the timing information in a beacon to the CDN;
including in the code an identifier that uniquely identifies at least one of:
(i) a point of presence in the CDN in which the proxy server resides;
(ii) an element from which the proxy server retrieved the markup language file, the network element comprising any of: the local cache, a cache-hierarchy parent, a CDN network storage subsystem, the origin server;
(iii) an element from which the proxy server file any of retrieved and will retrieve an embedded object in the markup language file, the network element comprising any of: a local cache, a cache-hierarchy parent, a CDN network storage subsystem, an origin server;
the code including instructions specifying that the client will transmit the identifier, as a field in the beacon, with the timing information;
serving the markup language file with the inserted code to the client, in response to the request.
36. The method of claim 35, wherein the client comprises a web browser.
37. The method of claim 35, wherein the markup language file comprises an HTML file.
38. The method of claim 35, wherein the code is JavaScript code that is any of inlined into the markup language file and referenced by a URL inserted into the markup language file.
39. The method of claim 35, wherein the timing information includes information specified in the Navigation Timing or Resource Timing specification.
40. The method of claim 35, wherein the timing information includes one or more timestamps for a processing phase at the client.
41. The method of claim 35, wherein the identifier that uniquely identifies:
(i) a point of presence in the CDN in which the proxy server resides.
42. The method of claim 35, wherein the identifier that uniquely identifies:
(ii) a network element from which the proxy server retrieved the markup language file, the network element comprising any of a local cache, a cache-hierachy parent, a CDN network storage subsystem, the origin server.
43. The method of claim 35, the identifier that uniquely identifies:
(iii) a network element from which the proxy server file any of retrieved and will retrieve an embedded object in the markup language file, the network element comprising any of a local cache, a cache-hierarchy parent, a CDN network storage subsystem, the origin server.
US16/012,445 2011-12-23 2018-06-19 Assessment of content delivery services using performance measurements from within an end user client application Abandoned US20190028560A1 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
US16/012,445 US20190028560A1 (en) 2011-12-23 2018-06-19 Assessment of content delivery services using performance measurements from within an end user client application

Applications Claiming Priority (5)

Application Number Priority Date Filing Date Title
US201161579674P 2011-12-23 2011-12-23
US13/720,636 US9742858B2 (en) 2011-12-23 2012-12-19 Assessment of content delivery services using performance measurements from within an end user client application
US15/261,026 US9736258B2 (en) 2011-12-23 2016-09-09 Assessment of content delivery services using performance measurements from within an end user client application
US15/645,706 US20180027087A1 (en) 2011-12-23 2017-07-10 Assessment of content delivery services using performance measurements from within an end user client application
US16/012,445 US20190028560A1 (en) 2011-12-23 2018-06-19 Assessment of content delivery services using performance measurements from within an end user client application

Related Parent Applications (1)

Application Number Title Priority Date Filing Date
US15/645,706 Continuation US20180027087A1 (en) 2011-12-23 2017-07-10 Assessment of content delivery services using performance measurements from within an end user client application

Publications (1)

Publication Number Publication Date
US20190028560A1 true US20190028560A1 (en) 2019-01-24

Family

ID=48655616

Family Applications (4)

Application Number Title Priority Date Filing Date
US13/720,636 Active 2033-03-23 US9742858B2 (en) 2011-12-23 2012-12-19 Assessment of content delivery services using performance measurements from within an end user client application
US15/261,026 Active US9736258B2 (en) 2011-12-23 2016-09-09 Assessment of content delivery services using performance measurements from within an end user client application
US15/645,706 Abandoned US20180027087A1 (en) 2011-12-23 2017-07-10 Assessment of content delivery services using performance measurements from within an end user client application
US16/012,445 Abandoned US20190028560A1 (en) 2011-12-23 2018-06-19 Assessment of content delivery services using performance measurements from within an end user client application

Family Applications Before (3)

Application Number Title Priority Date Filing Date
US13/720,636 Active 2033-03-23 US9742858B2 (en) 2011-12-23 2012-12-19 Assessment of content delivery services using performance measurements from within an end user client application
US15/261,026 Active US9736258B2 (en) 2011-12-23 2016-09-09 Assessment of content delivery services using performance measurements from within an end user client application
US15/645,706 Abandoned US20180027087A1 (en) 2011-12-23 2017-07-10 Assessment of content delivery services using performance measurements from within an end user client application

Country Status (1)

Country Link
US (4) US9742858B2 (en)

Cited By (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US10958758B1 (en) 2019-11-22 2021-03-23 International Business Machines Corporation Using data analytics for consumer-focused autonomous data delivery in telecommunications networks
US11210360B2 (en) 2019-09-30 2021-12-28 Bby Solutions, Inc. Edge-caching optimization of personalized webpages
US11375033B1 (en) * 2020-05-06 2022-06-28 Amazon Technologies, Inc. Automated tuning of network intermediary devices
US11469981B2 (en) * 2020-01-17 2022-10-11 Cisco Technology, Inc. Network metric discovery
US11704383B2 (en) * 2019-09-30 2023-07-18 Bby Solutions, Inc. Dynamic generation and injection of edge-cached meta-data

Families Citing this family (51)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US9720569B2 (en) 2006-08-14 2017-08-01 Soasta, Inc. Cloud-based custom metric/timer definitions and real-time analytics of mobile applications
US9990110B1 (en) 2006-08-14 2018-06-05 Akamai Technologies, Inc. Private device cloud for global testing of mobile applications
US10579507B1 (en) 2006-08-14 2020-03-03 Akamai Technologies, Inc. Device cloud provisioning for functional testing of mobile applications
US9251035B1 (en) 2010-07-19 2016-02-02 Soasta, Inc. Load test charts with standard deviation and percentile statistics
US9450834B2 (en) 2010-07-19 2016-09-20 Soasta, Inc. Animated globe showing real-time web user performance measurements
WO2012112149A1 (en) * 2011-02-16 2012-08-23 Hewlett-Packard Development Company, L.P. Population category hierarchies
US9742858B2 (en) 2011-12-23 2017-08-22 Akamai Technologies Inc. Assessment of content delivery services using performance measurements from within an end user client application
US9772923B2 (en) 2013-03-14 2017-09-26 Soasta, Inc. Fast OLAP for real user measurement of website performance
US9706004B2 (en) * 2013-04-06 2017-07-11 Citrix Systems, Inc. Systems and methods for exporting client and server timing information for webpage and embedded object access
US10984175B2 (en) * 2013-08-09 2021-04-20 Yottaa Inc. Systems and methods for dynamically modifying a requested web page from a server for presentation at a client
US10187319B1 (en) * 2013-09-10 2019-01-22 Instart Logic, Inc. Automatic configuration generation for a proxy optimization server for optimizing the delivery of content of a web publisher
US10187283B2 (en) * 2013-11-19 2019-01-22 Telefonaktiebolaget Lm Ericsson (Publ) Testing the performance of a layer 3 proxy device using traffic amplification
US10601674B2 (en) 2014-02-04 2020-03-24 Akamai Technologies, Inc. Virtual user ramp controller for load test analytic dashboard
US10282479B1 (en) 2014-05-08 2019-05-07 Google Llc Resource view data collection
US20150339275A1 (en) * 2014-05-20 2015-11-26 Yahoo! Inc. Rendering of on-line content
US20150339330A1 (en) * 2014-05-20 2015-11-26 Sony Corporation System and method for content deployment
US9705762B2 (en) 2014-09-30 2017-07-11 Citrix Systems, Inc. Systems and methods for detecting device identity at a proxy background
US10154068B2 (en) * 2014-12-30 2018-12-11 Akamai Technologies, Inc. Self-adjusting tiered caching system to optimize traffic performance and origin offload
US9948709B2 (en) 2015-01-30 2018-04-17 Akamai Technologies, Inc. Using resource timing data for server push in multiple web page transactions
US10313463B2 (en) 2015-02-19 2019-06-04 Akamai Technologies, Inc. Systems and methods for avoiding server push of objects already cached at a client
US9225625B1 (en) * 2015-03-26 2015-12-29 Linkedin Corporation Detecting and alerting performance degradation during features ramp-up
US10346431B1 (en) 2015-04-16 2019-07-09 Akamai Technologies, Inc. System and method for automated run-tme scaling of cloud-based data store
US9495138B1 (en) * 2016-01-04 2016-11-15 International Business Machines Corporation Scheme for verifying the effects of program optimizations
CN105791034B (en) * 2016-05-15 2018-10-26 北京联合大学 A kind of browsing class service-aware analysis method
US10412186B2 (en) 2016-08-18 2019-09-10 Level 3 Communications, Llc Front-end optimization in a content delivery network (CDN)
US10725759B2 (en) * 2016-10-03 2020-07-28 Avaya Inc. Web application system and method to dynamically select between local installed and cloud-based resources
US10313223B2 (en) 2016-12-14 2019-06-04 Level 3 Communications, Llc Object integrity verification in a content delivery network (CDN)
US10084855B2 (en) 2017-01-23 2018-09-25 Akamai Technologies, Inc. Pixel-based load balancing
CN106878438A (en) * 2017-03-03 2017-06-20 久远谦长(北京)技术服务有限公司 The method and system of user behavior analysis under a kind of https environment
US10606736B1 (en) 2017-03-03 2020-03-31 Akamai Technologies Inc. System and method for automated creation of a load test plan
US10360067B1 (en) * 2017-03-28 2019-07-23 Amazon Technologies, Inc. Dynamic function calls in an on-demand network code execution system
US10586358B1 (en) 2017-05-10 2020-03-10 Akamai Technologies, Inc. System and method for visualization of beacon clusters on the web
US10439925B2 (en) * 2017-12-21 2019-10-08 Akamai Technologies, Inc. Sandbox environment for testing integration between a content provider origin and a content delivery network
US10630797B2 (en) 2018-01-30 2020-04-21 Akamai Technologies, Inc. Systems and methods for content delivery acceleration of virtual reality and augmented reality web pages
US10810279B2 (en) 2018-02-07 2020-10-20 Akamai Technologies, Inc. Content delivery network (CDN) providing accelerated delivery of embedded resources from CDN and third party domains
US10764402B2 (en) 2018-03-03 2020-09-01 Akamai Technologies, Inc. Leveraging time-windows generated by web browser pre-connections
US20190347315A1 (en) * 2018-05-08 2019-11-14 International Business Machines Corporation Methods and systems for rendering web pages with restricted features
CN108920703B (en) * 2018-07-18 2021-11-26 郑州云海信息技术有限公司 HTTP cache optimization method and device
US11044090B2 (en) * 2018-07-24 2021-06-22 ZenDesk, Inc. Facilitating request authentication at a network edge device
US10931695B2 (en) 2018-08-22 2021-02-23 Akamai Technologies, Inc. Nonce injection and observation system for detecting eavesdroppers
US10972576B2 (en) * 2018-11-14 2021-04-06 International Business Machines Corporation Content acceleration for cross-site resources by CDN
CN109714406B (en) * 2018-12-18 2021-04-02 网宿科技股份有限公司 Method and equipment for processing resource description file and acquiring page resource
CN111404761B (en) * 2019-01-02 2022-03-25 中国移动通信有限公司研究院 Content looping detection processing method and device and computer readable storage medium
US10924534B2 (en) 2019-03-01 2021-02-16 Akamai Technologies, Inc. Dynamic placement of computing tasks in a distributed computing environment
US10785281B1 (en) 2019-03-06 2020-09-22 Cisco Technology, Inc. Breaking down the load time of a web page into coherent components
US11436122B1 (en) * 2019-05-13 2022-09-06 Cisco Technology, Inc. Key performance indicator recommendations based on relevancy ranking
US10972572B2 (en) 2019-07-12 2021-04-06 Zycada Networks Programmable delivery network
US11531536B2 (en) * 2019-11-20 2022-12-20 Red Hat, Inc. Analyzing performance impacts of source code changes
US11409543B2 (en) 2020-02-03 2022-08-09 Dell Products L.P. Method and apparatus for improving data management in an information handling system
CN111770119B (en) * 2020-09-03 2020-11-27 云盾智慧安全科技有限公司 Website resource acquisition method, system, device and computer storage medium
US11379281B2 (en) 2020-11-18 2022-07-05 Akamai Technologies, Inc. Detection and optimization of content in the payloads of API messages

Citations (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20070083649A1 (en) * 2005-10-12 2007-04-12 Brian Zuzga Performance monitoring of network applications
US20080065980A1 (en) * 2006-09-08 2008-03-13 Opera Software Asa Modifying a markup language document which includes a clickable image
US20080104231A1 (en) * 2004-11-17 2008-05-01 Sujit Dey Network Monitoring System And Method
US20120166574A1 (en) * 2010-12-27 2012-06-28 Limelight Networks, Inc. Partial object caching
US20120209949A1 (en) * 2011-02-14 2012-08-16 Alexandros Deliyannis Methods and apparatus to monitor media content
US8266281B1 (en) * 2010-04-22 2012-09-11 Imdb.Com, Inc. Collecting client-side performance metrics and latencies
US8738766B1 (en) * 2011-11-01 2014-05-27 Edgecast Networks, Inc. End-to-end monitoring and optimization of a content delivery network using anycast routing
US8799372B1 (en) * 2008-10-07 2014-08-05 Sprint Spectrum, L.P. Management of referenced object based on size of referenced object

Family Cites Families (86)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6421733B1 (en) 1997-03-25 2002-07-16 Intel Corporation System for dynamically transcoding data transmitted between computers
US6275692B1 (en) 1998-02-11 2001-08-14 Telefonaktiebolaget L M Ericsson (Publ) Server request including code for customizing service to requesting cellular mobile station
US6243761B1 (en) 1998-03-26 2001-06-05 Digital Equipment Corporation Method for dynamically adjusting multimedia content of a web page by a server in accordance to network path characteristics between client and server
US6857102B1 (en) 1998-04-07 2005-02-15 Fuji Xerox Co., Ltd. Document re-authoring systems and methods for providing device-independent access to the world wide web
US6108703A (en) 1998-07-14 2000-08-22 Massachusetts Institute Of Technology Global hosting system
US7664864B2 (en) 1998-11-13 2010-02-16 Verisign, Inc. Meta content distribution network
US6397217B1 (en) 1999-03-04 2002-05-28 Futuretense, Inc. Hierarchical caching techniques for efficient dynamic page generation
US6973490B1 (en) 1999-06-23 2005-12-06 Savvis Communications Corp. Method and system for object-level web performance and analysis
US20010047394A1 (en) 1999-09-10 2001-11-29 Kloba David D. System, method, and computer program product for executing scripts on mobile devices
US6792575B1 (en) 1999-10-21 2004-09-14 Equilibrium Technologies Automated processing and delivery of media to web servers
US6665726B1 (en) 2000-01-06 2003-12-16 Akamai Technologies, Inc. Method and system for fault tolerant media streaming over the internet
US7047033B2 (en) 2000-02-01 2006-05-16 Infogin Ltd Methods and apparatus for analyzing, processing and formatting network information such as web-pages
US6820133B1 (en) 2000-02-07 2004-11-16 Netli, Inc. System and method for high-performance delivery of web content using high-performance communications protocol between the first and second specialized intermediate nodes to optimize a measure of communications performance between the source and the destination
US7240100B1 (en) 2000-04-14 2007-07-03 Akamai Technologies, Inc. Content delivery network (CDN) content server request handling mechanism with metadata framework support
US8060581B2 (en) 2000-07-19 2011-11-15 Akamai Technologies, Inc. Dynamic image delivery system
US7653706B2 (en) 2000-07-19 2010-01-26 Akamai Technologies, Inc. Dynamic image delivery system
WO2002017082A1 (en) 2000-08-22 2002-02-28 Akamai Technologies, Inc. Dynamic content assembly on edge-of-network servers in a content delivery network
US7111057B1 (en) 2000-10-31 2006-09-19 Akamai Technologies, Inc. Method and system for purging content from a content delivery network
US7574486B1 (en) 2000-11-06 2009-08-11 Telecommunication Systems, Inc. Web page content translator
US7600014B2 (en) 2000-11-16 2009-10-06 Symantec Corporation Method and system for monitoring the performance of a distributed application
US20020138331A1 (en) 2001-02-05 2002-09-26 Hosea Devin F. Method and system for web page personalization
US7472178B2 (en) 2001-04-02 2008-12-30 Akamai Technologies, Inc. Scalable, high performance and highly available distributed storage system for Internet content
DE60236221D1 (en) 2001-07-12 2010-06-10 Research In Motion Ltd A system and method for pushing data from an information source to a mobile terminal including transcoding the data
US6963874B2 (en) 2002-01-09 2005-11-08 Digital River, Inc. Web-site performance analysis system and method utilizing web-site traversal counters and histograms
US20030115365A1 (en) 2001-12-19 2003-06-19 Teddy Lindsey Transcoding information in a first markup language into a second markup language
US10031885B2 (en) 2010-02-01 2018-07-24 Netmotion Wireless, Inc. Public wireless network performance management system with mobile device data collection agents
US7133905B2 (en) 2002-04-09 2006-11-07 Akamai Technologies, Inc. Method and system for tiered distribution in a content delivery network
US7107309B1 (en) 2002-07-03 2006-09-12 Sprint Spectrum L.P. Method and system for providing interstitial notice
WO2004083990A2 (en) 2003-03-17 2004-09-30 British Telecommunications Public Limited Company Web content adaption process and system
US8635218B2 (en) 2003-09-02 2014-01-21 International Business Machines Corporation Generation of XSLT style sheets for different portable devices
US8782200B2 (en) 2004-09-14 2014-07-15 Sitespect, Inc. System and method for optimizing website visitor actions
US20060085420A1 (en) 2004-09-27 2006-04-20 Symphoniq Corp. Method and apparatus for monitoring real users experience with a website
US20070271375A1 (en) 2004-09-27 2007-11-22 Symphoniq Corporation Method and apparatus for monitoring real users experience with a website capable of using service providers and network appliances
US8346956B2 (en) 2004-10-29 2013-01-01 Akamai Technologies, Inc. Dynamic image delivery system
US20090292824A1 (en) 2005-01-21 2009-11-26 Internap Network Services Corporation System And Method For Application Acceleration On A Distributed Computer Network
US20060274869A1 (en) 2005-06-07 2006-12-07 Yahoo! Inc. Dynamically generating content based on capabilities of a mobile device
US7660296B2 (en) 2005-12-30 2010-02-09 Akamai Technologies, Inc. Reliable, high-throughput, high-performance transport and routing mechanism for arbitrary data flows
US8447837B2 (en) 2005-12-30 2013-05-21 Akamai Technologies, Inc. Site acceleration with content prefetching enabled through customer-specific configurations
US8037127B2 (en) 2006-02-21 2011-10-11 Strangeloop Networks, Inc. In-line network device for storing application-layer data, processing instructions, and/or rule sets
US9154611B1 (en) 2006-08-14 2015-10-06 Soasta, Inc. Functional test automation for gesture-based mobile applications
US7844036B2 (en) 2006-08-14 2010-11-30 Soasta, Inc. Visual test automation tool for message-based applications, web applications and SOA systems
US9720569B2 (en) 2006-08-14 2017-08-01 Soasta, Inc. Cloud-based custom metric/timer definitions and real-time analytics of mobile applications
US8274905B2 (en) 2006-08-22 2012-09-25 Embarq Holdings Company, Llc System and method for displaying a graph representative of network performance over a time period
NO325628B1 (en) 2006-09-20 2008-06-30 Opera Software Asa Procedure, computer program, transcoding server and computer system to modify a digital document
US20080098093A1 (en) 2006-10-16 2008-04-24 Palm, Inc. Offline automated proxy cache for web applications
US7765295B2 (en) 2006-10-25 2010-07-27 Compuware Corporation Methods and apparatus for real user monitoring
US8489923B1 (en) 2006-11-15 2013-07-16 Conviva Inc. Detecting problems in content distribution
US8874964B1 (en) 2006-11-15 2014-10-28 Conviva Inc. Detecting problems in content distribution
US20080228920A1 (en) 2007-03-16 2008-09-18 Souders Steven K System and method for resource aggregation and distribution
US8775603B2 (en) 2007-05-04 2014-07-08 Sitespect, Inc. Method and system for testing variations of website content
US8060486B2 (en) 2007-05-07 2011-11-15 Hewlett-Packard Development Company, L.P. Automatic conversion schema for cached web requests
US9165301B2 (en) 2007-06-06 2015-10-20 Core Audience, Inc. Network devices for replacing an advertisement with another advertisement
NZ566291A (en) 2008-02-27 2008-12-24 Actionthis Ltd Methods and devices for post processing rendered web pages and handling requests of post processed web pages
US20090254707A1 (en) 2008-04-08 2009-10-08 Strangeloop Networks Inc. Partial Content Caching
US9906620B2 (en) 2008-05-05 2018-02-27 Radware, Ltd. Extensible, asynchronous, centralized analysis and optimization of server responses to client requests
US20100050089A1 (en) 2008-08-20 2010-02-25 Company 100, Inc. Web browser system of mobile communication terminal, using proxy server
US20100324989A1 (en) 2009-06-23 2010-12-23 Craig Stephen Etchegoyen System and Method for Monitoring Efficacy of Online Advertising
US20110029899A1 (en) 2009-08-03 2011-02-03 FasterWeb, Ltd. Systems and Methods for Acceleration and Optimization of Web Pages Access by Changing the Order of Resource Loading
US9537967B2 (en) 2009-08-17 2017-01-03 Akamai Technologies, Inc. Method and system for HTTP-based stream delivery
US8112471B2 (en) 2009-12-07 2012-02-07 Yottaa, Inc System and method for website performance optimization and internet traffic processing
US9634993B2 (en) 2010-04-01 2017-04-25 Cloudflare, Inc. Internet-based proxy service to modify internet responses
CA2742059C (en) 2010-06-22 2019-10-29 Blaze Software Inc. Method and system for automated analysis and transformation of web pages
US9495473B2 (en) 2010-07-19 2016-11-15 Soasta, Inc. Analytic dashboard with user interface for producing a single chart statistical correlation from source and target charts during a load test
US9436579B2 (en) 2010-07-19 2016-09-06 Soasta, Inc. Real-time, multi-tier load test results aggregation
US9021362B2 (en) 2010-07-19 2015-04-28 Soasta, Inc. Real-time analytics of web performance using actual user measurements
US9450834B2 (en) 2010-07-19 2016-09-20 Soasta, Inc. Animated globe showing real-time web user performance measurements
US8341462B2 (en) 2010-07-19 2012-12-25 Soasta, Inc. System and method for provisioning and running a cross-cloud test grid
US9229842B2 (en) 2010-07-19 2016-01-05 Soasta, Inc. Active waterfall charts for continuous, real-time visualization of website performance data
US9251035B1 (en) 2010-07-19 2016-02-02 Soasta, Inc. Load test charts with standard deviation and percentile statistics
US20120089700A1 (en) 2010-10-10 2012-04-12 Contendo, Inc. Proxy server configured for hierarchical caching and dynamic site acceleration and custom object and associated method
US20120265853A1 (en) 2010-12-17 2012-10-18 Akamai Technologies, Inc. Format-agnostic streaming architecture using an http network for streaming
US8880633B2 (en) 2010-12-17 2014-11-04 Akamai Technologies, Inc. Proxy server with byte-based include interpreter
WO2012088023A2 (en) 2010-12-20 2012-06-28 Akamai Technologies, Inc. Methods and systems for delivering content to differentiated client devices
US9106607B1 (en) 2011-04-11 2015-08-11 Viasat, Inc. Browser based feedback for optimized web browsing
US9785533B2 (en) 2011-10-18 2017-10-10 Soasta, Inc. Session template packages for automated load testing
US9742858B2 (en) 2011-12-23 2017-08-22 Akamai Technologies Inc. Assessment of content delivery services using performance measurements from within an end user client application
US9817916B2 (en) 2012-02-22 2017-11-14 Akamai Technologies Inc. Methods and apparatus for accelerating content authored for multiple devices
US9674258B2 (en) 2012-02-23 2017-06-06 Yottaa Inc. System and method for context specific website optimization
US8626910B1 (en) 2012-06-19 2014-01-07 Edgecast Networks, Inc. Systems and methods for performing localized server-side monitoring in a content delivery network
US9785621B2 (en) 2012-11-26 2017-10-10 Akamai Technologies, Inc. Progressive consolidation of web page resources
US9772923B2 (en) 2013-03-14 2017-09-26 Soasta, Inc. Fast OLAP for real user measurement of website performance
US9706004B2 (en) 2013-04-06 2017-07-11 Citrix Systems, Inc. Systems and methods for exporting client and server timing information for webpage and embedded object access
US9544205B2 (en) 2013-04-09 2017-01-10 Twin Prime, Inc. Cognitive data delivery optimizing system
US9015348B2 (en) 2013-07-19 2015-04-21 Limelight Networks, Inc. Dynamically selecting between acceleration techniques based on content request attributes
WO2015041711A1 (en) 2013-09-20 2015-03-26 Yottaa, Inc. Systems and methods for managing loading priority or sequencing of fragments of a web object
US9336525B2 (en) 2013-10-01 2016-05-10 Adobe Systems Incorporated Method and apparatus for enabling dynamic analytics configuration on a mobile device

Patent Citations (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20080104231A1 (en) * 2004-11-17 2008-05-01 Sujit Dey Network Monitoring System And Method
US20070083649A1 (en) * 2005-10-12 2007-04-12 Brian Zuzga Performance monitoring of network applications
US20080065980A1 (en) * 2006-09-08 2008-03-13 Opera Software Asa Modifying a markup language document which includes a clickable image
US8799372B1 (en) * 2008-10-07 2014-08-05 Sprint Spectrum, L.P. Management of referenced object based on size of referenced object
US8266281B1 (en) * 2010-04-22 2012-09-11 Imdb.Com, Inc. Collecting client-side performance metrics and latencies
US20120166574A1 (en) * 2010-12-27 2012-06-28 Limelight Networks, Inc. Partial object caching
US20120209949A1 (en) * 2011-02-14 2012-08-16 Alexandros Deliyannis Methods and apparatus to monitor media content
US8738766B1 (en) * 2011-11-01 2014-05-27 Edgecast Networks, Inc. End-to-end monitoring and optimization of a content delivery network using anycast routing

Cited By (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US11210360B2 (en) 2019-09-30 2021-12-28 Bby Solutions, Inc. Edge-caching optimization of personalized webpages
US11704383B2 (en) * 2019-09-30 2023-07-18 Bby Solutions, Inc. Dynamic generation and injection of edge-cached meta-data
US10958758B1 (en) 2019-11-22 2021-03-23 International Business Machines Corporation Using data analytics for consumer-focused autonomous data delivery in telecommunications networks
US11469981B2 (en) * 2020-01-17 2022-10-11 Cisco Technology, Inc. Network metric discovery
US11375033B1 (en) * 2020-05-06 2022-06-28 Amazon Technologies, Inc. Automated tuning of network intermediary devices

Also Published As

Publication number Publication date
US20180027087A1 (en) 2018-01-25
US9736258B2 (en) 2017-08-15
US20160381166A1 (en) 2016-12-29
US20130166634A1 (en) 2013-06-27
US9742858B2 (en) 2017-08-22

Similar Documents

Publication Publication Date Title
US9736258B2 (en) Assessment of content delivery services using performance measurements from within an end user client application
US11870841B2 (en) System and method for constructing content site visitor profiles
US8775603B2 (en) Method and system for testing variations of website content
US9288256B2 (en) URL prefetching
US9654579B2 (en) Scalable content delivery network request handling mechanism
US9660890B2 (en) Service provider optimization of content management
US20070271375A1 (en) Method and apparatus for monitoring real users experience with a website capable of using service providers and network appliances
EP2583197B1 (en) Unified collection and distribution of data
US9015348B2 (en) Dynamically selecting between acceleration techniques based on content request attributes
US20070206584A1 (en) Systems and methods for providing a dynamic interaction router
US20060085420A1 (en) Method and apparatus for monitoring real users experience with a website
US20150066587A1 (en) Content site visitor processing system
KR20110100631A (en) Mobile ad optimization architecture
CN103765858B (en) For period that browses in communication network monitoring the method for user and server user
US20130238423A1 (en) Client-side event monitoring
US20210081212A1 (en) Identifying analytic element execution paths
Shivakumar et al. Getting Started with Web Performance Optimization
Pujol Gil Web content delivery, monetization, and search: back-office and advertisement traffic on the Internet

Legal Events

Date Code Title Description
AS Assignment

Owner name: AKAMAI TECHNOLOGIES, INC., MASSACHUSETTS

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:HOLLAND, MARK C.;REEL/FRAME:046210/0511

Effective date: 20130103

STPP Information on status: patent application and granting procedure in general

Free format text: NON FINAL ACTION MAILED

STPP Information on status: patent application and granting procedure in general

Free format text: FINAL REJECTION MAILED

STCB Information on status: application discontinuation

Free format text: ABANDONED -- FAILURE TO RESPOND TO AN OFFICE ACTION