Uploaded image for project: 'Red Hat 3scale API Management'
  1. Red Hat 3scale API Management
  2. THREESCALE-4515

Liquid statement looping through large number of services introduces unacceptable page load time

XMLWordPrintable

    • Not Started
    • Not Started
    • Not Started
    • Not Started
    • Not Started
    • Not Started
    • -
    • Hide
      • Create a tenant with >100 services
      • Create >1 plan per service
      • Create >1 metric/method per service
      • Create >1 limit per plan
      • Publish all plans
      • Create a test page in the CMS with the liquid statement attached to this issue
      • Publish test page and try to load in the browser
      Show
      Create a tenant with >100 services Create >1 plan per service Create >1 metric/method per service Create >1 limit per plan Publish all plans Create a test page in the CMS with the liquid statement attached to this issue Publish test page and try to load in the browser
    • 3scale 2020-03-09, 3scale 2020-03-23, Invalid Sprint

      Please don't start working on this issue before THREESCALE-4053 and THREESCALE-401 are done.

      Update 18 September 2024: THREESCALE-401 was closed as "will not do".

      Current behaviour

      Looping through all service objects then all plan objects then any children objects of the plan causes a very long response time in the developer portal page load time for the user.

      Expected behaviour

      Looping through any number of objects results in an acceptable response time from the application and thus doesn't significantly impact page load time. The alternative would be to provide some way for the API provider to not have to loop through all objects and therefore reduce latency incurred by the liquid evaluation.

      Some context

      The customer wants to be able to render all application plans for all services on a single page but, due to the large number of services and plans within those services and metrics & limits within those plans, all those nested loops incur a huge amount of processing, hence the timeout experienced. The customer expects this to be possible in a reasonable amount of time from a UX point of view so the question is: "If we deem this to be unreasonable then we should decide what is supported and document that and provide examples?" OR "If we want to support this, is it a case of upgrading to Liquid 4, paginating the service collection and exposing that pagination via Liquid tags to the user?" Maybe once we are able to answer this it might be clearer how to define and move the issue forward.

      Dev Notes
      Upgrade liquid and implement pagination in the controller.
      Customer is on SaaS. Pagination is the key. Liquid paginate. Pagination is only available in built-in pages.
      The solution seems to be to upgrade Liquid.
      Please read all comments before starting work on this issue.

      Definition/Investigation

       We need to have some performance numbers:

      From there we need to isolate the components that make the generation slow.

      • Maybe we load too many objects, that are linked to the drop (plans, features, and nested drops of those objects)
      • Maybe it is totally normal that hundreds of objects can't be rendered in time (less than the web server, unicorn, timeout)
      • Maybe some SQL are too slow taking around 1 seconds to load an object, which could be multiplied thus ending with a timeout.

      Maybe it is a real issue with Liquid, fixed in further versions

      There are too many possibilities but those are the pointers we should start from.

        1. example.html.liquid
          0.5 kB
          Kevin Price
        2. Liquid 4.0 improve loop performance.png
          307 kB
          Marta Noya
        3. Screenshot 2020-02-17 at 15.28.57.png
          27 kB
          Kevin Price
        4. test-page.html.liquid
          0.6 kB
          Kevin Price

              Unassigned Unassigned
              rhn-support-keprice Kevin Price
              Dominik Hlavac Duran Dominik Hlavac Duran
              Votes:
              0 Vote for this issue
              Watchers:
              9 Start watching this issue

                Created:
                Updated:
                Resolved: