You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					165 lines
				
				3.9 KiB
			
		
		
			
		
	
	
					165 lines
				
				3.9 KiB
			| 
								 
											2 years ago
										 
									 | 
							
								#!/bin/bash
							 | 
						||
| 
								 | 
							
								# info: update PostgreSQL rrd
							 | 
						||
| 
								 | 
							
								# options: PERIOD
							 | 
						||
| 
								 | 
							
								#
							 | 
						||
| 
								 | 
							
								# example: v-update-sys-rrd-pgsql
							 | 
						||
| 
								 | 
							
								#
							 | 
						||
| 
								 | 
							
								# This function is for updating postgresql 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
							 | 
						||
| 
								 | 
							
								# 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/pgsql.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_PGSQL_EXCLUDE//,/ }); do
							 | 
						||
| 
								 | 
							
									hosts=$(echo "$hosts" | grep -vw "$exclude")
							 | 
						||
| 
								 | 
							
								done
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								for host in $hosts; do
							 | 
						||
| 
								 | 
							
									# Checking database
							 | 
						||
| 
								 | 
							
									if [ ! -e "$RRD/db/pgsql_$host.rrd" ]; then
							 | 
						||
| 
								 | 
							
										# Adding database
							 | 
						||
| 
								 | 
							
										rrdtool create $RRD/db/pgsql_$host.rrd --step $RRD_STEP \
							 | 
						||
| 
								 | 
							
											DS:A:GAUGE:600:U:U \
							 | 
						||
| 
								 | 
							
											DS:T: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
							 | 
						||
| 
								 | 
							
										# Defining host credentials
							 | 
						||
| 
								 | 
							
										host_str=$(grep "HOST='$host'" $conf)
							 | 
						||
| 
								 | 
							
										for key in $host_str; do
							 | 
						||
| 
								 | 
							
											eval ${key%%=*}=${key#*=}
							 | 
						||
| 
								 | 
							
										done
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
										export PGPASSWORD="$PASSWORD"
							 | 
						||
| 
								 | 
							
										sql="psql -h $HOST -U $USER"
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
										# Checking empty vars
							 | 
						||
| 
								 | 
							
										if [ -z $HOST ] || [ -z $USER ] || [ -z $PASSWORD ]; then
							 | 
						||
| 
								 | 
							
											echo "Error: config is broken"
							 | 
						||
| 
								 | 
							
											log_event "$E_PARSING" "$ARGUMENTS"
							 | 
						||
| 
								 | 
							
											exit "$E_PARSING"
							 | 
						||
| 
								 | 
							
										fi
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
										# Parsing data
							 | 
						||
| 
								 | 
							
										q='SELECT SUM(xact_commit + xact_rollback), SUM(numbackends)
							 | 
						||
| 
								 | 
							
								                FROM pg_stat_database;'
							 | 
						||
| 
								 | 
							
										status=$($sql -d postgres -c "$q" 2> /dev/null)
							 | 
						||
| 
								 | 
							
										code="$?"
							 | 
						||
| 
								 | 
							
										if [ '0' -ne "$code" ]; then
							 | 
						||
| 
								 | 
							
											active=0
							 | 
						||
| 
								 | 
							
											slow=0
							 | 
						||
| 
								 | 
							
										else
							 | 
						||
| 
								 | 
							
											active=$(echo "$status" | head -n 3 | tail -n 1 | awk '{print $3}')
							 | 
						||
| 
								 | 
							
											trans=$(echo "$status" | head -n 3 | tail -n 1 | awk '{print $1}')
							 | 
						||
| 
								 | 
							
										fi
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
										# Updating rrd
							 | 
						||
| 
								 | 
							
										export PGPASSWORD='pgsql'
							 | 
						||
| 
								 | 
							
										rrdtool update $RRD/db/pgsql_$host.rrd N:$active:$trans
							 | 
						||
| 
								 | 
							
									fi
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
									# Updating rrd graph
							 | 
						||
| 
								 | 
							
									rrdtool graph $RRD/db/$period-pgsql_$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/pgsql_$host.rrd:A:AVERAGE \
							 | 
						||
| 
								 | 
							
										DEF:t=$RRD/db/pgsql_$host.rrd:T: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' \
							 | 
						||
| 
								 | 
							
										LINE2:t#f57900:"Transactions" \
							 | 
						||
| 
								 | 
							
										GPRINT:t:'LAST:Current\:''%8.0lf' \
							 | 
						||
| 
								 | 
							
										GPRINT:t:'MIN:Min\:''%8.0lf' \
							 | 
						||
| 
								 | 
							
										GPRINT:t:'MAX:Max\:''%8.0lf\j' &> /dev/null
							 | 
						||
| 
								 | 
							
									result=$?
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
									if [ "$result" -ne 0 ]; then
							 | 
						||
| 
								 | 
							
										exit "$E_RRD"
							 | 
						||
| 
								 | 
							
									fi
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								done
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#----------------------------------------------------------#
							 | 
						||
| 
								 | 
							
								#                       Hestia                             #
							 | 
						||
| 
								 | 
							
								#----------------------------------------------------------#
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								exit
							 |