Citrix HDX User Active Sessions Test
In order to ensure that the user experience with applications/desktops deployed on a XenApp/XenDesktop environment remains ‘superlative’ at all times, administrators should be able to proactively detect potential slowdowns when accessing applications/desktops, precisely pinpoint the user session affected by the slowdown, accurately isolate the root-cause of such slowness, and rapidly initiate measures to eliminate the root-cause. The Citrix HDX User Active Sessions test facilitates all the above, and thus assures users of uninterrupted application/desktop access!
For a user session that is currently active on a XenApp server or a XenDesktop virtual desktop, this test measures session latencies and leads you to the probable cause of session slowness (if any) - is it the network? the server hosting the applications/desktops? or are the applications (in the case of sessions to a XenApp server) taking too long to startup? If a latent network is causing the slowness, then the test provides administrators with detailed insights into network performance and enables them to rapidly figure out where the bottleneck lies - on the client-side network? or on the server-side network? This way, the test promptly leads administrators to slow user sessions, and also reveals what is causing the slowness, so that administrators can initiate the right steps to enhance user experience with applications/desktops.
Target of the test : An AppFlow-enabled ADC Appliance
Agent deploying the test : A remote agent
Outputs of the test : One set of results for each session for every user to a XenApp server / XenDesktop virtual desktop
First level descriptor: User name
Second level descriptor: Session GUID
An application session is identified by a single session GUID, regardless of the number of applications accessed by a user during that session.
A desktop session is identified by a separate session GUID - one each for every desktop that is accessed
Parameter | Description |
Test period |
How often should the test be executed. It is recommended that you set the test period to 5 minutes. This is because, the eG AppFlow Collector is capable of capturing and aggregating AppFlow data related to the last 5 minutes only. |
Host |
The host for which the test is to be configured. |
Cluster IPs |
This parameter applies only if the ADC appliance being monitored is part of a ADC cluster. In this case, configure this parameter with a comma-separated list of IP addresses of all other nodes in that cluster. If the monitored ADC appliance is down/unreachable, then the eG AppFlow Collector uses the Cluster IPs configuration to figure out which other node in the cluster it should connect to for pulling AppFlow statistics. Typically, the collector attempts to connect to every IP address that is configured against Cluster IPs, in the same sequence in which they are specified. Metrics are pulled from the first cluster node that the collector successfully establishes a connection with. |
Enable Logs |
This flag is set to No by default. This means that, by default, the eG agent does not create AppFlow logs. You can set this flag to Yes to enable AppFlow logging. If this is done, then the eG agent automatically writes the raw AppFlow records it reads from the collector into individual CSV files. These CSV files are stored in the <EG_AGENT_INSTALL_DIR>\NetFlow\data\<IP_of_Monitored_NetScaler>\hdxappflow\actual_csv folder on the eG agent host. These CSV files provide administrators with granular insights into the HDX appflows, thereby enabling effective troubleshooting. Note: By default, the eG agent creates a maximum of 10 CSV files in the actual_csv folder. Beyond this point, the older CSV files will be automatically deleted by the eG agent to accommodate new files with current data. Likewise, a single CSV file can by default contain a maximum of 99999 records only. If the records to be written exceed this default value, then the eG agent automatically creates another CSV file to write the data. If required, you can overwrite these default settings . For this, do the following:
|
DD Frequency |
Refers to the frequency with which detailed diagnosis measures are to be generated for this test. The default is 1:1. This indicates that, by default, detailed measures will be generated every time this test runs, and also every time the test detects a problem. You can modify this frequency, if you so desire. Also, if you intend to disable the detailed diagnosis capability for this test, you can do so by specifying none against DD Frequency. |
Detailed Diagnosis |
To make diagnosis more efficient and accurate, the eG Enterprise embeds an optional detailed diagnostic capability. With this capability, the eG agents can be configured to run detailed, more elaborate tests as and when specific problems are detected. To enable the detailed diagnosis capability of this test for a particular server, choose the On option. To disable the capability, click on the Off option. The option to selectively enable/disable the detailed diagnosis capability will be available only if the following conditions are fulfilled:
|
Measurement | Description | Measurement Unit | Interpretation | ||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
Active applications |
Indicates the number of applications currently accessed by this user session. |
Number |
To know which applications are active in this user session, use the detailed diagnosis of this measure. This measure is reported only for application sessions, and not desktop sessions. |
||||||||||||
Application launches |
Indicates the number of applications that were launched by this user session. |
Number |
To know which applications were launched by this user session, use the detailed diagnosis of this measure. This measure is reported only for application sessions, and not desktop sessions. |
||||||||||||
Application terminates |
Indicates the number of applications terminated by this user session. |
Number |
To know which applications were terminated in this user session, use the detailed diagnosis of this measure. This measure is reported only for application sessions, and not desktop sessions. |
||||||||||||
Session status |
Indicates the current status of this session. |
|
The values that this measure can take and the numeric values that correspond to each measure value are listed in the table below:
Note: Typically, this test reports the Measure Values in the table above to indicate session status. In the graph of this measure however, the same is indicated using the numeric equivalents only. |
||||||||||||
Average application startup duration |
Indicates the average time that elapsed between when an application accessed by this session was launched and when it started running. |
Msecs |
A high value for this measure indicates that one/more applications are starting up slowly on the server. In this case, use the detailed diagnosis of the Active applications measure to know which application is the slowest in starting up. This measure is reported only for application sessions, and not desktop sessions. |
||||||||||||
RTT |
Indicates the screen lag experienced by this session while interacting with applications/desktops. |
Msecs |
A high value for this measure is indicative of the poor quality of a user’s experience with applications/desktops. To know the reason for this below-par UX, compare the value of the WAN latency, DC latency, and Host delay measures of that session. |
||||||||||||
WAN latency |
Indicates the average latency experienced by this user session due to problems with the client side network. |
Msecs |
A high value for this measure indicates that the client side network is slow. If the value of the RTT measure is abnormally high for a session, you can compare the value of this measure with that of the DC latency and Host delay, and measures of that user session to know what is causing the slowness – is it the client side network? the server side network? or the server hosting the applications/desktops? |
||||||||||||
DC latency |
Indicates the average latency experienced by this session due to problems with the server side network. |
Msecs |
A high value for this measure indicates that the server side network is slow. If the value of the RTT measure is abnormally high for a session, you can compare the value of this measure with that of the WAN latency and Host delay, cy measures of that session to know what is causing the slowness – is it the client side network? the server side network? or the server hosting the applications/desktops? |
||||||||||||
Host delay |
Indicates the delay that this session experienced when waiting for the host to process the packets. |
Msecs |
A high value for this measure indicates a processing bottleneck with the server hosting the applications. If the value of the RTT measure is abnormally high for a session, you can compare the value of this measure with that of the WAN latency and DC latency, measures to know what is causing the slowness – is it the client side network? the server side network? or the server hosting the applications/desktops? |
||||||||||||
Bandwidth |
Indicates the rate at which data is transferred over this ICA session. |
Kbps |
Ideally, the value of this measure should be low. A high value indicates excessive bandwidth usage by the session. Compare the value of this measure across sessions to know which session is consuming bandwidth excessively. |
||||||||||||
Bytes |
Indicates the total bytes consumed by this session. |
Bytes |
Compare the value of this measure across sessions to know which session has the maximum throughput and which has the least. |
||||||||||||
Client side retransmits |
Indicates the number of packets retransmitted on the client side connection during the last measurement period. |
Number |
Ideally, the value of these measures should be 0.
|
||||||||||||
Server side retransmits |
Indicates the number of packets retransmitted on the server side connection during the last measurement period. |
Number |
|||||||||||||
Client side 0 window count |
Indicates how many times in this session the client advertised a zero TCP window during the last measurement period. |
Number |
TCP Zero Window is when the Window size in a machine remains at zero for a specified amount of time. TCP Window size is the amount of information that a machine can receive during a TCP session and still be able to process the data. Think of it like a TCP receive buffer. When a machine initiates a TCP connection to a server, it will let the server know how much data it can receive by the Window Size. In many Windows machines, this value is around 64512 bytes. As the TCP session is initiated and the server begins sending data, the client will decrement it's Window Size as this buffer fills. At the same time, the client is processing the data in the buffer, and is emptying it, making room for more data. Through TCP ACK frames, the client informs the server of how much room is in this buffer. If the TCP Window Size goes down to 0, the client will not be able to receive any more data until it processes and opens the buffer up again. The machine (client/server) alerting the Zero Window will not receive any more data from the host. This is why, ideally, the value of these measures should be 0. A non-zero value warrants an immediate investigation to determine the reason for the Zero Window. It could be that the client/server was running too many processes at that moment, and its processor is maxed. Or it could be that there is an error in the TCP receiver, like a Windows registry misconfiguration. Try to determine what the client was doing when the TCP Zero Window happened. These measures are reported only for application sessions, and not desktop sessions. |
||||||||||||
Server side 0 window count |
Indicates how many times in this session the server advertised a zero TCP window during the last measurement period. |
Number |
|||||||||||||
Client RTO |
Indicates how many times during the last measurement period the retransmit timeout got invoked in this session on the client side connection. |
Number |
An RTO occurs when the sender is missing too many acknowledgments and decides to take a time out and stop sending altogether. After some amount of time, usually at least one second, the sender cautiously starts sending again, testing the waters with just one packet at first, then two packets, and so on. As a result, an RTO causes, at minimum, a one-second delay on your network. A low value is hence desired for these measures. These measures are reported only for application sessions, and not desktop sessions. |
||||||||||||
Server RTO |
Indicates how many times during the last measurement period the retransmit timeout got invoked in this session on the server side connection. |
Number |
|||||||||||||
ACR counts |
Indicates the total number of times the client automatically reconnected the user to this session. |
Number |
The Automatic Client Reconnect (ACR) policy setting, when enabled, allows automatic reconnection by the same client after a connection has been interrupted. Allowing automatic client reconnect allows users to resume working where they were interrupted when a connection was broken. Automatic reconnection detects broken connections and then reconnects the users to their sessions. |
||||||||||||
Session reconnects |
Indicates the number of times this session reconnected. |
Number |
This measure includes only those times a user reconnected to a disconnected session by mechanisms other than the ACR setting. |
||||||||||||
Client SRTT |
Indicates the RTT (round-trip time or screen lag time) of this session smoothed over the client side connection.
|
MSecs |
TCP implementations attempt to predict future round-trip times by sampling the behavior of packets sent over a connection and averaging those samples into a ‘‘smoothed’’ round-trip time estimate, SRTT. When a packet is sent over a TCP connection, the sender times how long it takes for it to be acknowledged, producing a sequence, S, of round-trip time samples: s1, s2, s3.... With each new sample, si, the new SRTT is computed from the formula: SRTTi+1 = (α x SRTTi) + (1 − α )xsi Here, SRTTi is the current estimate of the round-trip time, SRTTi+1 is the new computed value, and α is a constant between 0 and 1 that controls how rapidly the SRTT adapts to change. The retransmission time-out (RTOi), the amount of time the sender will wait for a given packet to be acknowledged, is computed from SRTTi. The formula is: RTOi = β x SRTTi Here, β is a constant, greater than 1, chosen such that there is an acceptably small probability that the round-trip time for the packet will exceed RTOi. These measures are reported only for application sessions, and not desktop sessions. |
||||||||||||
Server SRTT |
Indicates the RTT (round-trip time or screen lag time) of this session, smoothed over the server side connection. |
MSecs |
|||||||||||||
Client side NS delay |
Indicates the average latency experienced by this session, which was caused by the ADC appliance when ICA traffic flowed from client network to server network. |
Msecs |
A high value for these measures indicates a processing bottleneck with the ADC appliance. If the value of the WAN latency measure is abnormally high for an application session, you can compare the value of the Client side NS delay measure with the value of the Client jitter measure for that session to determine what could have caused network delays on the client side - a ADC appliance that was slow in processing traffic from the client? or a traffic congestion on the client side? If the value of the DC latency measure is abnormally high for an application session, you can compare the value of the Server side NS delay measure with the value of the Server jitter measure for that session to determine what could have caused network delays on the server side - a ADC appliance that was slow in processing traffic from the server? or a traffic congestion on the server network? |
||||||||||||
Server side NS delay |
Indicates the average latency experienced by this session, which was caused by the ADC appliance when ICA traffic flowed from server network to client network. |
Msecs |
|||||||||||||
Client jitter |
Indicates the client side jitter. |
Msecs |
Jitter is defined as a variation in the delay of received packets. At the sending side, packets are sent in a continuous stream with the packets spaced evenly apart. Due to network congestion, improper queuing, or configuration errors, this steady stream can become lumpy, or the delay between each packet can vary instead of remaining constant. A high value for these measures therefore is indicative of a long time gap between ICA packets. To know where the delay is longer – whether on the client side or on the server side - compare the value of the Client jitter measure with that of the Server jitter measure. Also, if the value of the Round trip time – RTT measure is abnormally high for a user, then you can compare the values of these measures with that of the WAN latency and DC latency measures to know what is causing the problem – the client side network? or the server side network? These measures are reported only for application sessions, and not desktop sessions. |
||||||||||||
Server jitter |
Indicates the server side jitter. |
Msecs |
Use the detailed diagnosis of the Active applications measure to know which applications are being actively used by a user session. The application startup time, startup duration, application uptime, and module path are displayed for each active application. From this, you can quickly identify applications that took too long to startup and applications that restarted recently, and initiate investigations to find the reasons for the same.
Figure 14 : The detailed diagnosis of the Active applications measure reported by the Citrix HDX User Active Sessions test
Use the detailed diagnosis of the Application launches measure to know which applications were launched during a user session.
Figure 15 : The detailed diagnosis of the Application launches measure reported by the Citrix HDX User Active Sessions test
The detailed diagnosis of the Session status measure provides additional details of a user session. If the status of a session is abnormal, you can use these details to know from which client the user is connecting, the client type and version, which server the user is connecting to, the start time, and the uptime of the session. This will help in troubleshooting the abnormal session status.
Figure 16 : The detailed diagnosis of the Session status measure reported by the Citrix HDX User Active Sessions test