The Clients tab for an HTTP virtual service displays information about clients accessing that service.

The information shown within the tab is dependent on the setting for client insights. This setting can be modified in the Analytics tab of the Create Virtual Service pop-up window.



Note:

The Clients tab does not appear for non-HTTP virtual services.

Many of the entries on the Clients tab will present expanded data when clicked. For example, clicking Computer in the Devices section filters the Clients tab to display data for clients connecting to the virtual service from a desktop computer (versus phones or tablets). While an entry is highlighted, other sections will have two numbers.

  • Green or red percentage number shows how much higher or lower the numbers are when filtered for computers compared to without the filter.

  • Specific percentage for computers.

Clicking the selected item, such as Computer again, deselects that item and remove the filter.

Clients Tab

The Clients tab presents the following information:

  • End-to-End Timing: Complete view of client-to-server transaction times. This includes the time required for a client to download an individual HTTP-requested object or to complete a TCP transaction.

  • Page Load Time: If you have enabled active client insights on the Analytics tab for the virtual service, the Avi Load Balancer inserts Javascript into a sampling of HTTP responses sent to the client to gather additional information about the client experience of loading the page. This data appears in two bars:

    • DOM Load Time: Amount of time between the client's first attempt to load a page served from the virtual service and the point at which the client browsers could start rendering the HTML page, even if the entire page is not fully downloaded.

    • Page Load Time: Total time required to download and render the entire page. These metrics differ from the end-to-end timing metric in that they represent the client's view of the total time taken when the end-to-end timing metric takes the view of the Avi Load Balancer. End-to-end timing is the average time to download a single object, whereas page load time is the time to download all objects for the page and render them in the client’s browser. Page load time measures the following:

      • All HTTP objects and not just a single file

      • HTML errors and timeouts

      • HTTP redirects

      • DNS resolution

      • Blocking, where the browser is waiting for various reasons

      • Rendering time, or the time the browser took to paint the page

  • Location: Client country of origin. Clients connecting from internal IP addresses display as Internal. Administrators can create custom locations using IP groups. For example, an IP group can be configured in which 10.1.0.0/16 = West_Campus and 10.2.0.0/16 = East_Campus. Any clients connecting from these IP ranges are shown as originating from the custom locations, while all other 10.x.x.x IP addresses are still classified as Internal. If an IP address exists in multiple places, such as Japan and Tokyo Campus, a more specific address match is used. Custom groups are more specific and will override any default country.

  • Device: Client device type such as Computer, Tablet, Phone, or Other. The Avi Load Balancer derives this information from the client’s User-Agent header. Clients that do not present this header or that present an unknown User-Agent string are categorized as Other.

  • Browser: Browser is client browser. The Avi Load Balancer tracks Firefox, Safari, Internet Explorer, Opera, and Chrome. This information is sourced from the client’s User-Agent string.

  • Operating System: Operationg system is client operating system. The Avi Load Balancer tracks Apple MacOS, Apple iOS, Google Android, Microsoft Windows, and Linux. This information is sourced from the client’s User-Agent string.

  • Top URLs: The Avi Load Balancer records the most commonly requested URLs for the virtual service. Clicking the Resource Timing button for one of the URLs opens a detailed waterfall view for that URL and displays a breakdown of the objects referenced by the following:

    • Selected page.

    • Ordering of the objects.

    • Load times for each object, including DOM load time and total page load time. This information can be very useful for website developers to diagnose slow page load issues.

    • URL: Host, path, and query for the requested object.

    • Initiator: This object might have been requested because:

      • It was referenced by a link or script.

      • It is an image.

      • It is blank for the root-level page that was clicked by the client.

    • Start Time: The time when this object was requested relative to its peers. The first object will always be time zero and will reference sub-objects, which are requested later. The indicated times are averaged for the recorded requests to this page.

    • Duration: Total client download duration. This is a superset of the data points included in the end-to-end timing, because it includes additional metrics beyond the immediate client-to-web-server interaction.

    • Resource Timing: Breakdown of the time required to download the page object. The length of the bar indicates the time, and the colors denote the various stages where time was spent. The bars furthest to the left were processed first. Bars that start further to the right are objects that began downloading and processing later.

Resource Timing Metrics

The Resource Timing breakdown provides the following timing information:

  • DNS: Time the client spent waiting for the object hostname to resolve.

    • Many objects have the same underlying fully qualified domain name (FQDN) and thus not every object will contain a DNS time.

    • If the client must wait for DNS resolution, then the time could be notably longer.

    • If the client or the client’s local DNS server has the hostname cached, DNS time can be imperceptibly small.

  • Blocking: Time spent while the browser was blocked from further processing. This typically implies the browser was busy reading and processing a page or a script. Failed scripts may cause a head-of-line block while the browser waits to time out the failed process before continuing the page load process.

  • Redirecting: Time spent following redirects, such as HTTP-to-HTTPS, to a different hostname or path.

  • Connecting: Time spent connecting with the endpoint (virtual service). This roughly corresponds to the client RTT metric of the end-to-end timing chart.

  • Waiting: Time spent by the client waiting for the first packet of the response to its request. From the client’s perspective, this is a single metric for all objects requested for a page. The End to End Timing graph on the Health tab for the virtual service breaks this into the following separate metrics, recorded on a per object basis:

    • Server RTT: The TCP latency between the Avi Load Balancer and the server.

    • Client RTT: The TCP latency between Avi Load Balancer and the client.

    • Application Response: The time during which the application server was processing or generating the content.

  • Receiving: The interval between the receipt of the first packet of the response and the receipt of the last packet. This is a combination of object size, TCP latency and packet loss, and the number of round trip times (TCP ACKs) required. This corresponds to the end-to-end timing chart’s data transfer time.

  • Rendering: The time the browser takes to render or paint the page.