| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131 |
- #!/bin/bash
- # info: updating MySQL rrd
- #----------------------------------------------------------#
- # Variable&Function #
- #----------------------------------------------------------#
- # Argument defenition
- rrd_start="${1--1d}"
- rrd_end="${2-now}"
- rrd_grid="${3-MINUTE:30:HOUR:1:HOUR:4:0:%H:%M}"
- # Importing variables
- source $VESTA/conf/vars.conf
- source $V_FUNC/shared_func.sh
- source $V_FUNC/db_func.sh
- #----------------------------------------------------------#
- # Action #
- #----------------------------------------------------------#
- # Checking directory
- if [ ! -d "$V_RRD/db" ]; then
- mkdir $V_RRD/db
- fi
- # Parsing db hosts
- conf="$V_DB/mysql.conf"
- fields='$HOST'
- hosts=$(v_clear_list)
- check_row=$(echo "$hosts" |wc -l)
- if [ 0 -eq "$check_row" ]; then
- exit
- fi
- # Parsing excludes
- for exclude in $(echo ${V_RRD_MYSQL_EXCLUDE//,/ }); do
- hosts=$(echo "$hosts" |grep -vw "$exclude" )
- done
- for host in $hosts; do
- # Checking database
- if [ ! -e "$V_RRD/db/mysql_$host.rrd" ]; then
- # Adding database
- rrdtool create $V_RRD/db/mysql_$host.rrd --step $V_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 [ -z "$1" ]; then
- # Defining host credentials
- host_str=$(grep "HOST='$host'" $conf)
- for key in $host_str; do
- eval ${key%%=*}=${key#*=}
- done
- sql="mysql -h $HOST -u $USER -p$PASSWORD -P$PORT -e"
- # Checking empty vars
- if [ -z $HOST ] || [ -z $USER ] || [ -z $PASSWORD ] || [ -z $PORT ]
- then
- echo "Error: config is broken"
- log_event 'debug' "$E_PARSE_ERROR $V_EVENT"
- exit $E_PARSE_ERROR
- fi
- # Parsing data
- status=$($sql "SHOW GLOBAL STATUS" 2>/dev/null); code="$?"
- if [ '0' -ne "$code" ]; 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 $V_RRD/db/mysql_$host.rrd N:$active:$slow
- fi
- # Updating daily graph
- rrdtool graph $V_RRD/db/mysql_$host.png \
- --imgformat PNG \
- --height="120" \
- --width="440" \
- --start "$rrd_start" \
- --end "$rrd_end" \
- --title "MySQL Usage on $host" \
- --vertical-label "Queries" \
- --x-grid "$rrd_grid" \
- -c "BACK#484439" \
- -c "SHADEA#484439" \
- -c "SHADEB#484439" \
- -c "FONT#DDDDDD" \
- -c "CANVAS#202020" \
- -c "GRID#666666" \
- -c "MGRID#AAAAAA" \
- -c "FRAME#202020" \
- -c "ARROW#FFFFFF" \
- DEF:a=$V_RRD/db/mysql_$host.rrd:A:AVERAGE \
- DEF:s=$V_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 2>/dev/null; result=$?
- if [ "$result" -ne 0 ]; then
- exit $E_RRD_FAILED
- fi
- done
- #----------------------------------------------------------#
- # Vesta #
- #----------------------------------------------------------#
- exit $OK
|