How to set Automatic Horizontal Scaling

 

CloudJiffy allows you to automatically scale your projects horizontally, changing the number of web/application server nodes in your environment. All of the newly added nodes are created at different hardware servers, ensuring even more reliability and high-availability.

Automatic horizontal scaling is implemented with the help of the tunable triggers, which are custom conditions for nodes addition (scale out) and removal (scale in) based on the load. Every minute the platform analyses the average consumption of the resources (for the number of minutes specified within the trigger) to decide if the node count adjustment is required.

Herewith, the statistic is gathered for the whole layer, so if there are three nodes, which are loaded for 20%, 50%, and 20% respectively, the calculated average value is 30%. Also, the scale in and out conditions are independent, i.e. the analyzed period for one is not reset when another one is executed.

Below, we’ll overview how to:

  • set triggers for automatic scaling
  • view triggers execution history

To configure a trigger for the automatic horizontal scaling, follow the steps below.

 
1. Click the Settings button for the required environment.
 
 
2. In the opened tab, navigate to the Monitoring > Auto Horizontal Scaling section, where you can see a list of scaling triggers configured for the current environment (if any).
 
 

Use the buttons at the tools panel to manage auto horizontal scaling for the environment:

  • Add - creates a new trigger
  • Edit - adjusts the existing trigger
  • Remove - deletes unrequired trigger
  • Refresh - updates the displayed list of scaling triggers

Click Add to proceed.

3. Select the required environment layer from the drop-down list and choose the resource type to monitor via one of the appropriate tabs (CPUMemoryNetworkDisk I/ODisk IOPS).

 

4. The graph to the right shows the statistics on the selected resource consumption. You can choose the required period for displayed data (up to one week) using the appropriate drop-down list. Herewith, if needed, you can enable/disable the statistics' Auto Refresh function.

Also, you can hover over the graph to see the exact amount of used resources for a particular moment. Use this information to set up proper conditions for your triggers.

5. Each trigger has Add and Remove Nodes conditions, which can be enabled with the corresponding check-boxes right before the title.

 

Both of them are configured similarly:

  • When loading is more (less) than - the upper (lower) limit in percentage for the average load (i.e. executes trigger if exceeded)

 

  • For at least - the number of minutes the average consumption is calculated for (up to one hour with a 5 minutes step, i.e. 151015, etc.)
  • Scale out (in) to - the maximum (minimum) number of nodes for the layer, that can be configured due to automatic horizontal scaling
  • Scale by - the count of nodes that are to be added/removed at a time upon trigger’s execution

When configuring a trigger, we recommend taking into consideration the scaling mode of the layer. For example, you should set lower loading percent in the Add Nodes trigger for the stateful mode, as content cloning requires some time (especially for containers with a lot of data) and you can reach resources limit before a new node is created.

6. You automatically receive an email notification on the configured auto horizontal scaling trigger activity by default; however, if needed, you can disable it with the appropriate Send Email Notifications switcher.

7. At the bottom of the form you have the following buttons:

  • Undo Changes - returns to the previous state (for editing only)
  • Close - exits the dialog without changes
  • Apply (Add) - confirms changes for the trigger

Select the required option to finish trigger creation (adjustment).

You can view the history of scaling triggers execution for a particular environment.

In the example below, we’ll apply high load for 5 minutes (see the RAM usage statistics in the image below) on the application server with the following triggers configured:

  • add node when average RAM load is more than 65% for at least 5 minutes
  • remove node when average RAM load is less than 20% for at least 10 minutes

Now, let’s see the automatic horizontal scaling behaviour:

  1. Navigate to the Settings > Monitoring > Events History section and choose the Horizontal Scaling option within the Type drop-down list.

Additionally, you can customize the period to display triggers activity for via the appropriate From and To fields.

2. The following details are provided within the list:

  • Date and time of the trigger execution
  • Action performed (Add or Remove Nodes)
  • Nodes type the scaling has been applied to
  • Info about trigger execution condition

Additionally, upon hovering over the particular record, you can additionally check the Loading Value (resource usage on the moment of execution) and Node Count (resulting number of nodes).

The Add and Remove Nodes triggers are independent, so the removal condition (average load less than 20% for at least 10 minutes) is not reset and continued to check even after a new node addition. Such an approach provides a quicker detection of the sufficient average load during the specified interval. It’s recommended to set a significant difference between scaling out and scaling in limits to avoid often topology change.

That’s it! In such a way, you can configure a set of tunable triggers to ensure your application performance and track automatic horizontal scaling activity directly via the dashboard.


Was this article helpful?

mood_bad Dislike 0
mood Like 1
visibility Views: 15536