Improving the performance of legacy applications with quick wins

March 22, 2021
|
3
minute read
Blog
Written By
Olivia Baker
“Customers are disgruntled over the page load speed”, a complaint that echos amongst many of our client’s legacy users. We realise that when it comes to making improvements to legacy systems, it can be difficult to justify the investment. This may be because there’s a plan to phase out the application or it may seem that there is no feasible way of making performance improvements with older code.

But...improving the performance of your legacy application doesn’t have to be a big investment - we improved the page load time of a legacy application by 50% in 2 days, just by tackling the quick wins. 

How did we do it? To discover your quick wins, begin with a goal, then leverage modern technology to find your surface level-problems and develop simple solutions. 

Begin with a goal,

Having an objective to guide and direct your investigation will help focus your efforts and provide you with a starting point. In this case, our goal was to understand why certain pages took significantly longer to load than others, especially when similar data was being loaded elsewhere in the application with no problems. 

Leverage modern technology

Find a tool that will help you achieve what you need with the limitation of the code you are working with. We were unable to perform local testing, had limited access to our data source and all development diagnosis had to be performed by logging out of the UAT server. We utilised NewRelic to trace, capture and analyse surface level functions as it is easy to get set up and it runs with minimal impact. NewRelic also has built-in support for automatically capturing basic information about web requests, this includes information such as the length of time taken to complete long, external calls (like database requests) without us needing to handle the raw data or run other programs. 

Find your surface-level problems, 

The aim here is to find and solve problems that will give you the most return on investment. We began by adding traces to relevant functions, these are generally functions that seem like they’re doing something complex enough to drive the page load time up. Sometimes it can be a guessing game, sometimes it’s fairly obvious. Our general rule is that if there is any function that makes a call to another service or database, put a trace on it. Once your traces are in place, run your functions and perform some analysis to find the key culprits impacting your performance time. In this case, the culprits were caching, database queries and logging operations.

Develop simple solutions.

Performance tuning can be a never-ending battle, it’s important to remember not to over-optimise and to stick to performance fixes that don’t come at the cost of increased complexity. Ensure that you are aware of the intent of the code and any dependencies it may have before making changes. Try and avoid any performance changes that will alter business logic or change the user experience of the application. Make sure you don’t get bogged down on any individual change and stay focused on the changes that impact your real pain point. In this case, we optimised the caching, tweaked wasteful database queries and changed logging so it didn’t affect wait times. This enabled us to reduce the page load speed from 2 minutes to 30 seconds. 

By keeping your solutions straightforward and utilising tools to enhance your investigation, there is a good chance you will discover a number of improvements that can be made without having to invest in more significant changes. 

In saying this, sometimes problems get complicated and require out of the box thinking to tackle them, and without past experience, it can be a challenge to spot even the simple stuff. If you’d like us to help you identify the quick wins, or even tackle the harder stuff - get in touch!

Author

Development
Olivia Baker
With over 10 years of experience in organisations across the world, ranging from small startups to multinationals, her development life has been pushed forward on a strong foundation of guiding philosophies and practices.