This project is mainly composed by a bash script and a Zabbix template. The bash script reads values from Bacula Catalog and sends it to Zabbix Server. While the Zabbix template has items and other configurations that receive this values, start alerts and generate graphs and screens. This material was created using Bacula at 7.0.5 version and Zabbix at 2.4.5 version in a GNU/Linux CentOS 7 operational system.
Tested with Bacula 9.4.x with PostgreSQL 11 backend and Zabbix 4.0.x on GNU/Linux Debian 9
Tested with Bacula 13.0.x with PostgreSQL 14 backend and Zabbix 6.4.x on GNU/Linux Ubuntu 22.04
- Customizable and easy to set up
- Separate monitoring for each backup job
- Different job levels have different severities
- Monitoring of Bacula Director, Storage and File processes
- Generates graphs to follow the data evolution
- Screens with graphs ready for display
- Works with MySQL and PostgreSQL used by Bacula Catalog
- Job exit status
- Number of bytes transferred by the job
- Number of files transferred by the job
- Time elapsed by the job
- Job transfer rate
- Job compression rate
Link this Zabbix template to each host that has a Bacula's backup job implemented. Each host configured in Zabbix with this template linked needs to have its name equals to the name configured in Bacula's Client resource. Otherwise the data collected by the bash script will not be received by Zabbix server.
-
Items
This Zabbix template has two types of items, the items to receive data of backup jobs, and the itens to receive data of Bacula's processes. The items that receive data of Bacula's processes are described below:
- Bacula Director is running: Get the Bacula Director process status. The process name is defined by the variable {$BACULA.DIR}, and has its default value as 'bacula-dir'. This item needs to be disabled in hosts that are Bacula's clients only.
- Bacula Storage is running: Get the Bacula Storage process status. The process name is defined by the variable {$BACULA.SD}, and has its default value as 'bacula-sd'. This item needs to be disabled in hosts that are Bacula's clients only.
- Bacula File is running: Get the Bacula File process status. The process name is defined by the variable {$BACULA.FD}, and has its default value as 'bacula-fd'.
The items that receive data of backup jobs are divided into the three backup's levels: Full, Differential and Incremental. For each level there are six items as described below:
- Bytes: Receives the value of bytes transferred by each backup job
- Compression: Receives the value of compression rate of each backup job
- Files: Receives the value of files transferred by each backup job
- OK: Receives the value of exit status of each backup job
- Speed: Receives the value of transfer rate of each backup job
- Time: Receives the value of elapsed time of each backup job
-
Triggers
The triggers are configured to identify the host that started the trigger through the variable {HOST.NAME}. In the same way as the items, the triggers has two types too. The triggers that are related to Bacula's processes:
- Bacula Director is DOWN in {HOST.NAME}: Starts a disaster severity alert when the Bacula Director process goes down
- Bacula Storage is DOWN in {HOST.NAME}: Starts a disaster severity alert when the Bacula Storage process goes down
- Bacula File is DOWN in {HOST.NAME}: Starts a high severity alert when the Bacula File process goes down
And the triggers that are related to backup jobs:
- Backup Full FAIL in {HOST.NAME}: Starts a high severity alert when a full backup job fails
- Backup Differential FAIL in {HOST.NAME}: Starts a average severity alert when a differential backup job fails
- Backup Incremental FAIL in {HOST.NAME}: Starts a warning severity alert when a incremental backup job fails
-
Graphs
Again, in the same way as the items related to backup jobs, the graphs are divided into the three backup's levels: Full, Differential and Incremental. For each level there are five graphs as described below:
- Bytes transferred: Displays a graph with the variation of the bytes transferred by backup jobs, faced with the variation of the exit status of these jobs
- Compression rate: Displays a graph with the variation of the compression rate by backup jobs, faced with the variation of the exit status of these jobs
- Elapsed time: Displays a graph with the variation of the elapsed time by backup jobs, faced with the variation of the exit status of these jobs
- Files transferred: Displays a graph with the variation of the files transferred by backup jobs, faced with the variation of the exit status of these jobs
- Transfer rate: Displays a graph with the variation of the transfer rate by backup jobs, faced with the variation of the exit status of these jobs
-
Screens
There are three screens, one for each backup level, that displays the five graphs previously configured for that level.
- Bacula's implemented infrastructure and knowledge about it
- Zabbix's implemented infrastructure and knowledge about it
- Knowledge about MySQL or PostgreSQL databases
- Knowledge about GNU/Linux operational systems
Note: If your Bacula uses a config path other than /opt/bacula/etc
(e.g., Bacula.org builds use /etc/bacula
), you should set the valid path to bacula-zabbix.conf
in bacula-zabbix.bash
.
- Create the configuration file
/opt/bacula/etc/bacula-zabbix.conf
as the sample in this repository, customize it for your infrastructure environment, and set the permissions as below:
chown root:bacula /opt/bacula/etc/bacula-zabbix.conf
chmod 640 /opt/bacula/etc/bacula-zabbix.conf
- Create the bash script file
/var/spool/bacula/bacula-zabbix.bash
by copying it from this repository and set the permissions as below:
chown bacula:bacula /var/spool/bacula/bacula-zabbix.bash
chmod 700 /var/spool/bacula/bacula-zabbix.bash
- Edit the Bacula Director configuration file
/opt/bacula/etc/bacula-dir.conf
to start the script at the finish of each job. To do this you need to change the lines described below in the Messages resource that is used by all the configured jobs:
Messages {
...
mailcommand = "/var/spool/bacula/bacula-zabbix.bash %i"
mail = 127.0.0.1 = all, !skipped
...
}
Note that if there is already a mailcommand set then an additional wrapper script has to be used. For example if the original mailcommand was:
mailcommand = "/usr/sbin/bsmtp -h localhost -f \"\(Bacula\) \<[email protected]\>\" -s \"Bacula: %t %e of %c (%n) %l\" %r"
then it is necessary to use and external script like the bacula-sender.bash script provided. Put the file into /var/spool/bacula/ and set the permissions as below:
chown bacula:bacula /var/spool/bacula/bacula-sender.bash
chmod 700 /var/spool/bacula/bacula-sender.bash
The file is setup to work with the example mail command from above. Change the Messages mailcommand to
# Via arquivo bacula-dir.conf
mailcommand = "/var/spool/bacula/bacula-sender.bash \"%t\" \"%e\" \"%c\" \"%n\" \"%l\" \"%r\" \"%i\""
Note that if you edit the message via Baculum WEB(Prefered and no restart needed) you should use without "":
# Via WEB:
mailcommand = /var/spool/bacula/bacula-sender.bash "%t" "%e" "%c" "%n" "%l" "%r" "%i"
tip:
- you probably want bacula to send this "message" on All jobs.
- then check the
all
box in themail
Message option.
and leave everything else the same.
- Now restart the Bacula Director service. In my case I used this command:
systemctl restart bacula-dir
-
Make a copy of the Zabbix template from this repository and import it to your Zabbix server.
-
Edit your hosts that have configured backup jobs to use this template. Don't forget to edit the variables with the Bacula's processes names, and to disable in hosts that are only Bacula's clients the items that check the Bacula Director and Storage processes.
- alert when there is action need for labeling media
- monitor running jobs
- alert monitor jobs when they shouldn't be running
- Put the files into /var/spool/bacula/ and set the permissions as below:
chmod +x /var/spool/bacula/bacula-label-zabbix-sender.bash
chmod +x /var/spool/bacula/bacula-running-zabbix-sender.bash
- Create a cron to run and send the data to Zabbix: The bellow example is running every 10 minutes
*/10 * * * * /var/spool/bacula/bacula-label-zabbix-sender.bash
*/10 * * * * /var/spool/bacula/bacula-running-zabbix-sender.bash
tail -f /var/log/syslog
tail -f /var/log/bacula/bacula-zabbix.log
docker logs -f zabbix-snmptraps-1 -n 100
/var/log/zabbix/zabbix_server.log
-
Bacula:
- http://www.bacula.org/7.0.x-manuals/en/main
- https://www.bacula.org/9.4.x-manuals/en/main/
- http://www.bacula.com.br/manual/Messages_Resource.html
- https://www.bacula.org/9.4.x-manuals/en/main/Messages_Resource.html
- http://www.bacula-web.org/docs.html
- http://resources.infosecinstitute.com/data-backups-bacula-notifications
-
Zabbix:
-
Integration:
Feel free to send bug reports and feature requests here:
If you are using this solution in production, please write me about it. It's very important for me to know that my work is not meaningless.