
By Bulat Khamitov

Bash is a popular command processor available on Linux by default.
We have previously covered how to install Nagios monitoring server on Ubuntu 12.10 x64. This time, we will expand on this idea and create Nagios plugins using Bash. These plugins will be running on client VPS, and be executed via NRPE.
apt-get install -y nagios-nrpe-server useradd nrpe && update-rc.d nagios-nrpe-server defaults
It would be a good idea to keep your plugins in same directory as other Nagios plugins (/usr/lib/nagios/plugins/ for example).
For our example, we will create a script that checks current disk usage by calling "df" from shell, and throw an alert if it is over 85% used:
#!/bin/bash
used_space=`df -h / | grep -v Filesystem | awk '{print $5}' | sed 's/%//g'`
case $used_space in
[1-84]*)
echo "OK - $used_space% of disk space used."
exit 0
;;
[85]*)
echo "WARNING - $used_space% of disk space used."
exit 1
;;
[86-100]*)
echo "CRITICAL - $used_space% of disk space used."
exit 2
;;
*)
echo "UNKNOWN - $used_space% of disk space used."
exit 3
;;
esac
 
We will save this script in /usr/lib/nagios/plugins/usedspace.sh and make it executable:
chmod +x /usr/lib/nagios/plugins/usedspace.sh
The entire Nagios NRPE plugin boils down to using exit codes to trigger alerts.
You introduce your level of logic to the script, and if you want to trigger an alert (whether it is OK, WARNING, CRITICAL, or UNKNOWN) - you specify an exit code.
Refer to the following Nagios Exit Codes:
| Exit Code | Status | 
| 0 | OK | 
| 1 | WARNING | 
| 2 | CRITICAL | 
| 3 | UNKNOWN | 
Delete original /etc/nagios/nrpe.cfg and add the following lines to it:
log_facility=daemon pid_file=/var/run/nagios/nrpe.pid server_port=5666 nrpe_user=nrpe nrpe_group=nrpe allowed_hosts=198.211.117.251 dont_blame_nrpe=1 debug=0 command_timeout=60 connection_timeout=300 include_dir=/etc/nagios/nrpe.d/ command[usedspace_bash]=/usr/lib/nagios/plugins/usedspace.sh
Where 198.211.117.251 is our monitoring server from previous articles. Change these to your own values.
Make sure to restart Nagios NRPE service:
service nagios-nrpe-server restart
Define new command in /etc/nagios/objects/commands.cfg
define command{
        command_name    usedspace_bash
        command_line    $USER1$/check_nrpe -H $HOSTADDRESS$ -c usedspace_bash
        }
As you can see, it uses NRPE to make TCP connections to port 5666 and run command 'usedspace_bash', which we defined in /etc/nagios/nrpe.cfg on that remote host.
Add this check to your Nagios configuration file for client VPS.
For our example, we will monitor a server called UbuntuDroplet and edit /etc/nagios/servers/UbuntuDroplet.cfg
define service {
        use                             generic-service
        host_name                       UbuntuDroplet
        service_description             Custom Disk Checker In Bash
        check_command                   usedspace_bash
        }
 
Restart Nagios:
service nagios restart
Verify that the new check is working:
 
And you are all done!
Thanks for learning with the DigitalOcean Community. Check out our offerings for compute, storage, networking, and managed databases.

This textbox defaults to using Markdown to format your answer.
You can type !ref in this text area to quickly search our full set of tutorials, documentation & marketplace offerings and insert the link!
Suppose if I want to check all the disks present in my box then what would be the changes in the scroipt ?
Hi, I used this method and this is great, but I just want to know how I can set the performance data?
The case clauses in shell script are not correct. BASH case clauses use shell pattern matching, not number ranges.
http://www.gnu.org/software/bash/manual/bashref.html#Pattern-Matching
These are the correct patterns.
case $used_space in
    [1-9]|[1-7][1-9]|8[0-4])
        echo "Match 1 - 84";;
    85)
        echo "Match 85";;
    8[6-9]|9[0-9]|100)
        echo "Match 86-100";;
    *)
        echo "Default";;
esac
Explanation:
| is a logical OR between patterns
[1-9] matches 1 - 9.
[1-7][1-9] matches 11 - 79
8[0-4] matches 80-84
85 matches “85” only
Get paid to write technical tutorials and select a tech-focused charity to receive a matching donation.
Full documentation for every DigitalOcean product.
The Wave has everything you need to know about building a business, from raising funding to marketing your product.
Stay up to date by signing up for DigitalOcean’s Infrastructure as a Newsletter.
New accounts only. By submitting your email you agree to our Privacy Policy
Scale up as you grow — whether you're running one virtual machine or ten thousand.
Sign up and get $200 in credit for your first 60 days with DigitalOcean.*
*This promotional offer applies to new accounts only.