Welcome!

Cognitive Computing Authors: Yeshim Deniz, Pat Romanski, Roger Strukhoff, Elizabeth White, Jason Bloomberg

Related Topics: Microservices Expo, Industrial IoT, Cognitive Computing , Agile Computing

Microservices Expo: Article

Reach Higher Scalability from Your Web Applications

Tuning vs. adding additional hardware

When the performance of a web application starts to degrade, often IT managers jump to the conclusion that more hardware is required. This increased infrastructure can be expensive and may not even solve the underlying problem. Let's talk about tuning as a solution to higher scalability. It's been debated as to whether tuning is a science or an art but we can all agree on the goal: alleviate bottlenecks so that the web application can scale to a higher workload. Tuning is more efficient and cost effective than adding more hardware to your deployment. However, you need to have the right tools and expertise in place in order to successfully tune an environment.

Hardware servers are restricted to their physical resources (IO, memory, CPU, etc.). With OS tuning, there are certain buffers and network configurations you can open up to increase overall capacity. Software servers are even more configurable because they use their own thread pools, caching, memory management, connection pools, etc. All of these software resources do actually run on a hardware server, but tuning software servers can allow it to take more or less advantage of hardware resources.

Tuning can allow or restrict throughput to an environment. Imagine a funnel. The large opening is on top, the small opening is on the bottom. A properly tuned environment will have more processing capacity on the front end (larger end of the funnel) and less dedicated processing at the end. This approach is used for a couple of reasons; one - typically the front end of a deployment does more lightweight processing (webserver) and the back end (database) does more CPU intensive and shared resource processing. You want to allow as many requests to be processed on the front end without flooding the back end.

Most people don't know where to begin in the tuning process, so here are some tips to point you in the right direction. First you will need a load test solution that generates a realistic load. The solution also needs embedded monitoring for your entire deployment. For starters, don't change a single thing. Simply identify and document all the configurable settings for each software server in the environment. You want to be especially aware of the settings that affect throughput - giving the server more or less processing power. For example, a webserver's worker threads or database and application servers' memory/threads/pools/buffers can affect the throughput. Once you have all the settings documented, start executing your load tests and monitoring all the configurable resources. Run the tests up to the points of degradation; don't try to identify saturation points while the test is running as this is far too complicated. Once degradation occurs, stop the test and graph out your monitors. Identify the first major bottleneck, make a change to alleviate that bottleneck, and rerun your test.

Keep to a methodical approach and change only one variable at a time. It's also greatly helpful if the tool has a built-in comparison analysis engine that visually shows you how your one change affected the scalability of your test. Use the load to validate all of your changes. When you are tuning, you need to essentially be aware of two very important statistics: throughput and response time. This is where the art comes in. You need to tune the environment for maximum capacity without allocating too much "work" for the underlying hardware to handle. If you make this mistake, and we all do, you'll see the response times increase. Remember, there are limitations in infrastructure. Nothing is infinite. Tune until your workload is using up most of the hardware resources while delivering acceptable response times.

Tuning can save time, save money, and save the planet (greener deployments use less electricity). The costs associated with more hardware are not just in dollars though, it's also in administration and maintenance. Also, each new piece of equipment is another potential point of failure (we've all seen machine's go down due to myriad reasons). Tuning is typically the best first approach to address any performance degradation. Expertise is in knowing where to look.

More Stories By Rebecca Clinard

Rebecca Clinard is a Senior Performance Engineer at Neotys, a provider of load testing software for Web applications. Previously, she worked as a web application performance engineer for Bowstreet, Fidelity Investments, Bottomline Technologies and Timberland companies, industries spanning retail, financial services, insurance and manufacturing. Her expertise lies in creating realistic load tests and performance tuning multi-tier deployments. She has been orchestrating and conducting performance tests since 2001. Clinard graduated from University of New Hampshire with a BS and also holds a UNIX Certificate from Worcester Polytechnic Institute.

Comments (0)

Share your thoughts on this story.

Add your comment
You must be signed in to add a comment. Sign-in | Register

In accordance with our Comment Policy, we encourage comments that are on topic, relevant and to-the-point. We will remove comments that include profanity, personal attacks, racial slurs, threats of violence, or other inappropriate material that violates our Terms and Conditions, and will block users who make repeated violations. We ask all readers to expect diversity of opinion and to treat one another with dignity and respect.


IoT & Smart Cities Stories
@CloudEXPO and @ExpoDX, two of the most influential technology events in the world, have hosted hundreds of sponsors and exhibitors since our launch 10 years ago. @CloudEXPO and @ExpoDX New York and Silicon Valley provide a full year of face-to-face marketing opportunities for your company. Each sponsorship and exhibit package comes with pre and post-show marketing programs. By sponsoring and exhibiting in New York and Silicon Valley, you reach a full complement of decision makers and buyers in ...
There are many examples of disruption in consumer space – Uber disrupting the cab industry, Airbnb disrupting the hospitality industry and so on; but have you wondered who is disrupting support and operations? AISERA helps make businesses and customers successful by offering consumer-like user experience for support and operations. We have built the world’s first AI-driven IT / HR / Cloud / Customer Support and Operations solution.
LogRocket helps product teams develop better experiences for users by recording videos of user sessions with logs and network data. It identifies UX problems and reveals the root cause of every bug. LogRocket presents impactful errors on a website, and how to reproduce it. With LogRocket, users can replay problems.
Data Theorem is a leading provider of modern application security. Its core mission is to analyze and secure any modern application anytime, anywhere. The Data Theorem Analyzer Engine continuously scans APIs and mobile applications in search of security flaws and data privacy gaps. Data Theorem products help organizations build safer applications that maximize data security and brand protection. The company has detected more than 300 million application eavesdropping incidents and currently secu...
Rafay enables developers to automate the distribution, operations, cross-region scaling and lifecycle management of containerized microservices across public and private clouds, and service provider networks. Rafay's platform is built around foundational elements that together deliver an optimal abstraction layer across disparate infrastructure, making it easy for developers to scale and operate applications across any number of locations or regions. Consumed as a service, Rafay's platform elimi...
Two weeks ago (November 3-5), I attended the Cloud Expo Silicon Valley as a speaker, where I presented on the security and privacy due diligence requirements for cloud solutions. Cloud security is a topical issue for every CIO, CISO, and technology buyer. Decision-makers are always looking for insights on how to mitigate the security risks of implementing and using cloud solutions. Based on the presentation topics covered at the conference, as well as the general discussions heard between sessio...
Growth hacking is common for startups to make unheard-of progress in building their business. Career Hacks can help Geek Girls and those who support them (yes, that's you too, Dad!) to excel in this typically male-dominated world. Get ready to learn the facts: Is there a bias against women in the tech / developer communities? Why are women 50% of the workforce, but hold only 24% of the STEM or IT positions? Some beginnings of what to do about it! In her Day 2 Keynote at 17th Cloud Expo, Sandy Ca...
New competitors, disruptive technologies, and growing expectations are pushing every business to both adopt and deliver new digital services. This ‘Digital Transformation’ demands rapid delivery and continuous iteration of new competitive services via multiple channels, which in turn demands new service delivery techniques – including DevOps. In this power panel at @DevOpsSummit 20th Cloud Expo, moderated by DevOps Conference Co-Chair Andi Mann, panelists examined how DevOps helps to meet the de...
According to Forrester Research, every business will become either a digital predator or digital prey by 2020. To avoid demise, organizations must rapidly create new sources of value in their end-to-end customer experiences. True digital predators also must break down information and process silos and extend digital transformation initiatives to empower employees with the digital resources needed to win, serve, and retain customers.
In his keynote at 18th Cloud Expo, Andrew Keys, Co-Founder of ConsenSys Enterprise, will provide an overview of the evolution of the Internet and the Database and the future of their combination – the Blockchain. Andrew Keys is Co-Founder of ConsenSys Enterprise. He comes to ConsenSys Enterprise with capital markets, technology and entrepreneurial experience. Previously, he worked for UBS investment bank in equities analysis. Later, he was responsible for the creation and distribution of life ...