Linux

Overview

This section describes how to install and configure MetaDefender (MD) Cluster Control Center on supported Linux distributions. After installation, administrators can use MD Cluster Control Center to manage MD Cluster services from a centralized interface.

Prerequisites

Before installing the MD Cluster Control Center service, ensure the following requirements are met.

RequirementDescription
Operating SystemUbuntu 22.04+, Debian 12+, Rocky 9+, or RHEL 9+.
PrivilegesRoot or sudo privileges
Installation packageDebian/Ubuntu: md-cluster-control-center_<version>-1_amd64.deb Rocky/RHEL: md-cluster-control-center-<version>-1.x86_64.rpm
Network accessRequired port is open (default port: 8892).
DependenciesMD Cluster Identity Service and PostgreSQL must be installed and reachable from the Control Center host.
Disk spaceA minimum of 100 GB of available disk space is required.

Create the ignition file

Create an ignition file in YAML format. This file contains the credentials and connection settings required for the service.

The file must include the following keys:

KeyDescription
identity.hostIP address or domain name of the MD Cluster Identity Service host. Do not use localhost or 127.0.0.1.
identity.portPort used by MD Cluster Identity Service.
identity.connection_keyA 4-64 character alphanumeric string (a-z, A-Z, 0-9) that matches the Identity Service connection key.
database.hostIP address or domain name of the PostgreSQL server.
database.portPort used by PostgreSQL.
database.userPostgreSQL user. SUPERUSER privileges are required during the initial setup.
database.passwordPostgreSQL user password.
secure.encryption_keyA 32-character plain text key containing only lowercase letters and digits.

Example ignition file:

YAML
Copy

Save the ignition file to the following path on the target machine:

Bash
Copy

The ignition file contains sensitive credentials. This file can be safely deleted any time after the installation is complete.

Install the service

  1. Copy the installer file (.deb or .rpm) to the target machine.
  2. Open Terminal.
  3. Run the following command to start the installation:
Bash
Copy

Verify the service status

  1. Open Terminal and run the following command:
Bash
Copy
  1. Check the active (running) field in the output.
  2. If the service is not running, start it manually:
Bash
Copy
  1. To ensure the service starts automatically at system boot:
Bash
Copy

Service management

ActionCommand
Check service statussudo systemctl status md-cluster-control-center
Start servicesudo systemctl start md-cluster-control-center
Stop servicesudo systemctl stop md-cluster-control-center
Restart servicesudo systemctl restart md-cluster-control-center
Enable service at bootsudo systemctl enable md-cluster-control-center

Customize the service configuration

During installation, MD Cluster Control Center generates a configuration file at:

Bash
Copy

To customize the service behavior:

  1. Open the configuration file in a text editor such as nano.
Bash
Copy
  1. Modify the required settings according to your environment.
  2. Save the changes.
  3. Restart the service to apply the new settings.
Bash
Copy

Directory structure

  • /etc/opswat/md_cluster_control_center.yml: Service ignition file.
  • /etc/md-cluster-control-center/md_cluster_control_center.yml: Service configuration file.
  • /var/log/md-cluster-control-center/: Default log directory.
  • /var/lib/md-cluster-control-center/: Contains persistent data required for the service to maintain state across reboots.

Log files

To check the service logs, open the file: /var/log/md-cluster-control-center/control-center.log.

To check the system log, run the following in Terminal:

Bash
Copy

Uninstall the service

Bash
Copy

Troubleshooting

A. Service does not start

  1. Check the service status:
Bash
Copy
  1. Review recent service logs:
Bash
Copy
  1. Verify that the configuration file syntax is valid and restart the service after correcting any issue.

B. Installation fails

Possible causes:

  • Insufficient privileges.
  • Missing package dependencies.
  • Required uuid package is not installed.

Solution:

  • Ensure the installation commands are executed with sudo.
  • Install dependencies and rerun the package installation.
  • Confirm the package file matches the Linux distribution in use.

C. Control Center cannot connect to Identity Service

Possible causes:

  • identity.host is incorrect.
  • Network connectivity issues.
  • Firewall restrictions.
  • identity.connection_key does not match the value configured on MD Cluster Identity Service.

Solution:

  • Verify identity.host, identity.port, and identity.connection_key in the ignition or configuration file.
  • Ensure MD Cluster Identity Service is running and reachable from MD Cluster Control Center host.
  • Verify that firewall rules allow traffic between the two services.
  • Do not use localhost or 127.0.0.1 for identity.host unless both services run on the same host and the deployment explicitly supports it.

D. Database connection fails

Possible causes:

  • PostgreSQL is not running.
  • Database credentials are incorrect.
  • PostgreSQL is not reachable from MD Cluster Control Center host.

Solution:

  • Verify PostgreSQL service status.
  • Confirm database.host, database.port, database.user, and database.password are correct.
  • Ensure PostgreSQL accepts remote connections and firewall rules allow access.

Ignition file key reference

  • identity.host (Required)

    • Value type: string.
    • Description: IP address or domain name of the server hosting MD Cluster Identity Service. Avoid using localhost or 127.0.0.1.
  • identity.port (Required)

    • Value type: number.
    • Description: Port where MD Cluster Identity Service listens for client connections.
  • identity.connection_key (Required)

    • Value type: string.
    • Description: A 4-64 character string that contains only digits (0-9) and letters (a-z, A-Z). This value must match the connection key configured on MD Cluster Identity Service.
  • database.host (Required)

    • Value type: string.
    • Description: IP address or domain name of the PostgreSQL server.
  • database.port (Required)

    • Value type: number.
    • Description: Port where PostgreSQL listens for client connections.
  • database.user (Required)

    • Value type: string.
    • Description: PostgreSQL user account. SUPERUSER privilege is required during the initial setup.
  • database.password (Required)

    • Value type: string.
    • Description: PostgreSQL user password.
  • secure.encryption_key (Required)

    • Value type: string.
    • Description: A 32-character plain text key composed only of lowercase letters (a-z) and digits (0-9).
  • rest.port (optional)

    • Value type: number.
    • Description: Port where MD Cluster Control Center listens for incoming connections. Default value is 8892.
  • rest.log_path (optional)

    • Value type: string.
    • Description: Location where REST logs are written.
  • rest.log_level (optional)

    • Value type: string.
    • Description: Level of REST log messages (dump, debug, info, warning, or error).
  • log.streams[@].log_type (optional)

    • Value type: string.
    • Description: Type of log device (file or syslog).
  • log.streams[@].log_level (optional)

    • Value type: string.
    • Description: Level of log message (dump, debug, info, warning, or error).
  • log.streams[@].log_path (optional)

    • Value type: string.
    • Description: Location where logs are written. If log.streams[@].log_type is "file", the value is a file path. If log.streams[@].log_type is "syslog", the value can be [tcp/udp]://host:port for a remote syslog server or "local" for the local syslog server.
Type to search, ESC to discard
Type to search, ESC to discard
Type to search, ESC to discard