Increase Replication Threads on AhsayCBS
Article ID
Product Version
Operating System
Description
This document contains instructions on how to increase the number of available replication threads on an AhsayCBS backup server to improve the overall replication speed.
Default Setting
AhsayCBS supports multiple concurrent replication threads to enhance the performance of the replication process and ensure it does not negatively impact the overall performance of the AhsayCBS backup server.
Minimum replication threads=1
The maximum number of replication threads is determined using the following formula:
Maximum of replication threads = (Total number of CPU cores) / 8
For example, if the AhsayCBS server has a total of 8 CPU cores, then the number of concurrent backup sets to replication is 1. Conversely, if the AhsayCBS server has a total of 16 CPU cores, then the number of concurrent backup sets to replicate is 2.
Enhanced Setting
Starting from AhsayCBS v9.1.x or later, for underutilized AhsayCBS backup servers operating on high-performance hardware and storage configurations, with available spare network bandwidth capacity, there is an option to increase the maximum number of replication threads to match N, which represents the total number of CPU cores.
For instance, on an AhsayCBS server equipped with a 16-core CPU, up to 16 concurrent replication threads can be configured.
Please consider carefully before increasing the maximum number of concurrent replication threads on your AhsayCBS backup server. As this change could have a negative impact on your AhsayCBS backup server and therefore your backup service. For example:
- The AhsayCBS backup server could become unresponsive or sluggish.
- Slow AhsayOBM/AhsayACB backup/restore performance.
- Your AhsayOBM/AhsayACB clients may be unable to connect to the backup server, resulting in missed backups.
- The AhsayCBS replication server may become overloaded if it is unable to process the increased number of threads and data sent from the AhsayCBS backup server.
Solution
Assumptions:
- AhsayCBS v9.1.x or above is installed.
AhsayCBS Java heap size setting.
Increasing the number of concurrent replication threads will result in increased Java memory ussage. As a general rule of thumb, twice as many replication threads will utilize twice the amount of Java memory.
Therefore, it is highly recommended to increase your Java heap size setting before using a higher replication thread setting, if the peak Java memory usage on your AhsayCBS server is over 50% of the maximum Java heap size setting. (The peak Java memory usage can be obtained from [Monitoring]>[Dashboard]>[Memory]).
For example:
- If current maximum Java heap setting is 4096M and the peak Java memory usage exceeds 2048M, then you should consider increasing the maximum Java heap size up to 8196M (if your host server has extra RAM to spare without over allocating to starve your OS RAM requirements).
If current maximum Java heap setting is 4096M and the peak Java memory usage is only 1500M, you may not need any maximum Java heap size adjustment in the short term.
Please refer to the following Know-How article: Configure Java Heap Size for AhsayCBS
AhsayCBS installation path:
%CBS_INSTALL_PATH%
Windows: C:\Program Files\AhsayCBS
Linux/Unix: /usr/local/cbs
AhsayUBS: /ubs/mnt/eslsfw/obsr
Steps:
- Shutdown the AhsayCBS service.
- Using a text editor, open the %CBS_INSTALL_PATH%/conf/cbs.opt file.
Add the following setting to the end of the file and save:
com.ahsay.cbs.obs.config.Index.RepMaxThreads=true
- Restart the AhsayCBS service.
- Login to the AhsayCBS web management console.
Go to [Replication]>[Sending Data] and click on the "No. of backup sets to replicate concurrently" and select the number of replication threads you wish to configure.
Example: An AhsayCBS backup server with 16 core CPU