InfluxDB Installation/Collectors
From r00tedvw.com wiki
InfluxDB Installation | Collector Scripts
Contents |
vmstat collector
script
place in /etc/statcollector/statcollector.sh
#!/bin/bash -x #user defined variables dbhostname=('dbhost fqdn') dbport=('8086') dbtable=('influxdb') dbuser=('influx') dbpassword=('influxdb') logdir=("/var/log/statcollector/") #function that checks for connectivity to db host and continues if found. function inet_test { #define variables HOSTNAME=$(hostname) DOMAIN=$(hostname | awk -F "." '/1/ { printf $2"."$3"."$4};') log=("statcollector-$(date +%F).txt") DATE=$(date +%F"|"%R:%S) #function that extracts values and names from vmstat function vmstatvar { #set word boundary as a space, read the line and insert each variable into an array. #this reads the value names from vmstat string=$(vmstat 1 1 -S k | awk 'NR==2') IFS=' ' read -r -a vmstatdef <<<$string #same as above, but this reads the 10 second average values from vmstat and saves them into an array. string2=$(vmstat 10 2 -S k | awk 'NR==4') IFS=' ' read -r -a vmstatvalues <<<$string2 } #function that checks for access to log dir and creates log file either in log directory or in /var/tmp/ function log_dir { if ls "$logdir" >/dev/null 2>&1; then if [ -e "$logdir""$log" ] >/dev/null 2>&1; then printf "$DATE"" -- ""$dbhostname"" ""$is"" accessible\n" >> "$logdir""$log" else printf "Start New Log\n""$DATE"" -- ""$dbhostname"" ""$is"" accessible\n" > "$logdir""$log" fi elif [ -e "/var/tmp/""$log" ] >/dev/null 2>&1; then printf "$DATE"" -- ""$logdir"" is NOT accessible\n""$DATE"" -- ""$dbhostname"" ""$is"" accessible\n" >> "/var/tmp/""$log" else printf "Start New Log\n""$DATE"" -- ""$logdir"" is NOT accessible\n""$DATE"" -- ""$dbhostname"" ""$is"" accessible\n" > "/var/tmp/""$log" fi } #loop that brings everything together and outputs to db via http post function influx_post { for ((i=0;i<=(${#vmstatvalues[@]}-1);i++)) do curl -i --max-time 10\ -H "Accept: application/json" \ -H "Content-Type:application/json" \ -X POST "http://""$dbhostname"":""$dbport""/write?db=""$dbtable" -u "$dbuser":"$dbpassword" --data-binary "${vmstatdef[i]}"",host=""$HOSTNAME"",domain=""$DOMAIN"" value=""${vmstatvalues[i]}" done } #portion of code that checks db connectivity and then calls nested functions if ping -q -c 1 -W 1 "$dbhostname" >/dev/null 2>&1; then is=("is") \ && log_dir \ && vmstatvar \ && influx_post else is=('is NOT') \ && log_dir fi } while true; do inet_test sleep 5 done
Service
place in /etc/init.d/statcollector
# chkconfig: 345 90 60 ## BEGIN INIT INFO # Provides: statcollector # Required-Start: $remote_fs $syslog # Required-Stop: $remote_fs $syslog # Default-Start: 3 4 5 # Default-Stop: 90 # Short-Description: Start statcollector at boot time # Description: Load statcollector at startup to report vmstat values to InfluxDB ### END INIT INFO #startup function start_stat_collector() { printf "Starting Stat Collector ...\n" /etc/statcollector/statcollector.sh > /dev/null 2>&1 & printf "... started.\n" } #stopping function stop_stat_collector () { printf "Stopping Stat Collector ...\n" killall -9 statcollector.sh > /dev/null 2>&1 & printf "... stopped.\n" } #restarting function that stops and starts stat collector restart_stat_collector () { printf "Restarting Stat Collector ..." stop_stat_collector start_stat_collector } #status determination status_stat_collector () { if [ $(ps -ef | grep -v grep | grep 'statcollector.sh' | wc -l) -ge 1 ]; then printf "Stat Collector is running.\n" else printf "Stat Collector is not running.\n" fi } case "$1" in start) start_stat_collector ;; stop) stop_stat_collector ;; restart) restart_stat_collector ;; status) status_stat_collector ;; *) printf "Usage: /etc/init.d/statcollector {start|stop|restart|status}\n" exit 1 ;; esac exit 0
# sudo chmod +x /etc/init.d/statcollector # sudo chkconfig --add /etc/init.d/statcollector
File Count Collector
This was for a service that deposits files into a cache directory and then works on them. It would display the "queue".
Script
place in /etc/mail_queue/mail_queue.sh
#!/bin/bash -x #user defined variables dbhostname=('dbhost fqdn') dbport=('8086') dbtable=('influxdb') dbuser=('influx') dbpassword=('influxdb') logdir=("/var/log/mail_queue/") #function that checks for connectivity to db host and continues if found. function inet_test { #define variables HOSTNAME=$(hostname) DOMAIN=$(hostname | awk -F "." '/1/ { printf $2"."$3"."$4};') log=("mail_queue-$(date +%F).txt") DATE=$(date +%F"|"%R:%S) #function to extract the mail queue function mail_queue { #determine the total number of folders for mail-accepted clients #string0=$(find /var/tmp/smtp/ -maxdepth 1 -type d | while read -r dir; do printf "%s:\t" "$dir"; find "$dir" -type f | wc -l; done | awk 'NR==1' | awk '{ printf$2}') #determine the total number of messages and folders for each client #string1=$(find /var/tmp/smtp/ -maxdepth 1 -type d | while read -r dir; do printf "%s:\t" "$dir"; find "$dir" -type f | wc -l; done | awk 'NR==2' | awk '{ printf$2}') #subtract the total folder count from total message count #string2="$((string1 - string0))" #determine the number of files in directory and children, excluding the directories themselves and only looking for txt files. string2=$(find /var/tmp/smtp/feed/ -type f -name "*.txt" | wc -l) } #function that checks for access to log dir and creates log file either in log directory or in /var/tmp/ function log_dir { if ls "$logdir" >/dev/null 2>&1; then if [ -e "$logdir""$log" ] >/dev/null 2>&1; then printf "$DATE"" -- ""$dbhostname"" ""$is"" accessible\n" >> "$logdir""$log" else printf "Start New Log\n""$DATE"" -- ""$dbhostname"" ""$is"" accessible\n" > "$logdir""$log" fi elif [ -e "/var/tmp/""$log" ] >/dev/null 2>&1; then printf "$DATE"" -- ""$logdir"" is NOT accessible\n""$DATE"" -- ""$dbhostname"" ""$is"" accessible\n" >> "/var/tmp/""$log" else printf "Start New Log\n""$DATE"" -- ""$logdir"" is NOT accessible\n""$DATE"" -- ""$dbhostname"" ""$is"" accessible\n" > /var/tmp/""$log" fi } function print_message_count { string2="0" printf "$string2""\n" } #function that outputs to db via http post function influx_post { curl -i --max-time 10\ -H "Accept: application/json" \ -H "Content-Type:application/json" \ -X POST "http://""$dbhostname"":""$dbport""/write?db=""$dbtable" -u "$dbuser":"$dbpassword" --data-binary "mail_queue"",host=""$HOSTNAME"",domain=""$DOMAIN"" value=""$string2" } #portion of code that checks db connectivity and then calls nested functions if ping -q -c 1 -W 1 "$dbhostname" >/dev/null 2>&1; then is=("is") \ && log_dir \ && mail_queue \ && influx_post else is=('is NOT') \ && log_dir fi } while true; do inet_test sleep 30 done
Service
place in /etc/init.d/mail_queue
# chkconfig: 345 90 60 ## BEGIN INIT INFO # Provides: mail_queue # Required-Start: $remote_fs $syslog # Required-Stop: $remote_fs $syslog # Default-Start: 3 4 5 # Default-Stop: 90 # Short-Description: Start mail_queue at boot time # Description: Load mail_queue at startup to report queue values to InfluxDB ### END INIT INFO #startup function start_mail_queue() { printf "Starting Mail Queue ...\n" /etc/mail_queue/mail_queue.sh > /dev/null 2>&1 & printf "... started.\n" } #stopping function stop_mail_queue () { printf "Stopping Mail Queue ...\n" killall -9 mail_queue.sh > /dev/null 2>&1 & printf "... stopped.\n" } #restarting function that stops and starts stat collector restart_mail_queue () { printf "Restarting Mail Queue ..." stop_mail_queue start_mail_queue } #status determination status_mail_queue () { if [ $(ps -ef | grep -v grep | grep 'mail_queue.sh' | wc -l) -ge 1 ]; then printf "Mail Queue is running.\n" else printf "Mail Queue is not running.\n" fi } case "$1" in start) start_mail_queue ;; stop) stop_mail_queue ;; restart) restart_mail_queue ;; status) status_mail_queue ;; *) printf "Usage: /etc/init.d/mail_queue {start|stop|restart|status}\n" exit 1 ;; esac exit 0
# sudo chmod +x /etc/init.d/mail_queue # sudo chkconfig --add /etc/init.d/mail_queue