mirror of
https://github.com/myvesta/vesta
synced 2025-08-14 18:49:21 -07:00
Many fixes for v-list-sys-services
This commit is contained in:
parent
8c4be97720
commit
302e351252
2 changed files with 133 additions and 21 deletions
|
@ -18,6 +18,8 @@ source $VESTA/conf/vesta.conf
|
|||
|
||||
export PATH=$PATH:/sbin
|
||||
|
||||
debug=0
|
||||
|
||||
# JSON list function
|
||||
json_list() {
|
||||
IFS=$'\n'
|
||||
|
@ -50,6 +52,9 @@ shell_list() {
|
|||
echo "---- ----- --- --- ------"
|
||||
while read str; do
|
||||
eval $str
|
||||
if [ "$STATE" = "stopped" ]; then
|
||||
STATE='off'
|
||||
fi
|
||||
echo "$NAME $STATE $CPU $MEM $RTIME"
|
||||
done < <(echo -e "$data" |grep NAME)
|
||||
}
|
||||
|
@ -77,8 +82,17 @@ csv_list() {
|
|||
get_srv_state() {
|
||||
srv=$1
|
||||
name=${2-$1}
|
||||
procfolder=$4
|
||||
procfile=$5
|
||||
state='running'
|
||||
mem=0
|
||||
cpu=0
|
||||
rtime="0"
|
||||
|
||||
if [ $debug -eq 1 ]; then
|
||||
echo "---------------------"
|
||||
echo "$srv = $name"
|
||||
fi
|
||||
# Searching related pids
|
||||
if [ -z $3 ]; then
|
||||
pids=$(pidof $name |tr ' ' '|')
|
||||
|
@ -88,10 +102,23 @@ get_srv_state() {
|
|||
if [ -z "$pids" ] && [ "$name" != 'nginx' ]; then
|
||||
pids=$(pgrep $name |tr '\n' '|')
|
||||
fi
|
||||
if [ "$name" = 'elasticsearch' ]; then
|
||||
pids=$(ps -Af | grep 'elasticsearch' | grep -v 'grep' | awk '{print $2}' | tr '\n' '|')
|
||||
fi
|
||||
if [ "$name" = 'vesta-nginx' ]; then
|
||||
pids=$(ps -Af | grep 'vesta/nginx' | grep -v 'grep' | awk '{print $2}' | tr '\n' '|')
|
||||
fi
|
||||
if [ "$name" = 'vesta-php' ]; then
|
||||
pids=$(ps -Af | grep 'vesta/php' | grep -v 'grep' | awk '{print $2}' | tr '\n' '|')
|
||||
fi
|
||||
if [ $debug -eq 1 ]; then
|
||||
echo "pids = $pids"
|
||||
fi
|
||||
|
||||
# Checking pid
|
||||
if [ ! -z "$pids" ]; then
|
||||
if [ -n "$pids" ]; then
|
||||
pid=$(echo "$pids" |cut -f 1 -d '|')
|
||||
pids=${pids%|}
|
||||
pids=$(egrep "$pids" $tmp_file)
|
||||
|
||||
# Calculating CPU usage
|
||||
|
@ -103,7 +130,22 @@ get_srv_state() {
|
|||
|
||||
# Searching pid file
|
||||
pid_file=''
|
||||
if [ -e "/var/run/$srv.pid" ]; then
|
||||
if [ ! -z "$procfolder" ]; then
|
||||
if [ -f "/var/run/$procfolder/$srv.pid" ]; then
|
||||
pid_file="/var/run/$procfolder/$srv.pid"
|
||||
fi
|
||||
fi
|
||||
if [ -z "$pid_file" ] && [ ! -z "$procfolder" ] && [ ! -z "$procfile" ]; then
|
||||
if [ -f "/var/run/$procfolder/$procfile.pid" ]; then
|
||||
pid_file="/var/run/$procfolder/$procfile.pid"
|
||||
fi
|
||||
fi
|
||||
if [ -z "$pid_file" ] && [ -z "$procfolder" ] && [ ! -z "$procfile" ]; then
|
||||
if [ -f "/var/run/$procfile.pid" ]; then
|
||||
pid_file="/var/run/$procfile.pid"
|
||||
fi
|
||||
fi
|
||||
if [ -z "$pid_file" ] && [ -e "/var/run/$srv.pid" ]; then
|
||||
pid_file="/var/run/$srv.pid"
|
||||
fi
|
||||
if [ -z "$pid_file" ] && [ -e "/var/run/$srv/$srv.pid" ]; then
|
||||
|
@ -112,18 +154,31 @@ get_srv_state() {
|
|||
if [ -z "$pid_file" ] && [ -e "/var/run/$name/$name.pid" ]; then
|
||||
pid_file="/var/run/$name/$name.pid"
|
||||
fi
|
||||
if [ -z "$pid_file" ] && [ -f "/var/run/$name.pid" ]; then
|
||||
pid_file="/var/run/$name.pid"
|
||||
fi
|
||||
if [ -z "$pid_file" ] && [ -e "/proc/$pid" ]; then
|
||||
pid_file="/proc/$pid"
|
||||
fi
|
||||
|
||||
if [ $debug -eq 1 ]; then
|
||||
echo "$srv = $name = $pid_file"
|
||||
fi
|
||||
# Calculating uptime
|
||||
if [ ! -z "$pid_file" ]; then
|
||||
if [ -n "$pid_file" ]; then
|
||||
mtime=$(stat -c "%Y" $pid_file)
|
||||
rtime=$((ctime - mtime))
|
||||
rtime=$((rtime / 60))
|
||||
else
|
||||
rtime=0
|
||||
fi
|
||||
if [ "$pid_file" = "/proc/$pid" ]; then
|
||||
if [ $debug -eq 1 ]; then
|
||||
echo "getting pid lifetime via ps"
|
||||
fi
|
||||
rtime=$(ps -p 2877633 -o etimes | tail -n 1 | awk '{print $1}')
|
||||
rtime=$((rtime / 60))
|
||||
fi
|
||||
else
|
||||
state='stopped'
|
||||
mem=0
|
||||
|
@ -151,14 +206,6 @@ if [ ! -z "$WEB_SYSTEM" ] && [ "$WEB_SYSTEM" != 'remote' ]; then
|
|||
data="$data MEM='$mem' RTIME='$rtime'"
|
||||
fi
|
||||
|
||||
# Checking WEB Backend
|
||||
if [ ! -z "$WEB_BACKEND" ] && [ "$WEB_BACKEND" != 'remote' ]; then
|
||||
proc_name=$(ls /usr/sbin/php*fpm* | rev | cut -d'/' -f 1 | rev)
|
||||
get_srv_state $proc_name
|
||||
data="$data\nNAME='$WEB_BACKEND' SYSTEM='backend server' STATE='$state'"
|
||||
data="$data CPU='$cpu' MEM='$mem' RTIME='$rtime'"
|
||||
fi
|
||||
|
||||
# Checking WEB Proxy
|
||||
if [ ! -z "$PROXY_SYSTEM" ] && [ "$PROXY_SYSTEM" != 'remote' ]; then
|
||||
get_srv_state $PROXY_SYSTEM
|
||||
|
@ -166,6 +213,18 @@ if [ ! -z "$PROXY_SYSTEM" ] && [ "$PROXY_SYSTEM" != 'remote' ]; then
|
|||
data="$data CPU='$cpu' MEM='$mem' RTIME='$rtime'"
|
||||
fi
|
||||
|
||||
# Checking WEB Backend
|
||||
if [ "$WEB_BACKEND" != 'remote' ]; then
|
||||
php_versions=$(ls /usr/sbin/php*fpm* | cut -d'/' -f4 | sed 's|php-fpm||')
|
||||
for version in $php_versions; do
|
||||
proc_name="php-fpm${version}"
|
||||
service_name="php${version}-fpm"
|
||||
get_srv_state "$service_name" "$proc_name" '' 'php'
|
||||
data="$data\nNAME='$service_name' SYSTEM='backend server' STATE='$state'"
|
||||
data="$data CPU='$cpu' MEM='$mem' RTIME='$rtime'"
|
||||
done
|
||||
fi
|
||||
|
||||
# DNS
|
||||
service=$DNS_SYSTEM
|
||||
if [ ! -z "$service" ] && [ "$service" != 'remote' ]; then
|
||||
|
@ -177,14 +236,22 @@ fi
|
|||
|
||||
# Checking MAIL system
|
||||
if [ ! -z "$MAIL_SYSTEM" ] && [ "$MAIL_SYSTEM" != 'remote' ]; then
|
||||
get_srv_state $MAIL_SYSTEM
|
||||
if [ "$MAIL_SYSTEM" = "exim4" ]; then
|
||||
get_srv_state "$MAIL_SYSTEM" "$MAIL_SYSTEM" '' 'exim4' 'exim'
|
||||
else
|
||||
get_srv_state $MAIL_SYSTEM
|
||||
fi
|
||||
data="$data\nNAME='$MAIL_SYSTEM' SYSTEM='mail server' STATE='$state'"
|
||||
data="$data CPU='$cpu' MEM='$mem' RTIME='$rtime'"
|
||||
fi
|
||||
|
||||
# Checking MAIL IMAP
|
||||
if [ ! -z "$IMAP_SYSTEM" ] && [ "$IMAP_SYSTEM" != 'remote' ]; then
|
||||
get_srv_state $IMAP_SYSTEM
|
||||
if [ "$IMAP_SYSTEM" = "dovecot" ]; then
|
||||
get_srv_state "$IMAP_SYSTEM" "$IMAP_SYSTEM" '' 'dovecot' 'master'
|
||||
else
|
||||
get_srv_state $IMAP_SYSTEM
|
||||
fi
|
||||
data="$data\nNAME='$IMAP_SYSTEM' SYSTEM='pop/imap server' STATE='$state'"
|
||||
data="$data CPU='$cpu' MEM='$mem' RTIME='$rtime'"
|
||||
fi
|
||||
|
@ -200,11 +267,19 @@ if [ ! -z "$ANTIVIRUS_SYSTEM" ] && [ "$ANTIVIRUS_SYSTEM" != 'remote' ]; then
|
|||
if [ "$ANTIVIRUS_SYSTEM" == 'clamav-daemon' ];then
|
||||
proc_name='clamd'
|
||||
fi
|
||||
get_srv_state $ANTIVIRUS_SYSTEM $proc_name
|
||||
get_srv_state $ANTIVIRUS_SYSTEM $proc_name '' 'clamav' 'clamd'
|
||||
fi
|
||||
data="$data\nNAME='$ANTIVIRUS_SYSTEM' SYSTEM='email antivirus'"
|
||||
data="$data STATE='$state' CPU='$cpu' MEM='$mem' RTIME='$rtime'"
|
||||
proc_name=''
|
||||
if [ ! -d "/etc/sysconfig" ]; then
|
||||
if [ "$ANTIVIRUS_SYSTEM" == 'clamav-daemon' ];then
|
||||
get_srv_state "clamav-freshclam" "freshclam"
|
||||
data="$data\nNAME='clamav-freshclam' SYSTEM='email antivirus updater'"
|
||||
data="$data STATE='$state' CPU='$cpu' MEM='$mem' RTIME='$rtime'"
|
||||
proc_name=''
|
||||
fi
|
||||
fi
|
||||
fi
|
||||
|
||||
# Checking MAIL ANTISPAM
|
||||
|
@ -220,6 +295,7 @@ if [ ! -z "$DB_SYSTEM" ] && [ "$DB_SYSTEM" != 'remote' ]; then
|
|||
proc_name=''
|
||||
service="$db"
|
||||
if [ "$service" = 'mysql' ]; then
|
||||
proc_name='mysqld'
|
||||
release=$(cat /etc/debian_version | tr "." "\n" | head -n1)
|
||||
if [ "$release" -eq 11 ]; then
|
||||
service='mariadb'
|
||||
|
@ -243,7 +319,7 @@ if [ ! -z "$DB_SYSTEM" ] && [ "$DB_SYSTEM" != 'remote' ]; then
|
|||
proc_name='postgres'
|
||||
fi
|
||||
fi
|
||||
get_srv_state $service $proc_name
|
||||
get_srv_state $service $proc_name '' 'mysqld' 'mysqld'
|
||||
data="$data\nNAME='$service' SYSTEM='database server' STATE='$state'"
|
||||
data="$data CPU='$cpu' MEM='$mem' RTIME='$rtime'"
|
||||
proc_name=''
|
||||
|
@ -259,11 +335,28 @@ fi
|
|||
|
||||
# Checking CRON system
|
||||
if [ ! -z "$CRON_SYSTEM" ] && [ "$CRON_SYSTEM" != 'remote' ]; then
|
||||
get_srv_state $CRON_SYSTEM
|
||||
get_srv_state "$CRON_SYSTEM" "$CRON_SYSTEM" '' '' 'crond'
|
||||
data="$data\nNAME='$CRON_SYSTEM' SYSTEM='job scheduler' STATE='$state'"
|
||||
data="$data CPU='$cpu' MEM='$mem' RTIME='$rtime'"
|
||||
fi
|
||||
|
||||
# Checking SSH daemon
|
||||
if [ -e "/etc/ssh/sshd_config" ]; then
|
||||
get_srv_state 'ssh' 'ssh' '' '' 'sshd'
|
||||
data="$data\nNAME='ssh' SYSTEM='SSH Access' STATE='$state'"
|
||||
data="$data CPU='$cpu' MEM='$mem' RTIME='$rtime'"
|
||||
fi
|
||||
|
||||
# Checking Vesta nginx
|
||||
get_srv_state 'vesta' 'vesta-nginx' '' '' 'vesta-nginx'
|
||||
data="$data\nNAME='vesta-nginx' SYSTEM='Vesta nginx service' STATE='$state'"
|
||||
data="$data CPU='$cpu' MEM='$mem' RTIME='$rtime'"
|
||||
|
||||
# Checking Vesta php-fpm
|
||||
get_srv_state 'vesta' 'vesta-php' '' '' 'vesta-php'
|
||||
data="$data\nNAME='vesta-php' SYSTEM='Vesta php service' STATE='$state'"
|
||||
data="$data CPU='$cpu' MEM='$mem' RTIME='$rtime'"
|
||||
|
||||
# Checking FIREWALL system
|
||||
if [ ! -z "$FIREWALL_SYSTEM" ] && [ "$FIREWALL_SYSTEM" != 'remote' ]; then
|
||||
state="stopped"
|
||||
|
@ -277,11 +370,26 @@ fi
|
|||
|
||||
# Checking FIREWALL Fail2ban extention
|
||||
if [ ! -z "$FIREWALL_EXTENSION" ]; then
|
||||
get_srv_state $FIREWALL_EXTENSION fail2ban-server script
|
||||
get_srv_state "$FIREWALL_EXTENSION" 'fail2ban-server' 'script'
|
||||
data="$data\nNAME='$FIREWALL_EXTENSION' SYSTEM='brute-force monitor'"
|
||||
data="$data STATE='$state' CPU='$cpu' MEM='$mem' RTIME='$rtime'"
|
||||
fi
|
||||
|
||||
# Checking ElasticSearch
|
||||
if [ -d "/etc/elasticsearch" ]; then
|
||||
get_srv_state 'elasticsearch'
|
||||
data="$data\nNAME='elasticsearch' SYSTEM='ElasticSearch' STATE='$state'"
|
||||
data="$data CPU='$cpu' MEM='$mem' RTIME='$rtime'"
|
||||
fi
|
||||
|
||||
# Checking Redis
|
||||
if [ -d "/etc/redis" ]; then
|
||||
get_srv_state 'redis' 'redis-server' '' 'redis' 'redis-server'
|
||||
data="$data\nNAME='redis' SYSTEM='Redis' STATE='$state'"
|
||||
data="$data CPU='$cpu' MEM='$mem' RTIME='$rtime'"
|
||||
fi
|
||||
|
||||
|
||||
# Listing data
|
||||
case $format in
|
||||
json) json_list ;;
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue