Initial
This commit is contained in:
147
bin/v-update-sys-rrd-mysql
Executable file
147
bin/v-update-sys-rrd-mysql
Executable file
@@ -0,0 +1,147 @@
|
||||
#!/bin/bash
|
||||
# info: update MySQL rrd
|
||||
# options: PERIOD
|
||||
#
|
||||
# example: v-update-sys-rrd-mysql
|
||||
#
|
||||
# This function is for updating mysql rrd database and graphic.
|
||||
|
||||
#----------------------------------------------------------#
|
||||
# Variables & Functions #
|
||||
#----------------------------------------------------------#
|
||||
|
||||
# Argument definition
|
||||
period=${1-daily}
|
||||
|
||||
# Includes
|
||||
# shellcheck source=/etc/hestiacp/hestia.conf
|
||||
source /etc/hestiacp/hestia.conf
|
||||
# shellcheck source=/usr/local/hestia/func/main.sh
|
||||
source $HESTIA/func/main.sh
|
||||
# shellcheck source=/usr/local/hestia/func/db.sh
|
||||
source $HESTIA/func/db.sh
|
||||
# load config file
|
||||
source_conf "$HESTIA/conf/hestia.conf"
|
||||
|
||||
#----------------------------------------------------------#
|
||||
# Action #
|
||||
#----------------------------------------------------------#
|
||||
|
||||
# Switching on time period
|
||||
case $period in
|
||||
daily)
|
||||
start='-1d'
|
||||
end='now'
|
||||
grid='MINUTE:30:HOUR:1:HOUR:4:0:%H:%M'
|
||||
;;
|
||||
weekly)
|
||||
start='-7d'
|
||||
end='now'
|
||||
grid='HOUR:8:DAY:1:DAY:1:0:%a %d'
|
||||
;;
|
||||
monthly)
|
||||
start='-1m'
|
||||
end='now'
|
||||
grid='WEEK:1:WEEK:1:WEEK:1:0:%b %d'
|
||||
;;
|
||||
yearly)
|
||||
start='-1y'
|
||||
end='now'
|
||||
grid='MONTH:1:YEAR:1:MONTH:2:2419200:%b'
|
||||
;;
|
||||
*) exit "$E_RRD" ;;
|
||||
esac
|
||||
|
||||
# Checking directory
|
||||
if [ ! -d "$RRD/db" ]; then
|
||||
mkdir $RRD/db
|
||||
fi
|
||||
|
||||
# Parsing db hosts
|
||||
conf="$HESTIA/conf/mysql.conf"
|
||||
hosts=$(grep HOST "$conf" | awk '{print $1}' | cut -f 2 -d \')
|
||||
check_row=$(echo "$hosts" | wc -l)
|
||||
if [ 0 -eq "$check_row" ]; then
|
||||
exit
|
||||
fi
|
||||
|
||||
# Parsing excludes
|
||||
for exclude in $(echo ${RRD_MYSQL_EXCLUDE//,/ }); do
|
||||
hosts=$(echo "$hosts" | grep -vw "$exclude")
|
||||
done
|
||||
|
||||
for host in $hosts; do
|
||||
# Checking database
|
||||
if [ ! -e "$RRD/db/mysql_$host.rrd" ]; then
|
||||
# Adding database
|
||||
rrdtool create $RRD/db/mysql_$host.rrd --step $RRD_STEP \
|
||||
DS:A:COUNTER:600:U:U \
|
||||
DS:S:COUNTER:600:U:U \
|
||||
RRA:AVERAGE:0.5:1:600 \
|
||||
RRA:AVERAGE:0.5:6:700 \
|
||||
RRA:AVERAGE:0.5:24:775 \
|
||||
RRA:AVERAGE:0.5:288:797 \
|
||||
RRA:MAX:0.5:1:600 \
|
||||
RRA:MAX:0.5:6:700 \
|
||||
RRA:MAX:0.5:24:775 \
|
||||
RRA:MAX:0.5:288:797
|
||||
fi
|
||||
|
||||
if [ "$period" = 'daily' ]; then
|
||||
mysql_connect "$host"
|
||||
query='SHOW GLOBAL STATUS'
|
||||
status=$(mysql_query "$query" 2> /dev/null)
|
||||
if [ $? -ne 0 ]; then
|
||||
active=0
|
||||
slow=0
|
||||
else
|
||||
active=$(echo "$status" | grep 'Queries' | cut -f 2)
|
||||
slow=$(echo "$status" | grep 'Slow_queries' | cut -f 2)
|
||||
fi
|
||||
|
||||
# Updating rrd
|
||||
rrdtool update $RRD/db/mysql_$host.rrd N:$active:$slow
|
||||
fi
|
||||
|
||||
# Updating daily graph
|
||||
rrdtool graph $RRD/db/$period-mysql_$host.png \
|
||||
--imgformat PNG \
|
||||
--height="150" \
|
||||
--width="670" \
|
||||
--start "$start" \
|
||||
--end "$end" \
|
||||
--vertical-label "Queries" \
|
||||
--x-grid "$grid" \
|
||||
-c "BACK#ffffff" \
|
||||
-c "SHADEA#ffffff" \
|
||||
-c "SHADEB#ffffff" \
|
||||
-c "FONT#555555" \
|
||||
-c "CANVAS#302c2d" \
|
||||
-c "GRID#666666" \
|
||||
-c "MGRID#AAAAAA" \
|
||||
-c "FRAME#302c2d" \
|
||||
-c "ARROW#FFFFFF" \
|
||||
DEF:a=$RRD/db/mysql_$host.rrd:A:AVERAGE \
|
||||
DEF:s=$RRD/db/mysql_$host.rrd:S:AVERAGE \
|
||||
COMMENT:'\r' \
|
||||
LINE1:a#fefda0:"Queries" \
|
||||
GPRINT:a:'LAST: Current\:''%8.0lf' \
|
||||
GPRINT:a:'MIN: Min\:''%8.0lf' \
|
||||
GPRINT:a:'MAX: Max\:''%8.0lf\j' \
|
||||
AREA:s#f57900:"Slow " \
|
||||
GPRINT:s:'LAST:Current\:''%8.0lf' \
|
||||
GPRINT:s:'MIN:Min\:''%8.0lf' \
|
||||
GPRINT:s:'MAX:Max\:''%8.0lf\j' &> /dev/null
|
||||
result=$?
|
||||
|
||||
if [ "$result" -ne 0 ]; then
|
||||
exit "$E_RRD"
|
||||
fi
|
||||
|
||||
done
|
||||
|
||||
#----------------------------------------------------------#
|
||||
# Hestia #
|
||||
#----------------------------------------------------------#
|
||||
|
||||
exit
|
||||
Reference in New Issue
Block a user