ROOTPLOIT
Server: Apache
System: Linux node6122.myfcloud.com 6.14.3-x86_64-linode168 #1 SMP PREEMPT_DYNAMIC Mon Apr 21 19:47:55 EDT 2025 x86_64
User: bashacomputer (1004)
PHP: 7.4.33
Disabled: exec,passthru,shell_exec,system
Upload Files
File: //usr/lib64/nagios/plugins/check_a2_mysql-replication.sh
#!/bin/bash
#
# Icinga plugin for checking MySQL replication status
#
# Author: Refactored for Icinga
#

MYSQL_USER="root"
MYSQL_PASS=""
MYSQL_SOCKET="/var/lib/mysql/mysql.sock"

# Performance thresholds
DELAY_OK=600
DELAY_WARNING=43200

MYSQL_STATUS=$(mysql --defaults-extra-file="/root/.my.cnf" -u$MYSQL_USER -S $MYSQL_SOCKET -e "SHOW SLAVE STATUS\G" | grep -E 'Slave_.*_Running|Seconds_Behind_Master' | sed 's/^ *//')

IO_RUNNING=$(echo "$MYSQL_STATUS" | grep "Slave_IO_Running:" | awk '{print $2}')
SQL_RUNNING=$(echo "$MYSQL_STATUS" | grep "Slave_SQL_Running:" | awk '{print $2}')
DELAY=$(echo "$MYSQL_STATUS" | grep "Seconds_Behind_Master:" | awk '{print $2}')

EXIT_CODE=0

if [[ "$IO_RUNNING" != "Yes" ]]; then
  OUTPUT="CRITICAL - Replication IO Stopped"
  EXIT_CODE=2
elif [[ "$SQL_RUNNING" != "Yes" ]]; then
  OUTPUT="CRITICAL - Replication SQL Stopped"
  EXIT_CODE=2
elif [[ "$DELAY" == "NULL" ]]; then
  OUTPUT="CRITICAL - Replication delay is NULL"
  EXIT_CODE=2
elif (( DELAY < DELAY_OK )); then
  OUTPUT="OK - MySQL Replication is running with delay $DELAY seconds"
elif (( DELAY < DELAY_WARNING )); then
  OUTPUT="WARNING - Replication delay $DELAY seconds"
  EXIT_CODE=1
else
  OUTPUT="CRITICAL - Replication delay $DELAY seconds"
  EXIT_CODE=2
fi

# Print output for Icinga
echo "$OUTPUT | delay=$DELAY;$DELAY_OK;$DELAY_WARNING;;"
exit $EXIT_CODE