Add a backend server

Expanding a cluster in a multi-container backend architecture with a new server is similar to the WEKA multi-container backend installation process.

Adding a server to the cluster includes discovering the existing cluster resources, generating the resource files, creating containers using the resource files, and adding the SSDs to the new server.

Before you begin

  1. Review the system dashboard and ensure that the system is operational and does not indicate any alarms.

  2. Discover the number of cores for each container type in the cluster server.

weka local resources -C drives0 |grep -c DRIVES 

weka local resources -C compute0 |grep -c COMPUTE

weka local resources -C frontend0 |grep -c FRONTEND
  1. Discover the Management IPs of one of the containers. In a high-availability system, more than one IP exists.

weka local resources -C drives0 | grep "Management IPs"
  1. Ensure that the new backend server meets the requirements and is available for installation.

  2. Download from get.weka.io the same WEKA software version as in the existing WEKA cluster servers.

To learn how about the options of the commands in the following procedure, see the related topics.

Procedure

  1. Install the WEKA software on the new backend server.

  2. Remove the default container from the new backend server.

weka local stop default && weka local rm -f default
  1. Download the Weka tools from the GitHub repository.

cd ~
git clone https://github.com/weka/tools/
cd ~/tools/install/
  1. Generate the resource files with the same network devices and options as the existing Weka cluster servers.

./resources_generator.py --net <net-devices> [options]
Example of a high-availability system with two network devices
./resources_generator.py --net ens4 ens5 --compute-dedicated-cores 3 --drive-dedicated-cores 2 --frontend-dedicated-cores 2
Example of a high-availability system with two network devices and a gateway

Add to the --net option the following for each network device: <net device name>/<net device IP>/<net mask>/<gateway IP>

./resources_generator.py --net enp197s0np0/172.25.5.132/16/172.25.5.2 enp129s0np0/172.25.6.132/16/172.25.5.2 --compute-dedicated-cores 12 --drive-dedicated-cores 12 --frontend-dedicated-cores 1
  1. Create the drive, compute, and frontend containers, and join the new server's containers to the existing cluster.

    • 

In management-ips, specify the management IP address of the new server joining the cluster. Specify two or more comma-separated management IP addresses in a high-availability system.



    • In join-ips, specify the management IP of one of the servers in the cluster to join.

weka local setup container --name drives0 --resources-path <path>/drives0.json --management-ips=<management IPs of the new server> --join-ips=<management IP of the existing server>

weka local setup container --name compute0 --resources-path <path>/compute0.json --management-ips=<management IPs of the new server> --join-ips=<management IP of the existing server>

weka local setup container --name frontend0 --resources-path <path>/frontend0.json --management-ips=<management IPs of the new server> --join-ips=<management IP of the existing server>
  1. Verify that the server is added to the cluster successfully. Run weka local ps.

[root@weka8 ~]# weka local ps
CONTAINER  STATE    DISABLED  UPTIME    MONITORING  PERSISTENT  PORT   PID    STATUS  VERSION    LAST FAILURE
compute0   Running  False     0:09:08h  True        True        14300  26441  Ready   4.2.0.153
drives0    Running  False     0:09:41h  True        True        14000  25295  Ready   4.2.0.153
frontend0  Running  False     0:08:35h  True        True        14200  27911  Ready   4.2.0.153
  1. Configure the SSD drives on the drive container.

weka cluster drive add <container-id> <device-paths>

Related topics

WEKA cluster installation on bare metal servers (see Path C: Manual installation and configuration)