Report Desk: Understanding Timeout and Strikeout Scenarios

Report Desk: Understanding Timeout and Strikeout Scenarios

Release Date: 2/22/2024
Versions: Elliott V8.6 and Up

Background: Report Desk Impact on the Database Server

Report Desk sessions are run on the user's workstation -- that is to say, the creation, formatting, and delivery of the reports are done on the client machine.  Whenever report data is needed, a request is shipped off to the database server (usually a separate, more powerful computer), where database access occurs and the results are sent back to the client for processing.  This type of client/server processing spreads the workload among multiple computers while minimizing network traffic.

The request to the server is limited by a timeout on the client side.  If no response is received from the server after the specified number of seconds, the client software assumes the server will not respond and returns control to the user who can decide how to handle the timeout.  Ideally, the server will see that the client has timed out and will stop any further processing of the request.  But there are some situations where the server will continue processing the request even though the client has given up.  Obviously, Elliott tries to minimize those scenarios.

Two Timeout Values

Elliott specifies two timeout values:
  • An initial number of seconds for processing a report.
  • An extended number of seconds that can be used to retry a report that has just timed out.
These values can be set globally, by using the Elliott Configuration utility.  See the Report Desk tab described in this article:  Elliott v8.6 Configuration Utility (EL860CF.EXE) .  Your Elliott administrator can update these values as needed.

Each report can have its own unique timeout values that will override the global values.  See the following article for details: Report Desk: Font, Margin and Timeout Overrides .  A privileged Report Desk user (one who can modify reports) can specify these overrides in the Report Designer as needed.

Two Strikes and You're Out!

Most of the time, your report requests will process quickly and have minimum impact on the database server.  However, it is possible to start long reports that can negatively impact the server.   When a timeout occurs, or when a user cancels a report during the initial database record selection process, it is possible for an unusable database request to continue to run on the database server.

We are introducing the concept of Report Desk strikes to help in these scenarios.

When a timeout occurs, or when a user cancels a report during the initial database record selection process, the current Report Desk session is charged with a strike.  If the strike count reaches two strikes for the session, the Report Desk session will be cancelled and the user will be returned to the list of reports.  Elliott cancels the session to help prevent the user from unwittingly flooding the server with unusable requests.  

Note that whenever a report completes its initial record selection, the strike count is reset to zero.

Accumulating Strikes

When a timeout initially occurs, a message similar to the following is shown:


Notice "STRIKE ONE!" in the title of the message.  The timeout number of seconds is shown on the first line of the message (here set to 2 seconds for demonstration purposes).  At this point, there is one strike against this report session.

If you press the Yes button, the report will be retried with the extended timeout number of seconds.  Pressing No returns the user to the input parameters screen.  In either case, the session has one strike against it.

Another way to get a strike is to press the Cancel button during the initial record selection process.  Doing that will result in this message:


If you press Yes, you will get a strike.

When you get two strikes against the session, you will get this message:


Notice "STRIKE TWO!" in the title of the message.  After you press OK, the Report Desk session will terminate and you will return to the list of available reports.  There is nothing to stop the user from trying to run the same report again.  However, it would be better to change one or more input parameters to reduce the time to produce the report.

JEG
EL860RD, ELRW_SYRPTUDR


    • Related Articles

    • Report Desk: Documentation Roadmap

      Release Date: 4/28/23 Version: 8.6 Setup and Configuration The following articles explain initial setup and ongoing maintenance of Report Desk: Report Desk: Setup and Configuration : Initial installation and ongoing maintenance. Elliott V8.6 ...
    • Report Desk: Font, Margin and Timeout Overrides

      Released: TBA Version 8.6 Most of the time, the default Report Desk settings (located in EL860.Cfg and maintained by EL860CF.Exe) will work for your reports. But certain reports may need a special font, or a broader point size range, or different ...
    • Report Desk: Understanding SumValuesInGroup Aggregates

      Release Date: 10/18/2022 Elliott Version: 8.6 and Higher Background The Sum aggregate is useful for calculating the sum of a value in all report rows. For example, a detail line in a report might contain a column for Quantity On Hand. You might use ...
    • Report Desk: Record Thresholds

      Release date: 4/28/23 Version: 8.6 Background Report Desk reports can be CPU intensive and potentially run for a long time, depending on the complexity of the report, the output format and the number of records involved. Accordingly, when a user runs ...
    • Report Desk: Report Documentation

      Release Date: 6/8/2021 Elliott Version: 8.6 & Up Displaying Report Documentation There are two places from which you can view the available documentation for a report: From the list of reports: From the Report Desk Input Parameters screen: The Report ...