Skip to main content

SAF Beat for Linux

Please note!

SAF Beat can work with any version of ElasticBeat, but if you plan to send data directly to OpenSearch, then the ElasticBeat version should be 7.12.1 (or 7.10.2 is a more stable version). If you plan to use Logstash, then the ElasticBeat version does not matter, but it is better to use the same version as Logstash (8.9.x). Read more on the official website.

Symbols

  • $SB_HOME - SAF Beat installation home directory, for Linux - /app/SAFBeat/, for Windows - C:\Program Files\SAFBeat\.

Installing and running SAF Beat

Please note!

Use the SAF Beat version corresponding to the OS bit depth.

To install SAF Beat on Linux OS, you need to open the terminal under the root user to execute commands. Before unpacking the archive, you need to create a directory and a user under which the agent will work:

mkdir /app/SAFBeat
useradd --no-create-home --system --user-group sb
Please note!

In some cases, a group of the same name may not be created automatically for the user. Make sure that the user belongs to a group of the same name (in the example above, sb), or create a group manually and add a user to it:

groupadd sb
usermod -aG sb sb

In the SAF installation archive, in the directory $SAF_INSTALLER/utils/SAFBeat/ there are executable files (the file extension elf - executable linux file may be present) of the agents, copy the appropriate bit depth and OS type, for example:

cp $SM_INSTALLER/utils/SAFBeat/SAFBeat-x64* /app/SAFBeat
chmod +x /app/SAFBeat/SAFBeat-x64*

To install SAF Beat, run the executable file with the install flag:

/app/SAFBeat/safBeat-linux-x64-* install
chown -Rf sb:sb /app/SAFBeat
Please note!

The structure of files and directories is created only during the launch of SAF Beat. If any file already exists, it will not be created.

To run SAF Beat, run the following command:

systemctl start saf-beat.service

In order to find out if the service is working, you need to run the command:

systemctl status saf-beat.service

Additional settings

Using pre-generated certificates

To use ready-made certificates and the SAF Beat private key, follow these steps:

  1. Stop the SAF Beat service via systemd
  2. In the ${SB_HOME}/cert/ directory, delete all existing certificates and private keys
  3. Transfer the existing CA certificate, certificate and SAF Beat private key to the same directory ${SB_HOME}/cert/
  4. Edit, if necessary, the configuration file ${SB_HOME}/config/config.yaml:
    1. ssl.cert_ca - specify the name of the CA's x509 certificate
    2. ssl.node_cert - file name of the x509 SAF Beat certificate
  5. ssl.node_key - file name of the SAF Beat private key
  6. ssl.enable: true - enable SSL/TLS
  7. ssl.verify: true - enable validation of the SAF Beat server certificate Manager
  8. Start the SAF Beat service via systemd

It is recommended to generate certificates with the following parameters:

  • keyUsage = critical, digitalSignature, keyEncipherment
  • extendedKeyUsage = serverAuth, clientAuth
  • Subject Alternative Name - specify all possible IP and domain names of the server where the agent is installed

To generate a certificate, you can use the utility provided in the installer: $SM_INSTALLER/utils/ssl-tls-gen/gencerts.sh .

Using self-signed certificates

If the ssl.enable:true parameter is set in the ${SB_HOME}/config/config.yaml configuration, then the agent will check for the presence of ssl.node_cert and ssl.node_key files at startup, and in their absence it will generate self-signed certificates using the same paths.

The interaction between SAF Beat and SAF Beat Manager can be used with encryption, but without checking the certificates themselves, it is enough to set the following parameters:

  1. ssl.node_cert is the file name of the x509 SAF Beat certificate
  2. ssl.node_key is the file name of the SAF Beat private key
  3. ssl.enable: true - enable SSL/TLS
  4. ssl.verify: false - disable validation of the SAF Beat Manager server certificate

User Change

In order to understand the user under whom SAF Beat works, it is necessary to manage the state:

  1. Turn on the SAF Beat system via systemd
  2. Replace the delimiters ${SB_HOME} and all user files and folders, example: chown -R $USER:$USER $SB_HOME/
  3. Add a split to something completely new for the SAF Beat user
  4. Lock the /etc/systemd/system/saf-beat.service file and specify the User field for the new user
  5. Connect the systemd server
[Unit]
Description=SAF Beat

[Service]
User=sb
WorkingDirectory=/opt/safbeat
ExecStart=/opt/safbeat/SAFBeat
Restart=always

[Install]
WantedBy=multi-user.target

Changing the GUID

The GUID is formed based on the UUID of the disk that is mounted on the root of the file system. At startup, SAF Beat calculates the GUID and in the absence of the file ${SB_HOME}/config/guid.yml stores the received value in it. With an existing file, it compares the received value and the value in the file and writes the result in a log file.

If the virtual servers were cloned, then a situation may arise in which the UUIDs will be the same, for this you should add salt when generating the GUID. In the configuration file ${SB_HOME}/config/config.yaml, you need to add the parameter guid_salt. Currently, you can add 2 tokens, which are calculated for each server:

  • <IP> - substitutes the IP address from which the manager.host server is accessed or the value from the agent.ip parameter is taken (must be real, otherwise it will be selected randomly)
  • <MAC> - substitutes the MAC of a network device that has the IP address obtained above

To change the SAF Beat GUID, follow these steps:

  1. Stop the SAF Beat service via systemd
  2. Delete the file ${SB_HOME}/config/guid.yml
  3. Edit the configuration file ${SB_HOME}/config/config.yaml and make changes to the parameter guid_salt - specify the necessary "salt", it is recommended to use the value from the tokens <IP> <MAC>
  4. Start the SAF Beat service via systemd

Description of the configuration file

The configuration file ${SB_HOME}/config/config.yaml consists of the following parameters:

ParameterDescriptionDefault value
guid_saltSalt when generating GUID for SAF Beat.<IP> <MAC>
heartbeat.min_conditionThe minimum connection frequency of SAF Beat.1m0s (1 minute)
heartbeat.multiplierMultiplier of the minimum connection frequency.2
heartbeat.max_conditionThe maximum connection frequency.1h0m0s (1 hour)
manager.hostHost (IP address or DNS name) SAF Beat Manager.localhost
manager.portPort of SAF Beat Manager.7767
agent.ipThe IP address of the agent. It is used in the case of multiple network interfaces to select the agent's IP address to be sent to the SAF Beat Manager. The specified ip address must be assigned to one of the host's network interfaces, otherwise the parameter will be filled with the default value. An optional parameter.The IP address of the network interface of the host through which the request to the SAF Beat Manager passes.
agent.tagsAn array of agent labels. On the SAF Beat Manager side, it is not used yet. Optional parameter.[]
agent.send_addrsEnabling sending information about the host's network interfaces. If the value is true, then an array of addrs objects will be sent to SAF Beat Manager, where each object consists of three fields inter - the interface name, hwaddr - the physical address of the interface, ipv4 - the ip address assigned to the interface. On the SAF Beat Manager side, it is not used yet. Optional parameter.true
rotation.rotation_timeThe frequency of rotation of the logging file.24h (24 hours)
rotation.max_ageLifetime of the logging file.168h (1 week)
rotation.max_sizeLimit the size of the logging file.10485760 (10 MB)
rotation.log_levelLogging level. It can take the values trace, debug, info, warn, error, fatal'. It is recommended to use the debug` level for debugging.info
rotation.log_pathDirectory for saving logs../logs
ssl.verifyChecking ssl certificates when securely connected to SAF Beat Manager.false
ssl.enableSecure connection to SAF Beat Manager.true
ssl.cert_caPath to the CA of the certificate../cert/ca-cert.pem
ssl.node_certPath to generate the node certificate../cert/node-cert.pem
ssl.node_keyPath to generate the node key../cert/node-key.pem