Add clients to an on-premises WEKA cluster
This page describes how to add clients to a bare-metal cluster.
Cgroups configuration
Clients run applications that access the WEKA filesystem but do not contribute CPUs or drives to the cluster. They connect solely to use the filesystems.
By default, WEKA uses Cgroups to limit or isolate resources for its exclusive use, such as assigning specific CPUs.
Cgroups (Control Groups) is a Linux kernel feature that allows you to limit, prioritize, and isolate a collection of processes' resource usage (CPU, memory, disk I/O, network). It helps allocate resources among user-defined groups of tasks and manage their performance effectively.
Versions of Cgroups:
CgroupsV1: Uses multiple hierarchies for different resource controllers, offering fine-grained control but with increased complexity.
CgroupsV2: Combines all resource controllers into a single unified hierarchy, simplifying management and providing better resource isolation and a more consistent interface.
Hybrid mode: If the OS is configured with hybrid mode (CgroupsV1 and CgroupsV2), WEKA defaults to using CgroupsV1.
WEKA requirements:
Backends and clients serving protocols: Must run on an OS with CgroupsV1 support. CgroupsV2 is supported on backends and clients but is incompatible with protocol cluster deployments.
Cgroups mode compatibility: When setting up Cgroups on clients or backends, ensure that the Cgroups configuration (whether using CgroupsV1 or CgroupsV2) aligns with the operating system's capabilities and configuration.
Cgroups configuration and compatibility
The configuration of Cgroups depends on the installed operating system, and it is important that the cluster server settings match the OS configuration to ensure proper resource management and compatibility.
Customers using a supported OS with CgroupsV2 or wanting to modify the Cgroups usage can set the cgroups usage during the agent installation or by editing the service configuration file. The specified mode must match the existing Cgroups configuration in the OS.
The Cgroups setting includes the following modes:
auto
: WEKA tries using CgroupsV1 (default). If it fails, the Cgroups is set to none automatically.force
: WEKA uses CgroupsV1. If the OS does not support it, WEKA fails.force_v2
: WEKA uses CgroupsV2. If the OS does not support it, WEKA fails. This mode is not supported in protocol cluster deployments.none
: WEKA never uses Cgroups, even if it runs on an OS with CgroupsV1.
Set the Cgroups mode during the client or backend installation
In the installation command line, specify the required Cgroups mode (WEKA_CGROUPS_MODE
).
Example:
Set the Cgroups mode in the service configuration file
You can set the Cgroups mode in the service configuration file for clients and backends.
Open the service configuration file
/etc/wekaio/service.conf
and add one of the following:cgroups_mode=auto
cgroups_mode=force
cgroups_mode=force_v2
cgroups_mode=none
Restart the WEKA agent service.
Restart the containers to apply the Cgroups settings:
Run
weka local restart
to restart all containers, or specify a container, for example,weka local restart client
for the client container. If WEKA is mounted, unmount it before restarting.
Verify the Cgroups settings by running the
weka local status
command.
Example:
Add a stateless client to the cluster
A stateless client is a client that does not persistently store any software or configuration state locally. Instead, it dynamically installs the required software and configuration each time it interacts with the WEKA system. This approach simplifies client management, eliminates the need to join the client to the cluster, and allows for deployment on lightweight, diskless servers.
To enable a stateless client to use the WEKA filesystem, the mount
command is used. This command installs the WEKA software automatically and configures the client without requiring manual intervention.
Before you begin
Ensure each client has a unique IP address and fully qualified domain name (FQDN) for proper cluster identification.
Procedure
Install the WEKA agent (One-time setup): Install the WEKA agent from one of the backend instances. This step prepares the client to interact with the WEKA system. Run the following command:
Create a mount point (one-time setup): Create a directory on the client system where the WEKA filesystem will be mounted. For example:
Mount the WEKA filesystem: Use the
mount
command to attach the WEKA filesystem to the client. For example:During the first mount, the required WEKA software is installed, and the client is configured automatically.
Additional configuration
Automatic mounting at boot: To configure the client OS to automatically mount the filesystem at boot time, you can use traditional methods or configure
autofs
. For more details, refer to the relevant documentation on Mount a filesystem using the stateless mount mode Mount a filesystem using the traditional method or Mount filesystems using autofs.Diskless deployment: Stateless clients can be deployed on by storing the WEKA client software in RAM and using an NFS mount for traces. For assistance with this setup, contact the Customer Success Team.
Related topic
Mount a filesystem using the stateless mount mode (for detailed mount and configuration options)
Add a persistent client (stateful client) to the cluster
A persistent client (or stateful client) is a client that remains an integral part of the cluster. It does not contribute resources to the cluster but is used for mounting filesystems or serving purposes, such as NFS/SMB servers, that require continuous availability. Adding persistent clients ensures that these servers are always up and accessible for file system operations.
There are two methods for adding a persistent client to the cluster: a shorter, streamlined option and a longer, more detailed option. Both methods achieve the same outcome but offer different levels of flexibility and control.
Shorter option: Quick and efficient for most users. It sets up and joins the container with minimal configuration, ideal for persistent clients that do not require specific resource allocations or custom networking.
Longer option: Provides more control and flexibility, allowing for detailed configuration of the client, making it suitable for environments with specific performance or network requirements.
Choose the method that best fits your needs based on the level of customization required.
Option 1: Shorter method (recommended for most use cases)
This method sets up the client with all required resources in a single step and self-joins the container to the cluster using its management and join IPs.
Procedure
Setup container locally with resources This step sets up the client with all necessary resources, such as cores, memory, networking, and ports.
Example:
join-ips
: The IP address for joining the cluster.base-port
: The base port for container communication.cores
: The number of cores to allocate.cores-ids
: The cores' identifiers.only-frontend-cores
: Indicates that only frontend cores are used.
Join the container to the cluster After setting up the container, apply the configuration to finalize the process.
Example:
Option 2: longer method (more control and flexibility)
This method involves more detailed steps, allowing you to manually set up the client with specific configurations, including core allocation, networking settings, and container setup.
Procedure
Install the WEKA software
Install the WEKA software on the client by running the
install.sh
script after downloading the tarball from get.weka.io. Follow the instructions in the Install tab to complete the installation.
All clients in a WEKA system cluster must use the same software version as the backends or a maximum of one version back. The backend containers must run the same WEKA software version except during upgrades (as managed by the upgrade process).
Join the cluster
Once the client is in stem mode, use the following command to add it to the cluster.
Example:
backend-hostname
: The hostname (FQDN) or IP address of an existing backend instance.client-hostname
: The unique hostname (FQDN) of the client to add.
Once this step is complete, the
container-id
of the newly added container will be displayed. Record it for use in the following steps.Configure the container as a client
After adding the client to the cluster, configure it by setting the number of cores and frontend-dedicated cores.
Example:
container-id
: The unique identifier of the container.cores
: The number of physical cores to allocate to the client.frontend-dedicated-cores
: The number of physical cores dedicated to frontend processes (must matchcores
for clients). You can set up to 19 cores.
Configure client networking
If needed, configure the client’s network interface for high-performance communication with the WEKA cluster. (For UDP, this step is not needed.)
When configuring an InfiniBand client, do not pass the
--ips
,--netmask
, or--gateway
parameters.InfiniBand and Ethernet clients can only join a cluster with the same network technology connectivity. However, it is possible to mix InfiniBand and Ethernet clients in the same cluster as long as the cluster backends are connected to both network technologies.
Example:
container-id
: A valid identifier for the container to add to the cluster.device
: A valid network interface device name (for example,eth1
).ips
: A valid IP address for the new interface.gateway
: The IP address of the default routing gateway. The gateway must be within the same IP network as the providedips
, as defined by thenetmask
. Not applicable for IB / L2 non-routable networks.netmask
: The number of bits that define the network ID (CIDR notation). For example, a netmask of255.255.0.0
corresponds to16
netmask bits.
Apply the container configuration
After configuring the container and networking, apply the changes to activate the client container.
Example:
Last updated