In this guide we shall cover how to setup Cacti monitoring tool on Rocky Linux 8. Cacti is an open-source monitoring tool that works as a front end for the enterprise class logging tool, RRDtool.

Cacti can make use of RRDtool’s data storage and graphing functionality with some more functionalities such as:

  1. Support for advanced templating
  2. User management with Access Control List (ACL)
  3. Fast polling of metrics
  4. Support for multiple data acquisition methods.

Cacti runs with a web front end for managing and monitoring configurations. There are some dependencies that needs to be installed alongside Cacti for a successful setup. These are:

  1. Apache server
  2. MySQL/MariaDB server
  3. PHP and PHP extensions
  4. SNMP tools

This article will cover how to setup all of them.

Step 1 – Install System Dependencies and Build tools

Before we can start installation of these tools, we first need to install Development Tools set:

sudo dnf groupinstall "Development Tools"

After a successful installation of Development Tools, proceed to installation of SNMP packages:

sudo dnf install -y net-snmp net-snmp-utils rrdtool

Step 2 – Install Apache Web server

Install Apache web server with the command below:

sudo dnf install @httpd

Start and enable httpd service to start at boot

sudo systemctl enable --now httpd

Check and confirm that the service is up and running.

 $ systemctl status httpd
● httpd.service - The Apache HTTP Server
   Loaded: loaded (/usr/lib/systemd/system/httpd.service; enabled; vendor preset: disabled)
  Drop-In: /usr/lib/systemd/system/httpd.service.d
   Active: active (running) since Sat 2021-07-10 19:00:47 EDT; 41s ago
     Docs: man:httpd.service(8)
 Main PID: 53312 (httpd)
   Status: "Total requests: 3; Idle/Busy workers 100/0;Requests/sec: 0.0769; Bytes served/sec: 140 B/sec"
    Tasks: 213 (limit: 11389)
   Memory: 31.7M
   CGroup: /system.slice/httpd.service
           ├─53312 /usr/sbin/httpd -DFOREGROUND
           ├─53314 /usr/sbin/httpd -DFOREGROUND
           ├─53315 /usr/sbin/httpd -DFOREGROUND
           ├─53316 /usr/sbin/httpd -DFOREGROUND
           └─53317 /usr/sbin/httpd -DFOREGROUND

Jul 10 19:00:47 rockylinux8.linuxvmimages.local systemd[1]: httpd.service: Succeeded.
Jul 10 19:00:47 rockylinux8.linuxvmimages.local systemd[1]: Starting The Apache HTTP Server...
Jul 10 19:00:47 rockylinux8.linuxvmimages.local systemd[1]: Started The Apache HTTP Server.
Jul 10 19:00:47 rockylinux8.linuxvmimages.local httpd[53312]: Server configured, listening on: port 443, port 80

Allow http and https service through the firewall

sudo firewall-cmd --add-service={http,https} --permanent
sudo firewall-cmd --reload

Step 3 – Install PHP and PHP Extensions

Before we install Cacti on Rocky Linux 8 we need to get PHP and PHP extensions required by Cacti system.

Add Remi repository for PHP:

sudo dnf install dnf-utils

Enable the DNF module for PHP installation.

sudo dnf module reset php
sudo dnf module enable php:remi-7.4

Install PHP and PHP extensions

sudo dnf install @php
sudo dnf install -y php php-{mysqlnd,curl,gd,intl,pear,recode,ldap,xmlrpc,snmp,mbstring,gettext,gmp,json,xml,common}

Verify the installed PHP version

$ php -v
PHP 7.4.21 (cli) (built: Jun 29 2021 15:17:15) ( NTS )
Copyright (c) The PHP Group
Zend Engine v3.4.0, Copyright (c) Zend Technologies
    with Zend OPcache v7.4.21, Copyright (c), by Zend Technologies

Set PHP timezone and memory_limit in /etc/php.ini

$ vi /etc/php.ini
date.timezone = Africa/Nairobi
memory_limit = 512M
max_execution_time = 300

Start and enable PHP-FPM

sudo systemctl enable --now php-fpm

Step 4 – Install and configure Database server

Follow the guide below on how to setup a secure MariaDB od MySQL 8 instance on Rocky Linux 8

How To Install MariaDB Server on Rocky Linux 8

Install MySQL 8 on Rocky Linux 8 | AlmaLinux 8

After a successful installation, create a database, and a user for Cacti tool.

$ mysql -u root -p
GRANT ALL ON cacti.* TO 'cacti'@'localhost' IDENTIFIED BY '[email protected]';

Add the following settings under [mysqld] section of the file /etc/my.cnf.d/mariadb-server.cnf


Restart mariadb service.

sudo systemctl restart mariadb

Step 5 – Download and Configure Cacti on Rocky Linux 8

Download and extract the latest version of Cacti on Rocky Linux 8:

mkdir cacti && cd cacti
curl -SL | tar --strip 1 -xzf -

Move the cacti directory to /var/www/html/ directory.

cd ..
sudo mv cacti/ /var/www/html/

Import Cacti database data

mysql -u root -p cacti < /var/www/html/cacti/cacti.sql

Setup mysl timezone for the cacti user created on the database

mysql_tzinfo_to_sql /usr/share/zoneinfo | mysql -u root -p mysql

Grant the cacti user access to the timezone database:

$ mysql -u root -p

MariaDB [(none)]> GRANT SELECT ON mysql.time_zone_name TO [email protected];
MariaDB [(none)]> ALTER DATABASE cacti CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;

Configure SELinux to allow connections to the cacti directory

sudo semanage fcontext -a -t httpd_sys_rw_content_t "/var/www/html/cacti(/.*)?"
sudo restorecon -Rv /var/www/html/cacti

Restart httpd service

sudo systemctl restart httpd php-fpm

Cacti Configuration

We need to do some initial configurations for cacti e.g database connection and permissions.

Edit the /var/www/html/cacti/include/config.php file to setup the database credentials we created in step 4 above.

$database_type     = 'mysql';
$database_default  = 'cacti';
$database_hostname = 'localhost';
$database_username = 'cacti';
$database_password = '[email protected]';
$database_port     = '3306';

Create Cacti System log file

touch /var/www/html/cacti/log/cacti.log

Set directory permissions on the cacti folder

sudo chown -R apache:apache  /var/www/html/cacti

Setup Cacti cron job

sudo crontab -u apache -e

Add the content below:

*/5 * * * * php /var/www/html/cacti/poller.php > /dev/null 2>&1

Step 6 – Access Cacti Web Interface on Rocky Linux 8

We can now access our cacti web interface for the installation wizard via http://[ServerIP/Hostname]/cacti.

The default logins for cacti are:

Username: admin
Password: admin

You will be required to change the password upon first-time login.

Accept License Agreement for GPL the click “Begin

Make sure that all the pre-installation checks have passed with a green thumbs-up.

Select “New Primary server” option in the installation type window to do a local installation of cacti.

Confirm that directory permission checks are okay

In the next window confirm that binary paths are located in the correct paths.

Select the default profile for data polling

Choose the device templates of your choice which will be used to add devices. You can also add other templates later after the installation.

Confirm that the database settings are in order.

Confirm installation

Click install to start the installation process.

The installation process takes a few moments to complete. Upon completion, click on “Get Started” to navigate to the Cacti dashboard.

You will be redirected to the login dashboard where you can now add devices for monitoring.

To add a device go to Console>Create>New Device then add a new device for monitoring.

Cacti polling runs as a cron job which is set to run after every 5 minutes. This means that for you to see the metrics being populated you have to wait for at least 5 minutes.

You can then navigate to Graphs and choose the device that you added to see the metrics.


I hope this article was informative enough as we have been able to successfully deploy Cacti monitoring tool on Rocky Linux 8. Cheers and please have a look at some of the articles about monitoring on this article.

Add Remote Hosts to Nagios Server for Monitoring

Install and Configure Nagios 4.x on Rocky Linux 8

Best Grafana and Prometheus Monitoring books


Please enter your comment!
Please enter your name here