############################################################################### # COMMANDS.CFG - SAMPLE COMMAND DEFINITIONS FOR NAEMON 1.3.0 # # # NOTES: This config file provides you with some example command definitions # that you can reference in host, service, and contact definitions. # # You don't need to keep commands in a separate file from your other # object definitions. This has been done just to make things easier to # understand. # ############################################################################### ############################### # Slack notifications ############################### # 'notify-service-by-slack' command definition define command { command_name notify-service-by-slack command_line SERVICESTATE="$SERVICESTATE$" \ HOSTNAME="$HOSTNAME$" \ SERVICEDISPLAYNAME="$SERVICEDISPLAYNAME$" \ SERVICEOUTPUT="$SERVICEOUTPUT$" \ HOSTNAME="$HOSTNAME$" \ /usr/local/bin/slack_nagios.sh > /tmp/slack.log 2>&1 } # 'notify-host-by-slack' command definition define command { command_name notify-host-by-slack command_line SERVICESTATE="$SERVICESTATE$" \ HOSTNAME="$HOSTNAME$" \ SERVICEDISPLAYNAME="$SERVICEDISPLAYNAME$" \ SERVICEOUTPUT="$SERVICEOUTPUT$" \ HOSTNAME="$HOSTNAME$" \ /usr/local/bin/slack_nagios.sh > /tmp/slack.log 2>&1 } ################################################################################ # # SAMPLE NOTIFICATION COMMANDS # # These are some example notification commands. They may or may not work on # your system without modification. As an example, some systems will require # you to use "/usr/bin/mailx" instead of "/usr/bin/mail" in the commands below. # ################################################################################ # 'notify-host-by-email' command definition define command { command_name notify-host-by-email command_line /usr/bin/printf "%b" "***** Naemon *****\n\nNotification Type: $NOTIFICATIONTYPE$\nHost: $HOSTNAME$\nState: $HOSTSTATE$\nAddress: $HOSTADDRESS$\nInfo: $HOSTOUTPUT$\n\nDate/Time: $LONGDATETIME$\n" \ | /usr/bin/mail \ -s "** $NOTIFICATIONTYPE$ Host Alert: $HOSTNAME$ is $HOSTSTATE$ **" $CONTACTEMAIL$ } # 'notify-service-by-email' command definition define command { command_name notify-service-by-email command_line /usr/bin/printf "%b" "***** Naemon *****\n\nNotification Type: $NOTIFICATIONTYPE$\n\nService: $SERVICEDESC$\nHost: $HOSTALIAS$\nAddress: $HOSTADDRESS$\nState: $SERVICESTATE$\n\nDate/Time: $LONGDATETIME$\n\nAdditional Info:\n\n$SERVICEOUTPUT$\n" \ | /usr/bin/mail \ -s "** $NOTIFICATIONTYPE$ Service Alert: $HOSTALIAS$/$SERVICEDESC$ is $SERVICESTATE$ **" $CONTACTEMAIL$ } ################################################################################ # # SAMPLE HOST CHECK COMMANDS # ################################################################################ # This command checks to see if a host is "alive" by pinging it # The check must result in a 100% packet loss or 5 second (5000ms) round trip # average time to produce a critical error. # Note: Five ICMP echo packets are sent (determined by the '-p 5' argument) # 'check-host-alive' command definition #define command { # command_name check-host-alive # command_line $USER1$/check_ping -H $HOSTADDRESS$ -w 3000.0,80% -c 5000.0,100% -p 5 #} ################################################################################ # # SAMPLE SERVICE CHECK COMMANDS # # These are some example service check commands. They may or may not work on # your system, as they must be modified for your plugins. See the HTML # documentation on the plugins for examples of how to configure command definitions. # # NOTE: The following 'check_local_...' functions are designed to monitor # various metrics on the host that Naemon is running on (i.e. this one). ################################################################################ # 'check_local_disk' command definition define command { command_name check_local_disk command_line $USER1$/check_disk -w $ARG1$ -c $ARG2$ -p $ARG3$ } # 'check_local_load' command definition define command { command_name check_local_load command_line $USER1$/check_load -w $ARG1$ -c $ARG2$ } # 'check_local_procs' command definition define command { command_name check_local_procs command_line $USER1$/check_procs -w $ARG1$ -c $ARG2$ -s $ARG3$ } # 'check_local_users' command definition define command { command_name check_local_users command_line $USER1$/check_users -w $ARG1$ -c $ARG2$ } # 'check_local_swap' command definition define command { command_name check_local_swap command_line $USER1$/check_swap -w $ARG1$ -c $ARG2$ } # 'check_local_mrtgtraf' command definition define command { command_name check_local_mrtgtraf command_line $USER1$/check_mrtgtraf -F $ARG1$ -a $ARG2$ -w $ARG3$ -c $ARG4$ -e $ARG5$ } # ################################################################################# ## NOTE: The following 'check_...' commands are used to monitor services on ## both local and remote hosts. ################################################################################# ## 'check_ftp' command definition #define command { # command_name check_ftp # command_line $USER1$/check_ftp -H $HOSTADDRESS$ $ARG1$ #} # ## 'check_hpjd' command definition #define command { # command_name check_hpjd # command_line $USER1$/check_hpjd -H $HOSTADDRESS$ $ARG1$ #} # # 'check_snmp' command definition define command { command_name check_snmp command_line $USER1$/check_snmp -H $HOSTADDRESS$ $ARG1$ } # ## 'check_http' command definition #define command { # command_name check_http # command_line $USER1$/check_http -I $HOSTADDRESS$ $ARG1$ #} # ## 'check_ssh' command definition #define command { # command_name check_ssh # command_line $USER1$/check_ssh $ARG1$ $HOSTADDRESS$ #} # ## 'check_dhcp' command definition #define command { # command_name check_dhcp # command_line $USER1$/check_dhcp $ARG1$ #} # ## 'check_ping' command definition #define command { # command_name check_ping # command_line $USER1$/check_ping -H $HOSTADDRESS$ -w $ARG1$ -c $ARG2$ -p 5 #} # ## 'check_pop' command definition #define command { # command_name check_pop # command_line $USER1$/check_pop -H $HOSTADDRESS$ $ARG1$ #} # ## 'check_imap' command definition #define command { # command_name check_imap # command_line $USER1$/check_imap -H $HOSTADDRESS$ $ARG1$ #} # ## 'check_smtp' command definition #define command { # command_name check_smtp # command_line $USER1$/check_smtp -H $HOSTADDRESS$ $ARG1$ #} # ## 'check_tcp' command definition #define command { # command_name check_tcp # command_line $USER1$/check_tcp -H $HOSTADDRESS$ -p $ARG1$ $ARG2$ #} # ## 'check_udp' command definition #define command { # command_name check_udp # command_line $USER1$/check_udp -H $HOSTADDRESS$ -p $ARG1$ $ARG2$ #} # ## 'check_nt' command definition #define command { # command_name check_nt # command_line $USER1$/check_nt -H $HOSTADDRESS$ -p 12489 -v $ARG1$ $ARG2$ #} ################################################################################ # # SAMPLE PERFORMANCE DATA COMMANDS # # These are sample performance data commands that can be used to send performance # data output to two text files (one for hosts, another for services). If you # plan on simply writing performance data out to a file, consider using the # host_perfdata_file and service_perfdata_file options in the main config file. # ################################################################################ # 'process-host-perfdata' command definition define command { command_name process-host-perfdata command_line /usr/bin/printf "%b" "$LASTHOSTCHECK$\t$HOSTNAME$\t$HOSTSTATE$\t$HOSTATTEMPT$\t$HOSTSTATETYPE$\t$HOSTEXECUTIONTIME$\t$HOSTOUTPUT$\t$HOSTPERFDATA$\n" \ >> /var/lib/naemon/host-perfdata.out } # 'process-service-perfdata' command definition define command { command_name process-service-perfdata command_line /usr/bin/printf "%b" "$LASTSERVICECHECK$\t$HOSTNAME$\t$SERVICEDESC$\t$SERVICESTATE$\t$SERVICEATTEMPT$\t$SERVICESTATETYPE$\t$SERVICEEXECUTIONTIME$\t$SERVICELATENCY$\t$SERVICEOUTPUT$\t$SERVICEPERFDATA$\n" \ >> /var/lib/naemon/service-perfdata.out }